@dsivd/prestations-ng 15.1.2 → 15.1.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -26,6 +26,23 @@ A change is considered **breaking** if you have to change your code or update yo
26
26
 
27
27
  ---
28
28
 
29
+ ## [15.1.4]
30
+
31
+ ### Updated
32
+
33
+ - [gesdem-error.component.html](projects/prestations-ng/src/gesdem-error/gesdem-error.component.html)
34
+ - display a custom message if the error page is displayed when the action status in `PENDING_PAYMENT`
35
+ - redirect to the last page if the error page is displayed when the action status is final (`TRANSFERRED`, `ABANDONED`)
36
+
37
+ ## [15.1.3]
38
+
39
+ ### Updated
40
+ - [foehn-input-nav13.component.ts](projects/prestations-ng/src/foehn-nav13/foehn-input-nav13.component.ts)
41
+ - pasting an AVS number (witouht the prefix `756`) in the first editable input will now expand it to the other inputs.
42
+
43
+ - [foehn-agenda-timeslot-panel.component.ts](projects/prestations-ng/src/foehn-agenda/foehn-agenda-timeslot-panel/foehn-agenda-timeslot-panel.component.ts)
44
+ - don't allow closing the panel if it would hide the selected slot
45
+
29
46
  ## [15.1.2]
30
47
 
31
48
  - [foehn-agenda.components.ts](projects/prestations-ng/src/foehn-agenda/foehn-agenda.component.ts)
Binary file
@@ -9,6 +9,7 @@ export class FoehnAgendaTimeslotPanelComponent extends FoehnInputComponent {
9
9
  super();
10
10
  this.dictionaryService = dictionaryService;
11
11
  this.isClosed = true;
12
+ this.canClose = true;
12
13
  this.DEFAULT_NB_VISISBLE_ELEMENTS = 22;
13
14
  this.keyboardNavigationAllowed = false;
14
15
  this.hasSelectedSlotInPanel = false;
@@ -99,6 +100,7 @@ export class FoehnAgendaTimeslotPanelComponent extends FoehnInputComponent {
99
100
  else {
100
101
  this.hasSelectedSlotInPanel = false;
101
102
  }
103
+ this.canClose = positionValue < this.nbVisibleElements;
102
104
  }
103
105
  onTimeFocusin() {
104
106
  this.keyboardNavigationAllowed = true;
@@ -214,7 +216,7 @@ FoehnAgendaTimeslotPanelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion
214
216
  useExisting: forwardRef(() => FoehnAgendaTimeslotPanelComponent),
215
217
  multi: true
216
218
  }
217
- ], viewQueries: [{ propertyName: "timeSlotButtonsElemRef", predicate: ["timeSlotButtonsElemRef"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<section\n *ngIf=\"calendar | async as loadedCalendar\"\n class=\"panel panel-default mb-3\"\n>\n <div class=\"panel-heading mt-2 mb-2 py-2 d-flex align-items-baseline\">\n <h3 class=\"h5 ml-3 mt-0 mb-0\">\n {{ capitalCaseFirstLetter(currentWeek.day) }}\n <span class=\"sr-only\" *ngIf=\"!!isSelected(timeInputValue)\">\n &nbsp;{{\n 'foehn-agenda-timeslot-panel.selected-time'\n | fromDictionary: { timeSelectedValue: timeInputValue }\n }}\n </span>\n </h3>\n <small *ngIf=\"!!currentWeek.timeSlots.length\" class=\"sr-only\">\n {{\n 'foehn-agenda-timeslot-panel.nbr-dispo'\n | fromDictionary\n : {\n nbElements: currentWeek.timeSlots.length.toString()\n }\n }}\n </small>\n <small\n *ngIf=\"!currentWeek.timeSlots.length\"\n class=\"font-italic align-self-end ml-2\"\n >\n {{ 'foehn-agenda-timeslot-panel.no-dispo' | fromDictionary }}\n </small>\n </div>\n\n <div\n *ngIf=\"!!currentWeek.timeSlots.length\"\n class=\"panel-body row d-flex flex-wrap ml-auto mr-auto pl-3\"\n (focusin)=\"onTimeFocusin()\"\n (focusout)=\"onTimeFocusout()\"\n role=\"application\"\n >\n <button\n *ngFor=\"let timeSlot of timeSlots; let index = index\"\n class=\"btn btn-info mr-2 mb-2\"\n #timeSlotButtonsElemRef\n [attr.id]=\"\n cleanIdForQuerySelector(currentWeek.day + '-' + timeSlot)\n \"\n [tabindex]=\"getTimeSlotTabIndex(timeSlot, index)\"\n [class.btn-danger]=\"isSelected(timeSlot)\"\n (click)=\"\n handleUserInput(\n currentWeek.day,\n currentWeek.date,\n timeSlot,\n loadedCalendar\n )\n \"\n [attr.aria-label]=\"\n getButtonTimeSlotAriaLabel(currentWeek.day, timeSlot)\n \"\n >\n {{ timeSlot }}\n </button>\n <div\n class=\"col-12 d-flex justify-content-end mb-1\"\n *ngIf=\"currentWeek.timeSlots.length > nbVisibleElements\"\n >\n <button\n class=\"btn btn-link show-more\"\n #timeSlotButtonsElemRef\n (click)=\"togglePanel()\"\n [attr.aria-label]=\"\n (isClosed\n ? 'foehn-agenda-timeslot-panel.show-more-sr-only'\n : 'foehn-agenda-timeslot-panel.show-less'\n )\n | fromDictionary\n : {\n nbrElementsHidden: timeslotRemaining.toString()\n }\n \"\n >\n {{\n (isClosed\n ? 'foehn.agenda-timeslot-panel.show-more'\n : 'foehn-agenda-timeslot-panel.show-less'\n )\n | fromDictionary\n : {\n nbrElementsHidden: timeslotRemaining.toString()\n }\n }}\n </button>\n </div>\n </div>\n</section>\n", styles: [".panel-default{border:1px solid #dfdfdf}.panel-heading{position:sticky;background-color:#fff;width:100%;top:0}.panel-heading small{font-size:.9rem}.panel-heading:focus{outline:0;box-shadow:inset 0 1px 1px #00000013,0 0 0 .2rem var(--vd-focus)}.panel-body .btn-info{padding-right:.4rem;padding-left:.4rem}.panel-body .btn-link{padding:0}.show-more{cursor:pointer;font-size:.9rem}\n"], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i2.AsyncPipe, "fromDictionary": i3.SdkDictionaryPipe } });
219
+ ], viewQueries: [{ propertyName: "timeSlotButtonsElemRef", predicate: ["timeSlotButtonsElemRef"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<section\n *ngIf=\"calendar | async as loadedCalendar\"\n class=\"panel panel-default mb-3\"\n>\n <div class=\"panel-heading mt-2 mb-2 py-2 d-flex align-items-baseline\">\n <h3 class=\"h5 ml-3 mt-0 mb-0\">\n {{ capitalCaseFirstLetter(currentWeek.day) }}\n <span class=\"sr-only\" *ngIf=\"!!isSelected(timeInputValue)\">\n &nbsp;{{\n 'foehn-agenda-timeslot-panel.selected-time'\n | fromDictionary: { timeSelectedValue: timeInputValue }\n }}\n </span>\n </h3>\n <small *ngIf=\"!!currentWeek.timeSlots.length\" class=\"sr-only\">\n {{\n 'foehn-agenda-timeslot-panel.nbr-dispo'\n | fromDictionary\n : {\n nbElements: currentWeek.timeSlots.length.toString()\n }\n }}\n </small>\n <small\n *ngIf=\"!currentWeek.timeSlots.length\"\n class=\"font-italic align-self-end ml-2\"\n >\n {{ 'foehn-agenda-timeslot-panel.no-dispo' | fromDictionary }}\n </small>\n </div>\n\n <div\n *ngIf=\"!!currentWeek.timeSlots.length\"\n class=\"panel-body row d-flex flex-wrap ml-auto mr-auto pl-3\"\n (focusin)=\"onTimeFocusin()\"\n (focusout)=\"onTimeFocusout()\"\n role=\"application\"\n >\n <button\n *ngFor=\"let timeSlot of timeSlots; let index = index\"\n class=\"btn btn-info mr-2 mb-2\"\n #timeSlotButtonsElemRef\n [attr.id]=\"\n cleanIdForQuerySelector(currentWeek.day + '-' + timeSlot)\n \"\n [tabindex]=\"getTimeSlotTabIndex(timeSlot, index)\"\n [class.btn-danger]=\"isSelected(timeSlot)\"\n (click)=\"\n handleUserInput(\n currentWeek.day,\n currentWeek.date,\n timeSlot,\n loadedCalendar\n )\n \"\n [attr.aria-label]=\"\n getButtonTimeSlotAriaLabel(currentWeek.day, timeSlot)\n \"\n >\n {{ timeSlot }}\n </button>\n <div\n class=\"col-12 d-flex justify-content-end mb-1\"\n *ngIf=\"currentWeek.timeSlots.length > nbVisibleElements && canClose\"\n >\n <button\n class=\"btn btn-link show-more\"\n #timeSlotButtonsElemRef\n (click)=\"togglePanel()\"\n [attr.aria-label]=\"\n (isClosed\n ? 'foehn-agenda-timeslot-panel.show-more-sr-only'\n : 'foehn-agenda-timeslot-panel.show-less'\n )\n | fromDictionary\n : {\n nbrElementsHidden: timeslotRemaining.toString()\n }\n \"\n >\n {{\n (isClosed\n ? 'foehn.agenda-timeslot-panel.show-more'\n : 'foehn-agenda-timeslot-panel.show-less'\n )\n | fromDictionary\n : {\n nbrElementsHidden: timeslotRemaining.toString()\n }\n }}\n </button>\n </div>\n </div>\n</section>\n", styles: [".panel-default{border:1px solid #dfdfdf}.panel-heading{position:sticky;background-color:#fff;width:100%;top:0}.panel-heading small{font-size:.9rem}.panel-heading:focus{outline:0;box-shadow:inset 0 1px 1px #00000013,0 0 0 .2rem var(--vd-focus)}.panel-body .btn-info{padding-right:.4rem;padding-left:.4rem}.panel-body .btn-link{padding:0}.show-more{cursor:pointer;font-size:.9rem}\n"], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i2.AsyncPipe, "fromDictionary": i3.SdkDictionaryPipe } });
218
220
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnAgendaTimeslotPanelComponent, decorators: [{
219
221
  type: Component,
220
222
  args: [{ selector: 'foehn-agenda-timeslot-panel', providers: [
@@ -223,7 +225,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImpor
223
225
  useExisting: forwardRef(() => FoehnAgendaTimeslotPanelComponent),
224
226
  multi: true
225
227
  }
226
- ], template: "<section\n *ngIf=\"calendar | async as loadedCalendar\"\n class=\"panel panel-default mb-3\"\n>\n <div class=\"panel-heading mt-2 mb-2 py-2 d-flex align-items-baseline\">\n <h3 class=\"h5 ml-3 mt-0 mb-0\">\n {{ capitalCaseFirstLetter(currentWeek.day) }}\n <span class=\"sr-only\" *ngIf=\"!!isSelected(timeInputValue)\">\n &nbsp;{{\n 'foehn-agenda-timeslot-panel.selected-time'\n | fromDictionary: { timeSelectedValue: timeInputValue }\n }}\n </span>\n </h3>\n <small *ngIf=\"!!currentWeek.timeSlots.length\" class=\"sr-only\">\n {{\n 'foehn-agenda-timeslot-panel.nbr-dispo'\n | fromDictionary\n : {\n nbElements: currentWeek.timeSlots.length.toString()\n }\n }}\n </small>\n <small\n *ngIf=\"!currentWeek.timeSlots.length\"\n class=\"font-italic align-self-end ml-2\"\n >\n {{ 'foehn-agenda-timeslot-panel.no-dispo' | fromDictionary }}\n </small>\n </div>\n\n <div\n *ngIf=\"!!currentWeek.timeSlots.length\"\n class=\"panel-body row d-flex flex-wrap ml-auto mr-auto pl-3\"\n (focusin)=\"onTimeFocusin()\"\n (focusout)=\"onTimeFocusout()\"\n role=\"application\"\n >\n <button\n *ngFor=\"let timeSlot of timeSlots; let index = index\"\n class=\"btn btn-info mr-2 mb-2\"\n #timeSlotButtonsElemRef\n [attr.id]=\"\n cleanIdForQuerySelector(currentWeek.day + '-' + timeSlot)\n \"\n [tabindex]=\"getTimeSlotTabIndex(timeSlot, index)\"\n [class.btn-danger]=\"isSelected(timeSlot)\"\n (click)=\"\n handleUserInput(\n currentWeek.day,\n currentWeek.date,\n timeSlot,\n loadedCalendar\n )\n \"\n [attr.aria-label]=\"\n getButtonTimeSlotAriaLabel(currentWeek.day, timeSlot)\n \"\n >\n {{ timeSlot }}\n </button>\n <div\n class=\"col-12 d-flex justify-content-end mb-1\"\n *ngIf=\"currentWeek.timeSlots.length > nbVisibleElements\"\n >\n <button\n class=\"btn btn-link show-more\"\n #timeSlotButtonsElemRef\n (click)=\"togglePanel()\"\n [attr.aria-label]=\"\n (isClosed\n ? 'foehn-agenda-timeslot-panel.show-more-sr-only'\n : 'foehn-agenda-timeslot-panel.show-less'\n )\n | fromDictionary\n : {\n nbrElementsHidden: timeslotRemaining.toString()\n }\n \"\n >\n {{\n (isClosed\n ? 'foehn.agenda-timeslot-panel.show-more'\n : 'foehn-agenda-timeslot-panel.show-less'\n )\n | fromDictionary\n : {\n nbrElementsHidden: timeslotRemaining.toString()\n }\n }}\n </button>\n </div>\n </div>\n</section>\n", styles: [".panel-default{border:1px solid #dfdfdf}.panel-heading{position:sticky;background-color:#fff;width:100%;top:0}.panel-heading small{font-size:.9rem}.panel-heading:focus{outline:0;box-shadow:inset 0 1px 1px #00000013,0 0 0 .2rem var(--vd-focus)}.panel-body .btn-info{padding-right:.4rem;padding-left:.4rem}.panel-body .btn-link{padding:0}.show-more{cursor:pointer;font-size:.9rem}\n"] }]
228
+ ], template: "<section\n *ngIf=\"calendar | async as loadedCalendar\"\n class=\"panel panel-default mb-3\"\n>\n <div class=\"panel-heading mt-2 mb-2 py-2 d-flex align-items-baseline\">\n <h3 class=\"h5 ml-3 mt-0 mb-0\">\n {{ capitalCaseFirstLetter(currentWeek.day) }}\n <span class=\"sr-only\" *ngIf=\"!!isSelected(timeInputValue)\">\n &nbsp;{{\n 'foehn-agenda-timeslot-panel.selected-time'\n | fromDictionary: { timeSelectedValue: timeInputValue }\n }}\n </span>\n </h3>\n <small *ngIf=\"!!currentWeek.timeSlots.length\" class=\"sr-only\">\n {{\n 'foehn-agenda-timeslot-panel.nbr-dispo'\n | fromDictionary\n : {\n nbElements: currentWeek.timeSlots.length.toString()\n }\n }}\n </small>\n <small\n *ngIf=\"!currentWeek.timeSlots.length\"\n class=\"font-italic align-self-end ml-2\"\n >\n {{ 'foehn-agenda-timeslot-panel.no-dispo' | fromDictionary }}\n </small>\n </div>\n\n <div\n *ngIf=\"!!currentWeek.timeSlots.length\"\n class=\"panel-body row d-flex flex-wrap ml-auto mr-auto pl-3\"\n (focusin)=\"onTimeFocusin()\"\n (focusout)=\"onTimeFocusout()\"\n role=\"application\"\n >\n <button\n *ngFor=\"let timeSlot of timeSlots; let index = index\"\n class=\"btn btn-info mr-2 mb-2\"\n #timeSlotButtonsElemRef\n [attr.id]=\"\n cleanIdForQuerySelector(currentWeek.day + '-' + timeSlot)\n \"\n [tabindex]=\"getTimeSlotTabIndex(timeSlot, index)\"\n [class.btn-danger]=\"isSelected(timeSlot)\"\n (click)=\"\n handleUserInput(\n currentWeek.day,\n currentWeek.date,\n timeSlot,\n loadedCalendar\n )\n \"\n [attr.aria-label]=\"\n getButtonTimeSlotAriaLabel(currentWeek.day, timeSlot)\n \"\n >\n {{ timeSlot }}\n </button>\n <div\n class=\"col-12 d-flex justify-content-end mb-1\"\n *ngIf=\"currentWeek.timeSlots.length > nbVisibleElements && canClose\"\n >\n <button\n class=\"btn btn-link show-more\"\n #timeSlotButtonsElemRef\n (click)=\"togglePanel()\"\n [attr.aria-label]=\"\n (isClosed\n ? 'foehn-agenda-timeslot-panel.show-more-sr-only'\n : 'foehn-agenda-timeslot-panel.show-less'\n )\n | fromDictionary\n : {\n nbrElementsHidden: timeslotRemaining.toString()\n }\n \"\n >\n {{\n (isClosed\n ? 'foehn.agenda-timeslot-panel.show-more'\n : 'foehn-agenda-timeslot-panel.show-less'\n )\n | fromDictionary\n : {\n nbrElementsHidden: timeslotRemaining.toString()\n }\n }}\n </button>\n </div>\n </div>\n</section>\n", styles: [".panel-default{border:1px solid #dfdfdf}.panel-heading{position:sticky;background-color:#fff;width:100%;top:0}.panel-heading small{font-size:.9rem}.panel-heading:focus{outline:0;box-shadow:inset 0 1px 1px #00000013,0 0 0 .2rem var(--vd-focus)}.panel-body .btn-info{padding-right:.4rem;padding-left:.4rem}.panel-body .btn-link{padding:0}.show-more{cursor:pointer;font-size:.9rem}\n"] }]
227
229
  }], ctorParameters: function () { return [{ type: i1.SdkDictionaryService }]; }, propDecorators: { timeSlotButtonsElemRef: [{
228
230
  type: ViewChildren,
229
231
  args: ['timeSlotButtonsElemRef']
@@ -237,4 +239,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImpor
237
239
  type: HostListener,
238
240
  args: ['keydown', ['$event']]
239
241
  }] } });
240
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-agenda-timeslot-panel.component.js","sourceRoot":"","sources":["../../../../../projects/prestations-ng/src/foehn-agenda/foehn-agenda-timeslot-panel/foehn-agenda-timeslot-panel.component.ts","../../../../../projects/prestations-ng/src/foehn-agenda/foehn-agenda-timeslot-panel/foehn-agenda-timeslot-panel.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    forwardRef,\n    HostListener,\n    Input,\n    OnChanges,\n    QueryList,\n    SimpleChange,\n    SimpleChanges,\n    ViewChildren\n} from '@angular/core';\nimport { FoehnInputComponent } from '../../foehn-input/foehn-input.component';\nimport { Observable } from 'rxjs';\nimport { SdkDictionaryService } from '../../sdk-dictionary/sdk-dictionary.service';\nimport { SelectedSlot } from '../selected-slot.type';\nimport { DaySlots } from '../day-slots.type';\nimport { Calendar } from '../calendar.type';\n\n@Component({\n    selector: 'foehn-agenda-timeslot-panel',\n    templateUrl: './foehn-agenda-timeslot-panel.component.html',\n    styleUrls: ['./foehn-agenda-timeslot-panel.component.css'],\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnAgendaTimeslotPanelComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnAgendaTimeslotPanelComponent\n    extends FoehnInputComponent<SelectedSlot>\n    implements OnChanges {\n    @ViewChildren('timeSlotButtonsElemRef')\n    timeSlotButtonsElemRef: QueryList<ElementRef>;\n\n    @Input()\n    calendar: Observable<Calendar>;\n\n    @Input()\n    nbVisibleElements: number;\n\n    selectedTimeSlot: string;\n    timeSlots: string[];\n    isClosed = true;\n    timeslotRemaining: number;\n    timeInputValue: string;\n\n    readonly DEFAULT_NB_VISISBLE_ELEMENTS = 22;\n\n    private currentWeek_: DaySlots;\n    private dayInputValue: string;\n    private keyboardNavigationAllowed = false;\n    private currentActiveElement: Element;\n    private hasSelectedSlotInPanel = false;\n\n    constructor(private dictionaryService: SdkDictionaryService) {\n        super();\n        this.nbVisibleElements = this.DEFAULT_NB_VISISBLE_ELEMENTS;\n    }\n\n    get currentWeek(): DaySlots {\n        return this.currentWeek_;\n    }\n\n    @Input()\n    set currentWeek(value: DaySlots) {\n        this.currentWeek_ = value;\n        this.sliceNbVisibleElements();\n    }\n\n    @HostListener('keydown', ['$event'])\n    handleKeyboardDownEvent(event: KeyboardEvent): void {\n        if (this.keyboardNavigationAllowed) {\n            this.onKeyDownInner(event);\n        }\n    }\n\n    focus(): void {\n        const timeSlotButtonsElemRefArray = [\n            ...this.timeSlotButtonsElemRef.toArray()\n        ];\n        if (!!timeSlotButtonsElemRefArray.length) {\n            timeSlotButtonsElemRefArray[0].nativeElement.focus();\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        this.onNbVisibleElementsChange(changes.nbVisibleElements);\n    }\n\n    capitalCaseFirstLetter(s: string): string {\n        if (!s) {\n            return s;\n        }\n        if (s.length === 1) {\n            return s.toUpperCase();\n        }\n        return `${s.charAt(0).toUpperCase()}${s.slice(1)}`;\n    }\n\n    handleUserInput(\n        day: string,\n        date: number[],\n        time: string,\n        calendar: Calendar\n    ): void {\n        const validValue = this.getValidValue(day, date, time, calendar);\n        if (typeof validValue !== 'undefined') {\n            this.userInput.next(validValue);\n            this.updateNgModel(validValue);\n        }\n    }\n\n    togglePanel(): void {\n        this.isClosed = !this.isClosed;\n        if (this.isClosed) {\n            this.sliceNbVisibleElements();\n        } else {\n            // Need setTimeout because we are outside angular cycle when reloading page\n            setTimeout(() => {\n                this.timeSlots = this.currentWeek.timeSlots;\n            });\n        }\n    }\n\n    onModelChange(value: SelectedSlot): void {\n        if (value) {\n            this.selectedTimeSlot = `${value.day}-${value.time}`;\n            this.timeInputValue = value.time;\n            this.dayInputValue = value.day;\n        } else if (!value) {\n            this.selectedTimeSlot = null;\n            this.timeInputValue = null;\n            this.dayInputValue = null;\n        }\n        this.searchTimeValueInTimeSlot();\n    }\n\n    getTimeInputValue(s: string): string {\n        if (!!s) {\n            const valueSplit = s.split('-');\n            if (valueSplit.length >= 2) {\n                return valueSplit[1];\n            }\n        }\n        return s;\n    }\n\n    searchTimeValueInTimeSlot(): void {\n        const positionValue = this.currentWeek.timeSlots.findIndex(\n            x =>\n                x === this.timeInputValue &&\n                this.currentWeek.day === this.dayInputValue\n        );\n        if (positionValue !== -1 && !!this.selectedTimeSlot) {\n            this.hasSelectedSlotInPanel = true;\n            if (this.isClosed && positionValue >= this.nbVisibleElements) {\n                this.togglePanel();\n            }\n        } else {\n            this.hasSelectedSlotInPanel = false;\n        }\n    }\n\n    onTimeFocusin(): void {\n        this.keyboardNavigationAllowed = true;\n        this.currentActiveElement = document.activeElement;\n    }\n\n    onTimeFocusout(): void {\n        this.keyboardNavigationAllowed = false;\n    }\n\n    isSelected(timeSlot: string): boolean {\n        if (!this.selectedTimeSlot) {\n            return false;\n        }\n        return (\n            timeSlot === this.timeInputValue &&\n            this.currentWeek.day === this.dayInputValue\n        );\n    }\n\n    getButtonTimeSlotAriaLabel(day: string, timeSlot: string): string {\n        let result = `${day} ${timeSlot}`;\n        if (this.isSelected(timeSlot)) {\n            result += this.dictionaryService.getKeySync(\n                'foehn-agenda.timeslot.selected'\n            );\n        }\n        return result;\n    }\n\n    getTimeSlotTabIndex(timeSlot: string, index: number): number {\n        if (this.isSelected(timeSlot)) {\n            return 0;\n        }\n        if (!index && !this.hasSelectedSlotInPanel) {\n            return 0;\n        }\n        return -1;\n    }\n\n    cleanIdForQuerySelector(s: string): string {\n        s = s.replace(new RegExp(' ', 'g'), '_');\n        return s.replace(new RegExp(':', 'g'), '_');\n    }\n\n    private sliceNbVisibleElements(): void {\n        if (!this.nbVisibleElements) {\n            this.nbVisibleElements = this.DEFAULT_NB_VISISBLE_ELEMENTS;\n        }\n        this.timeSlots = this.currentWeek.timeSlots.slice(\n            0,\n            this.nbVisibleElements\n        );\n        this.timeslotRemaining =\n            this.currentWeek.timeSlots.length - this.nbVisibleElements;\n    }\n\n    private getValidValue(\n        day: string,\n        date: number[],\n        time: string,\n        calendar: Calendar\n    ): SelectedSlot | null | undefined {\n        if (!day || !time) {\n            if (this.model_ !== undefined) {\n                return null;\n            }\n            return undefined;\n        }\n        return {\n            day,\n            time,\n            year: calendar.currentWeek.year,\n            weekNumber: calendar.currentWeek.weekNumber,\n            date\n        };\n    }\n\n    private onNbVisibleElementsChange(change: SimpleChange): void {\n        if (change) {\n            this.sliceNbVisibleElements();\n        }\n    }\n\n    private onKeyDownInner(keyEvent: KeyboardEvent): boolean {\n        // IE doesn't support keyEvent.code, and has different values\n        // in keyEvent.key (Down instead of ArrowDown for instance), hence the multi-support.\n        const ie11CompatibleCode = keyEvent.code || keyEvent.key;\n        switch (ie11CompatibleCode) {\n            case 'Down':\n            case 'ArrowDown':\n            case 'Right':\n            case 'ArrowRight':\n                this.focusTimeSlot(1);\n                break;\n            case 'Up':\n            case 'ArrowUp':\n            case 'Left':\n            case 'ArrowLeft':\n                this.focusTimeSlot(-1);\n                break;\n            case 'Space':\n            case 'Spacebar':\n            case 'Enter':\n                document.activeElement.dispatchEvent(new Event('click'));\n                break;\n            default:\n                return true;\n        }\n\n        keyEvent.preventDefault();\n        keyEvent.stopPropagation();\n\n        return false;\n    }\n\n    private focusTimeSlot(inc: number): void {\n        const buttonsArray = [...this.timeSlotButtonsElemRef.toArray()];\n        const indexselected = buttonsArray.findIndex(\n            item =>\n                item.nativeElement.getAttribute('id') ===\n                this.currentActiveElement.getAttribute('id')\n        );\n        const newIndex = indexselected + inc;\n        if (newIndex >= buttonsArray.length) {\n            buttonsArray[0].nativeElement.focus();\n        } else if (newIndex < 0) {\n            buttonsArray[buttonsArray.length - 1].nativeElement.focus();\n        } else {\n            buttonsArray[newIndex].nativeElement.focus();\n        }\n    }\n}\n","<section\n    *ngIf=\"calendar | async as loadedCalendar\"\n    class=\"panel panel-default mb-3\"\n>\n    <div class=\"panel-heading mt-2 mb-2 py-2 d-flex align-items-baseline\">\n        <h3 class=\"h5 ml-3 mt-0 mb-0\">\n            {{ capitalCaseFirstLetter(currentWeek.day) }}\n            <span class=\"sr-only\" *ngIf=\"!!isSelected(timeInputValue)\">\n                &nbsp;{{\n                    'foehn-agenda-timeslot-panel.selected-time'\n                        | fromDictionary: { timeSelectedValue: timeInputValue }\n                }}\n            </span>\n        </h3>\n        <small *ngIf=\"!!currentWeek.timeSlots.length\" class=\"sr-only\">\n            {{\n                'foehn-agenda-timeslot-panel.nbr-dispo'\n                    | fromDictionary\n                        : {\n                              nbElements: currentWeek.timeSlots.length.toString()\n                          }\n            }}\n        </small>\n        <small\n            *ngIf=\"!currentWeek.timeSlots.length\"\n            class=\"font-italic align-self-end ml-2\"\n        >\n            {{ 'foehn-agenda-timeslot-panel.no-dispo' | fromDictionary }}\n        </small>\n    </div>\n\n    <div\n        *ngIf=\"!!currentWeek.timeSlots.length\"\n        class=\"panel-body row d-flex flex-wrap ml-auto mr-auto pl-3\"\n        (focusin)=\"onTimeFocusin()\"\n        (focusout)=\"onTimeFocusout()\"\n        role=\"application\"\n    >\n        <button\n            *ngFor=\"let timeSlot of timeSlots; let index = index\"\n            class=\"btn btn-info mr-2 mb-2\"\n            #timeSlotButtonsElemRef\n            [attr.id]=\"\n                cleanIdForQuerySelector(currentWeek.day + '-' + timeSlot)\n            \"\n            [tabindex]=\"getTimeSlotTabIndex(timeSlot, index)\"\n            [class.btn-danger]=\"isSelected(timeSlot)\"\n            (click)=\"\n                handleUserInput(\n                    currentWeek.day,\n                    currentWeek.date,\n                    timeSlot,\n                    loadedCalendar\n                )\n            \"\n            [attr.aria-label]=\"\n                getButtonTimeSlotAriaLabel(currentWeek.day, timeSlot)\n            \"\n        >\n            {{ timeSlot }}\n        </button>\n        <div\n            class=\"col-12 d-flex justify-content-end mb-1\"\n            *ngIf=\"currentWeek.timeSlots.length > nbVisibleElements\"\n        >\n            <button\n                class=\"btn btn-link show-more\"\n                #timeSlotButtonsElemRef\n                (click)=\"togglePanel()\"\n                [attr.aria-label]=\"\n                    (isClosed\n                        ? 'foehn-agenda-timeslot-panel.show-more-sr-only'\n                        : 'foehn-agenda-timeslot-panel.show-less'\n                    )\n                        | fromDictionary\n                            : {\n                                  nbrElementsHidden: timeslotRemaining.toString()\n                              }\n                \"\n            >\n                {{\n                    (isClosed\n                        ? 'foehn.agenda-timeslot-panel.show-more'\n                        : 'foehn-agenda-timeslot-panel.show-less'\n                    )\n                        | fromDictionary\n                            : {\n                                  nbrElementsHidden: timeslotRemaining.toString()\n                              }\n                }}\n            </button>\n        </div>\n    </div>\n</section>\n"]}
242
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-agenda-timeslot-panel.component.js","sourceRoot":"","sources":["../../../../../projects/prestations-ng/src/foehn-agenda/foehn-agenda-timeslot-panel/foehn-agenda-timeslot-panel.component.ts","../../../../../projects/prestations-ng/src/foehn-agenda/foehn-agenda-timeslot-panel/foehn-agenda-timeslot-panel.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    forwardRef,\n    HostListener,\n    Input,\n    OnChanges,\n    QueryList,\n    SimpleChange,\n    SimpleChanges,\n    ViewChildren\n} from '@angular/core';\nimport { FoehnInputComponent } from '../../foehn-input/foehn-input.component';\nimport { Observable } from 'rxjs';\nimport { SdkDictionaryService } from '../../sdk-dictionary/sdk-dictionary.service';\nimport { SelectedSlot } from '../selected-slot.type';\nimport { DaySlots } from '../day-slots.type';\nimport { Calendar } from '../calendar.type';\n\n@Component({\n    selector: 'foehn-agenda-timeslot-panel',\n    templateUrl: './foehn-agenda-timeslot-panel.component.html',\n    styleUrls: ['./foehn-agenda-timeslot-panel.component.css'],\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnAgendaTimeslotPanelComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnAgendaTimeslotPanelComponent\n    extends FoehnInputComponent<SelectedSlot>\n    implements OnChanges {\n    @ViewChildren('timeSlotButtonsElemRef')\n    timeSlotButtonsElemRef: QueryList<ElementRef>;\n\n    @Input()\n    calendar: Observable<Calendar>;\n\n    @Input()\n    nbVisibleElements: number;\n\n    selectedTimeSlot: string;\n    timeSlots: string[];\n    isClosed = true;\n    timeslotRemaining: number;\n    timeInputValue: string;\n    canClose = true;\n\n    readonly DEFAULT_NB_VISISBLE_ELEMENTS = 22;\n\n    private currentWeek_: DaySlots;\n    private dayInputValue: string;\n    private keyboardNavigationAllowed = false;\n    private currentActiveElement: Element;\n    private hasSelectedSlotInPanel = false;\n\n    constructor(private dictionaryService: SdkDictionaryService) {\n        super();\n        this.nbVisibleElements = this.DEFAULT_NB_VISISBLE_ELEMENTS;\n    }\n\n    get currentWeek(): DaySlots {\n        return this.currentWeek_;\n    }\n\n    @Input()\n    set currentWeek(value: DaySlots) {\n        this.currentWeek_ = value;\n        this.sliceNbVisibleElements();\n    }\n\n    @HostListener('keydown', ['$event'])\n    handleKeyboardDownEvent(event: KeyboardEvent): void {\n        if (this.keyboardNavigationAllowed) {\n            this.onKeyDownInner(event);\n        }\n    }\n\n    focus(): void {\n        const timeSlotButtonsElemRefArray = [\n            ...this.timeSlotButtonsElemRef.toArray()\n        ];\n        if (!!timeSlotButtonsElemRefArray.length) {\n            timeSlotButtonsElemRefArray[0].nativeElement.focus();\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        this.onNbVisibleElementsChange(changes.nbVisibleElements);\n    }\n\n    capitalCaseFirstLetter(s: string): string {\n        if (!s) {\n            return s;\n        }\n        if (s.length === 1) {\n            return s.toUpperCase();\n        }\n        return `${s.charAt(0).toUpperCase()}${s.slice(1)}`;\n    }\n\n    handleUserInput(\n        day: string,\n        date: number[],\n        time: string,\n        calendar: Calendar\n    ): void {\n        const validValue = this.getValidValue(day, date, time, calendar);\n        if (typeof validValue !== 'undefined') {\n            this.userInput.next(validValue);\n            this.updateNgModel(validValue);\n        }\n    }\n\n    togglePanel(): void {\n        this.isClosed = !this.isClosed;\n        if (this.isClosed) {\n            this.sliceNbVisibleElements();\n        } else {\n            // Need setTimeout because we are outside angular cycle when reloading page\n            setTimeout(() => {\n                this.timeSlots = this.currentWeek.timeSlots;\n            });\n        }\n    }\n\n    onModelChange(value: SelectedSlot): void {\n        if (value) {\n            this.selectedTimeSlot = `${value.day}-${value.time}`;\n            this.timeInputValue = value.time;\n            this.dayInputValue = value.day;\n        } else if (!value) {\n            this.selectedTimeSlot = null;\n            this.timeInputValue = null;\n            this.dayInputValue = null;\n        }\n        this.searchTimeValueInTimeSlot();\n    }\n\n    getTimeInputValue(s: string): string {\n        if (!!s) {\n            const valueSplit = s.split('-');\n            if (valueSplit.length >= 2) {\n                return valueSplit[1];\n            }\n        }\n        return s;\n    }\n\n    searchTimeValueInTimeSlot(): void {\n        const positionValue = this.currentWeek.timeSlots.findIndex(\n            x =>\n                x === this.timeInputValue &&\n                this.currentWeek.day === this.dayInputValue\n        );\n        if (positionValue !== -1 && !!this.selectedTimeSlot) {\n            this.hasSelectedSlotInPanel = true;\n            if (this.isClosed && positionValue >= this.nbVisibleElements) {\n                this.togglePanel();\n            }\n        } else {\n            this.hasSelectedSlotInPanel = false;\n        }\n        this.canClose = positionValue < this.nbVisibleElements;\n    }\n\n    onTimeFocusin(): void {\n        this.keyboardNavigationAllowed = true;\n        this.currentActiveElement = document.activeElement;\n    }\n\n    onTimeFocusout(): void {\n        this.keyboardNavigationAllowed = false;\n    }\n\n    isSelected(timeSlot: string): boolean {\n        if (!this.selectedTimeSlot) {\n            return false;\n        }\n        return (\n            timeSlot === this.timeInputValue &&\n            this.currentWeek.day === this.dayInputValue\n        );\n    }\n\n    getButtonTimeSlotAriaLabel(day: string, timeSlot: string): string {\n        let result = `${day} ${timeSlot}`;\n        if (this.isSelected(timeSlot)) {\n            result += this.dictionaryService.getKeySync(\n                'foehn-agenda.timeslot.selected'\n            );\n        }\n        return result;\n    }\n\n    getTimeSlotTabIndex(timeSlot: string, index: number): number {\n        if (this.isSelected(timeSlot)) {\n            return 0;\n        }\n        if (!index && !this.hasSelectedSlotInPanel) {\n            return 0;\n        }\n        return -1;\n    }\n\n    cleanIdForQuerySelector(s: string): string {\n        s = s.replace(new RegExp(' ', 'g'), '_');\n        return s.replace(new RegExp(':', 'g'), '_');\n    }\n\n    private sliceNbVisibleElements(): void {\n        if (!this.nbVisibleElements) {\n            this.nbVisibleElements = this.DEFAULT_NB_VISISBLE_ELEMENTS;\n        }\n        this.timeSlots = this.currentWeek.timeSlots.slice(\n            0,\n            this.nbVisibleElements\n        );\n        this.timeslotRemaining =\n            this.currentWeek.timeSlots.length - this.nbVisibleElements;\n    }\n\n    private getValidValue(\n        day: string,\n        date: number[],\n        time: string,\n        calendar: Calendar\n    ): SelectedSlot | null | undefined {\n        if (!day || !time) {\n            if (this.model_ !== undefined) {\n                return null;\n            }\n            return undefined;\n        }\n        return {\n            day,\n            time,\n            year: calendar.currentWeek.year,\n            weekNumber: calendar.currentWeek.weekNumber,\n            date\n        };\n    }\n\n    private onNbVisibleElementsChange(change: SimpleChange): void {\n        if (change) {\n            this.sliceNbVisibleElements();\n        }\n    }\n\n    private onKeyDownInner(keyEvent: KeyboardEvent): boolean {\n        // IE doesn't support keyEvent.code, and has different values\n        // in keyEvent.key (Down instead of ArrowDown for instance), hence the multi-support.\n        const ie11CompatibleCode = keyEvent.code || keyEvent.key;\n        switch (ie11CompatibleCode) {\n            case 'Down':\n            case 'ArrowDown':\n            case 'Right':\n            case 'ArrowRight':\n                this.focusTimeSlot(1);\n                break;\n            case 'Up':\n            case 'ArrowUp':\n            case 'Left':\n            case 'ArrowLeft':\n                this.focusTimeSlot(-1);\n                break;\n            case 'Space':\n            case 'Spacebar':\n            case 'Enter':\n                document.activeElement.dispatchEvent(new Event('click'));\n                break;\n            default:\n                return true;\n        }\n\n        keyEvent.preventDefault();\n        keyEvent.stopPropagation();\n\n        return false;\n    }\n\n    private focusTimeSlot(inc: number): void {\n        const buttonsArray = [...this.timeSlotButtonsElemRef.toArray()];\n        const indexselected = buttonsArray.findIndex(\n            item =>\n                item.nativeElement.getAttribute('id') ===\n                this.currentActiveElement.getAttribute('id')\n        );\n        const newIndex = indexselected + inc;\n        if (newIndex >= buttonsArray.length) {\n            buttonsArray[0].nativeElement.focus();\n        } else if (newIndex < 0) {\n            buttonsArray[buttonsArray.length - 1].nativeElement.focus();\n        } else {\n            buttonsArray[newIndex].nativeElement.focus();\n        }\n    }\n}\n","<section\n    *ngIf=\"calendar | async as loadedCalendar\"\n    class=\"panel panel-default mb-3\"\n>\n    <div class=\"panel-heading mt-2 mb-2 py-2 d-flex align-items-baseline\">\n        <h3 class=\"h5 ml-3 mt-0 mb-0\">\n            {{ capitalCaseFirstLetter(currentWeek.day) }}\n            <span class=\"sr-only\" *ngIf=\"!!isSelected(timeInputValue)\">\n                &nbsp;{{\n                    'foehn-agenda-timeslot-panel.selected-time'\n                        | fromDictionary: { timeSelectedValue: timeInputValue }\n                }}\n            </span>\n        </h3>\n        <small *ngIf=\"!!currentWeek.timeSlots.length\" class=\"sr-only\">\n            {{\n                'foehn-agenda-timeslot-panel.nbr-dispo'\n                    | fromDictionary\n                        : {\n                              nbElements: currentWeek.timeSlots.length.toString()\n                          }\n            }}\n        </small>\n        <small\n            *ngIf=\"!currentWeek.timeSlots.length\"\n            class=\"font-italic align-self-end ml-2\"\n        >\n            {{ 'foehn-agenda-timeslot-panel.no-dispo' | fromDictionary }}\n        </small>\n    </div>\n\n    <div\n        *ngIf=\"!!currentWeek.timeSlots.length\"\n        class=\"panel-body row d-flex flex-wrap ml-auto mr-auto pl-3\"\n        (focusin)=\"onTimeFocusin()\"\n        (focusout)=\"onTimeFocusout()\"\n        role=\"application\"\n    >\n        <button\n            *ngFor=\"let timeSlot of timeSlots; let index = index\"\n            class=\"btn btn-info mr-2 mb-2\"\n            #timeSlotButtonsElemRef\n            [attr.id]=\"\n                cleanIdForQuerySelector(currentWeek.day + '-' + timeSlot)\n            \"\n            [tabindex]=\"getTimeSlotTabIndex(timeSlot, index)\"\n            [class.btn-danger]=\"isSelected(timeSlot)\"\n            (click)=\"\n                handleUserInput(\n                    currentWeek.day,\n                    currentWeek.date,\n                    timeSlot,\n                    loadedCalendar\n                )\n            \"\n            [attr.aria-label]=\"\n                getButtonTimeSlotAriaLabel(currentWeek.day, timeSlot)\n            \"\n        >\n            {{ timeSlot }}\n        </button>\n        <div\n            class=\"col-12 d-flex justify-content-end mb-1\"\n            *ngIf=\"currentWeek.timeSlots.length > nbVisibleElements && canClose\"\n        >\n            <button\n                class=\"btn btn-link show-more\"\n                #timeSlotButtonsElemRef\n                (click)=\"togglePanel()\"\n                [attr.aria-label]=\"\n                    (isClosed\n                        ? 'foehn-agenda-timeslot-panel.show-more-sr-only'\n                        : 'foehn-agenda-timeslot-panel.show-less'\n                    )\n                        | fromDictionary\n                            : {\n                                  nbrElementsHidden: timeslotRemaining.toString()\n                              }\n                \"\n            >\n                {{\n                    (isClosed\n                        ? 'foehn.agenda-timeslot-panel.show-more'\n                        : 'foehn-agenda-timeslot-panel.show-less'\n                    )\n                        | fromDictionary\n                            : {\n                                  nbrElementsHidden: timeslotRemaining.toString()\n                              }\n                }}\n            </button>\n        </div>\n    </div>\n</section>\n"]}
@@ -56,7 +56,13 @@ export class FoehnInputNav13Component extends FoehnInputStringComponent {
56
56
  ?.replace(/ /g, '');
57
57
  const isPastedValueMoreThanOneAvsBlock = pastedValue?.length > 4;
58
58
  if (isPastedValueMoreThanOneAvsBlock) {
59
- this.onModelChange(pastedValue);
59
+ let valueToPaste = pastedValue;
60
+ if (!pastedValue.startsWith(this.PREFIX_NAVS)) {
61
+ valueToPaste = pastedValue.includes('.')
62
+ ? `${this.PREFIX_NAVS}.${pastedValue}`
63
+ : this.PREFIX_NAVS + pastedValue;
64
+ }
65
+ this.onModelChange(valueToPaste);
60
66
  this.handleUserInput();
61
67
  event.preventDefault();
62
68
  }
@@ -105,4 +111,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImpor
105
111
  }
106
112
  ], 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\n [attr.for]=\"buildChildId()\"\n [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\"\n >\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=\"form-text text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"vd-form-flex\">\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--4-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--3-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part1Child'\"\n class=\"sr-only\"\n >\n Code du pays\n </label>\n <small\n [id]=\"buildId() + '_part1ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Etant obligatoirement un num\u00E9ro AVS suisse, ce\n champs est pr\u00E9rempli\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part1'\"\n [id]=\"buildId() + '_part1'\"\n [model]=\"PREFIX_NAVS\"\n [maxlength]=\"3\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n [disabled]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n\n <div class=\"vd-form-flex__item vd-form-flex__item--4-char-width\">\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part2Child'\"\n class=\"sr-only\"\n >\n Premiers chiffres al\u00E9atoires et anonymes\n </label>\n <small\n [id]=\"buildId() + '_part2ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Saisir quatres chiffres :\n <abbr title=\"Exemple\">Ex.</abbr>\n : 1234\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part2'\"\n [id]=\"buildId() + '_part2'\"\n [(model)]=\"part2\"\n (modelChange)=\"updateNavs()\"\n [maxlength]=\"4\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n (paste)=\"onPaste($event)\"\n ></foehn-input-number>\n </div>\n </div>\n\n <div class=\"vd-form-flex__item vd-form-flex__item--4-char-width\">\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part3Child'\"\n class=\"sr-only\"\n >\n Deuxi\u00E8mes chiffres al\u00E9atoires et anonymes\n </label>\n <small\n [id]=\"buildId() + '_part3ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Saisir quatres chiffres :\n <abbr title=\"Exemple\">Ex.</abbr>\n : 5678\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part3'\"\n [id]=\"buildId() + '_part3'\"\n [(model)]=\"part3\"\n (modelChange)=\"updateNavs()\"\n [maxlength]=\"4\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n ></foehn-input-number>\n </div>\n </div>\n\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item vd-form-flex__item--3-char-width\"\n >\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part4Child'\"\n class=\"sr-only\"\n >\n Chiffre al\u00E9atoire et anonyme et num\u00E9ro de contr\u00F4le\n </label>\n <small\n [id]=\"buildId() + '_part4ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Saisir deux chiffres :\n <abbr title=\"Exemple\">Ex.</abbr>\n : 97\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part4'\"\n [id]=\"buildId() + '_part4'\"\n [(model)]=\"part4\"\n (modelChange)=\"updateNavs()\"\n [maxlength]=\"2\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n ></foehn-input-number>\n </div>\n </div>\n </div>\n </fieldset>\n</div>\n" }]
107
113
  }] });
108
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-input-nav13.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-nav13/foehn-input-nav13.component.ts","../../../../projects/prestations-ng/src/foehn-nav13/foehn-input-nav13.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, OnInit } from '@angular/core';\nimport { Observable, of } from 'rxjs';\nimport { FoehnInputStringComponent } from '../foehn-input/foehn-input-string.component';\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\n\n@Component({\n    selector: 'foehn-input-nav13',\n    templateUrl: './foehn-input-nav13.component.html',\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnInputNav13Component),\n            multi: true\n        }\n    ]\n})\nexport class FoehnInputNav13Component\n    extends FoehnInputStringComponent\n    implements OnInit {\n    PREFIX_NAVS = '756';\n    part2: string;\n    part3: string;\n    part4: string;\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        if (!this.helpText) {\n            this.helpText = 'Par exemple, 756 1234 5678 97';\n        }\n        if (!this.label) {\n            this.label = 'Votre numéro <abbr title=\"Numéro AVS\">AVS</abbr>';\n        }\n    }\n\n    updateNavs(): 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    onModelChange(value: string): void {\n        if (!!value) {\n            this.splitValue(value);\n        } else {\n            this.part2 = null;\n            this.part3 = null;\n            this.part4 = null;\n        }\n    }\n\n    displayClearButton(): Observable<boolean> {\n        // Override the clear button fonction not worry about the model at this stage.\n        return of(this.clearButton);\n    }\n\n    onPaste(event: ClipboardEvent): void {\n        if (this.preventPaste === true) {\n            event.preventDefault();\n        }\n\n        const pastedValue = event.clipboardData\n            .getData('text')\n            ?.replace(/ /g, '');\n        const isPastedValueMoreThanOneAvsBlock = pastedValue?.length > 4;\n\n        if (isPastedValueMoreThanOneAvsBlock) {\n            this.onModelChange(pastedValue);\n            this.handleUserInput();\n            event.preventDefault();\n        }\n    }\n\n    private splitValue(value: string): void {\n        if (value.length === 13 && !value.includes('.')) {\n            this.part2 = value.substr(3, 4);\n            this.part3 = value.substr(7, 4);\n            this.part4 = value.substr(11, 2);\n        } else {\n            const splitted = value.split('.');\n            this.part2 = splitted[1];\n            this.part3 = splitted[2];\n            this.part4 = splitted[3];\n        }\n    }\n\n    private getValidValue(): string | null | undefined {\n        if (!this.part2 && !this.part3 && !this.part4) {\n            if (this.model_ !== undefined) {\n                return null;\n            }\n\n            return undefined;\n        }\n        this.part2 = this.part2 || '';\n        this.part3 = this.part3 || '';\n        this.part4 = this.part4 || '';\n        return `${this.PREFIX_NAVS}.${this.part2}.${this.part3}.${this.part4}`;\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\n            [attr.for]=\"buildChildId()\"\n            [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\"\n        >\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=\"form-text text-secondary\"\n            [innerHTML]=\"helpText\"\n        ></small>\n\n        <ng-content></ng-content>\n\n        <div class=\"vd-form-flex\">\n            <div\n                [ngClass]=\"{\n                    'vd-form-flex__item--4-char-width':\n                        displayClearButton() | async,\n                    'vd-form-flex__item--3-char-width': !(\n                        displayClearButton() | async\n                    )\n                }\"\n                class=\"vd-form-flex__item\"\n            >\n                <div class=\"form-group\">\n                    <label\n                        [attr.for]=\"buildId() + '_part1Child'\"\n                        class=\"sr-only\"\n                    >\n                        Code du pays\n                    </label>\n                    <small\n                        [id]=\"buildId() + '_part1ChildHelp'\"\n                        class=\"form-text text-secondary\"\n                    >\n                        <span class=\"sr-only\">\n                            Etant obligatoirement un numéro AVS suisse, ce\n                            champs est prérempli\n                        </span>\n                    </small>\n\n                    <foehn-input-number\n                        [name]=\"name + '_part1'\"\n                        [id]=\"buildId() + '_part1'\"\n                        [model]=\"PREFIX_NAVS\"\n                        [maxlength]=\"3\"\n                        [autocomplete]=\"'off'\"\n                        [clearButton]=\"displayClearButton() | async\"\n                        [disabled]=\"true\"\n                    ></foehn-input-number>\n                </div>\n            </div>\n\n            <div class=\"vd-form-flex__item vd-form-flex__item--4-char-width\">\n                <div class=\"form-group\">\n                    <label\n                        [attr.for]=\"buildId() + '_part2Child'\"\n                        class=\"sr-only\"\n                    >\n                        Premiers chiffres aléatoires et anonymes\n                    </label>\n                    <small\n                        [id]=\"buildId() + '_part2ChildHelp'\"\n                        class=\"form-text text-secondary\"\n                    >\n                        <span class=\"sr-only\">\n                            Saisir quatres chiffres :\n                            <abbr title=\"Exemple\">Ex.</abbr>\n                            : 1234\n                        </span>\n                    </small>\n\n                    <foehn-input-number\n                        [name]=\"name + '_part2'\"\n                        [id]=\"buildId() + '_part2'\"\n                        [(model)]=\"part2\"\n                        (modelChange)=\"updateNavs()\"\n                        [maxlength]=\"4\"\n                        [autocomplete]=\"'off'\"\n                        [clearButton]=\"displayClearButton() | async\"\n                        (userInput)=\"handleUserInput()\"\n                        [isErrorInherited]=\"hasErrorsToDisplay()\"\n                        [disabled]=\"disabled\"\n                        (paste)=\"onPaste($event)\"\n                    ></foehn-input-number>\n                </div>\n            </div>\n\n            <div class=\"vd-form-flex__item vd-form-flex__item--4-char-width\">\n                <div class=\"form-group\">\n                    <label\n                        [attr.for]=\"buildId() + '_part3Child'\"\n                        class=\"sr-only\"\n                    >\n                        Deuxièmes chiffres aléatoires et anonymes\n                    </label>\n                    <small\n                        [id]=\"buildId() + '_part3ChildHelp'\"\n                        class=\"form-text text-secondary\"\n                    >\n                        <span class=\"sr-only\">\n                            Saisir quatres chiffres :\n                            <abbr title=\"Exemple\">Ex.</abbr>\n                            : 5678\n                        </span>\n                    </small>\n\n                    <foehn-input-number\n                        [name]=\"name + '_part3'\"\n                        [id]=\"buildId() + '_part3'\"\n                        [(model)]=\"part3\"\n                        (modelChange)=\"updateNavs()\"\n                        [maxlength]=\"4\"\n                        [autocomplete]=\"'off'\"\n                        [clearButton]=\"displayClearButton() | async\"\n                        (userInput)=\"handleUserInput()\"\n                        [isErrorInherited]=\"hasErrorsToDisplay()\"\n                        [disabled]=\"disabled\"\n                    ></foehn-input-number>\n                </div>\n            </div>\n\n            <div\n                [ngClass]=\"{\n                    'vd-form-flex__item--3-char-width':\n                        displayClearButton() | async,\n                    'vd-form-flex__item--2-char-width': !(\n                        displayClearButton() | async\n                    )\n                }\"\n                class=\"vd-form-flex__item vd-form-flex__item--3-char-width\"\n            >\n                <div class=\"form-group\">\n                    <label\n                        [attr.for]=\"buildId() + '_part4Child'\"\n                        class=\"sr-only\"\n                    >\n                        Chiffre aléatoire et anonyme et numéro de contrôle\n                    </label>\n                    <small\n                        [id]=\"buildId() + '_part4ChildHelp'\"\n                        class=\"form-text text-secondary\"\n                    >\n                        <span class=\"sr-only\">\n                            Saisir deux chiffres :\n                            <abbr title=\"Exemple\">Ex.</abbr>\n                            : 97\n                        </span>\n                    </small>\n\n                    <foehn-input-number\n                        [name]=\"name + '_part4'\"\n                        [id]=\"buildId() + '_part4'\"\n                        [(model)]=\"part4\"\n                        (modelChange)=\"updateNavs()\"\n                        [maxlength]=\"2\"\n                        [autocomplete]=\"'off'\"\n                        [clearButton]=\"displayClearButton() | async\"\n                        (userInput)=\"handleUserInput()\"\n                        [isErrorInherited]=\"hasErrorsToDisplay()\"\n                        [disabled]=\"disabled\"\n                    ></foehn-input-number>\n                </div>\n            </div>\n        </div>\n    </fieldset>\n</div>\n"]}
114
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-input-nav13.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-nav13/foehn-input-nav13.component.ts","../../../../projects/prestations-ng/src/foehn-nav13/foehn-input-nav13.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, OnInit } from '@angular/core';\nimport { Observable, of } from 'rxjs';\nimport { FoehnInputStringComponent } from '../foehn-input/foehn-input-string.component';\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\n\n@Component({\n    selector: 'foehn-input-nav13',\n    templateUrl: './foehn-input-nav13.component.html',\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnInputNav13Component),\n            multi: true\n        }\n    ]\n})\nexport class FoehnInputNav13Component\n    extends FoehnInputStringComponent\n    implements OnInit {\n    PREFIX_NAVS = '756';\n    part2: string;\n    part3: string;\n    part4: string;\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        if (!this.helpText) {\n            this.helpText = 'Par exemple, 756 1234 5678 97';\n        }\n        if (!this.label) {\n            this.label = 'Votre numéro <abbr title=\"Numéro AVS\">AVS</abbr>';\n        }\n    }\n\n    updateNavs(): 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    onModelChange(value: string): void {\n        if (!!value) {\n            this.splitValue(value);\n        } else {\n            this.part2 = null;\n            this.part3 = null;\n            this.part4 = null;\n        }\n    }\n\n    displayClearButton(): Observable<boolean> {\n        // Override the clear button fonction not worry about the model at this stage.\n        return of(this.clearButton);\n    }\n\n    onPaste(event: ClipboardEvent): void {\n        if (this.preventPaste === true) {\n            event.preventDefault();\n        }\n\n        const pastedValue = event.clipboardData\n            .getData('text')\n            ?.replace(/ /g, '');\n\n        const isPastedValueMoreThanOneAvsBlock = pastedValue?.length > 4;\n\n        if (isPastedValueMoreThanOneAvsBlock) {\n            let valueToPaste = pastedValue;\n            if (!pastedValue.startsWith(this.PREFIX_NAVS)) {\n                valueToPaste = pastedValue.includes('.')\n                    ? `${this.PREFIX_NAVS}.${pastedValue}`\n                    : this.PREFIX_NAVS + pastedValue;\n            }\n\n            this.onModelChange(valueToPaste);\n            this.handleUserInput();\n            event.preventDefault();\n        }\n    }\n\n    private splitValue(value: string): void {\n        if (value.length === 13 && !value.includes('.')) {\n            this.part2 = value.substr(3, 4);\n            this.part3 = value.substr(7, 4);\n            this.part4 = value.substr(11, 2);\n        } else {\n            const splitted = value.split('.');\n            this.part2 = splitted[1];\n            this.part3 = splitted[2];\n            this.part4 = splitted[3];\n        }\n    }\n\n    private getValidValue(): string | null | undefined {\n        if (!this.part2 && !this.part3 && !this.part4) {\n            if (this.model_ !== undefined) {\n                return null;\n            }\n\n            return undefined;\n        }\n        this.part2 = this.part2 || '';\n        this.part3 = this.part3 || '';\n        this.part4 = this.part4 || '';\n        return `${this.PREFIX_NAVS}.${this.part2}.${this.part3}.${this.part4}`;\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\n            [attr.for]=\"buildChildId()\"\n            [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\"\n        >\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=\"form-text text-secondary\"\n            [innerHTML]=\"helpText\"\n        ></small>\n\n        <ng-content></ng-content>\n\n        <div class=\"vd-form-flex\">\n            <div\n                [ngClass]=\"{\n                    'vd-form-flex__item--4-char-width':\n                        displayClearButton() | async,\n                    'vd-form-flex__item--3-char-width': !(\n                        displayClearButton() | async\n                    )\n                }\"\n                class=\"vd-form-flex__item\"\n            >\n                <div class=\"form-group\">\n                    <label\n                        [attr.for]=\"buildId() + '_part1Child'\"\n                        class=\"sr-only\"\n                    >\n                        Code du pays\n                    </label>\n                    <small\n                        [id]=\"buildId() + '_part1ChildHelp'\"\n                        class=\"form-text text-secondary\"\n                    >\n                        <span class=\"sr-only\">\n                            Etant obligatoirement un numéro AVS suisse, ce\n                            champs est prérempli\n                        </span>\n                    </small>\n\n                    <foehn-input-number\n                        [name]=\"name + '_part1'\"\n                        [id]=\"buildId() + '_part1'\"\n                        [model]=\"PREFIX_NAVS\"\n                        [maxlength]=\"3\"\n                        [autocomplete]=\"'off'\"\n                        [clearButton]=\"displayClearButton() | async\"\n                        [disabled]=\"true\"\n                    ></foehn-input-number>\n                </div>\n            </div>\n\n            <div class=\"vd-form-flex__item vd-form-flex__item--4-char-width\">\n                <div class=\"form-group\">\n                    <label\n                        [attr.for]=\"buildId() + '_part2Child'\"\n                        class=\"sr-only\"\n                    >\n                        Premiers chiffres aléatoires et anonymes\n                    </label>\n                    <small\n                        [id]=\"buildId() + '_part2ChildHelp'\"\n                        class=\"form-text text-secondary\"\n                    >\n                        <span class=\"sr-only\">\n                            Saisir quatres chiffres :\n                            <abbr title=\"Exemple\">Ex.</abbr>\n                            : 1234\n                        </span>\n                    </small>\n\n                    <foehn-input-number\n                        [name]=\"name + '_part2'\"\n                        [id]=\"buildId() + '_part2'\"\n                        [(model)]=\"part2\"\n                        (modelChange)=\"updateNavs()\"\n                        [maxlength]=\"4\"\n                        [autocomplete]=\"'off'\"\n                        [clearButton]=\"displayClearButton() | async\"\n                        (userInput)=\"handleUserInput()\"\n                        [isErrorInherited]=\"hasErrorsToDisplay()\"\n                        [disabled]=\"disabled\"\n                        (paste)=\"onPaste($event)\"\n                    ></foehn-input-number>\n                </div>\n            </div>\n\n            <div class=\"vd-form-flex__item vd-form-flex__item--4-char-width\">\n                <div class=\"form-group\">\n                    <label\n                        [attr.for]=\"buildId() + '_part3Child'\"\n                        class=\"sr-only\"\n                    >\n                        Deuxièmes chiffres aléatoires et anonymes\n                    </label>\n                    <small\n                        [id]=\"buildId() + '_part3ChildHelp'\"\n                        class=\"form-text text-secondary\"\n                    >\n                        <span class=\"sr-only\">\n                            Saisir quatres chiffres :\n                            <abbr title=\"Exemple\">Ex.</abbr>\n                            : 5678\n                        </span>\n                    </small>\n\n                    <foehn-input-number\n                        [name]=\"name + '_part3'\"\n                        [id]=\"buildId() + '_part3'\"\n                        [(model)]=\"part3\"\n                        (modelChange)=\"updateNavs()\"\n                        [maxlength]=\"4\"\n                        [autocomplete]=\"'off'\"\n                        [clearButton]=\"displayClearButton() | async\"\n                        (userInput)=\"handleUserInput()\"\n                        [isErrorInherited]=\"hasErrorsToDisplay()\"\n                        [disabled]=\"disabled\"\n                    ></foehn-input-number>\n                </div>\n            </div>\n\n            <div\n                [ngClass]=\"{\n                    'vd-form-flex__item--3-char-width':\n                        displayClearButton() | async,\n                    'vd-form-flex__item--2-char-width': !(\n                        displayClearButton() | async\n                    )\n                }\"\n                class=\"vd-form-flex__item vd-form-flex__item--3-char-width\"\n            >\n                <div class=\"form-group\">\n                    <label\n                        [attr.for]=\"buildId() + '_part4Child'\"\n                        class=\"sr-only\"\n                    >\n                        Chiffre aléatoire et anonyme et numéro de contrôle\n                    </label>\n                    <small\n                        [id]=\"buildId() + '_part4ChildHelp'\"\n                        class=\"form-text text-secondary\"\n                    >\n                        <span class=\"sr-only\">\n                            Saisir deux chiffres :\n                            <abbr title=\"Exemple\">Ex.</abbr>\n                            : 97\n                        </span>\n                    </small>\n\n                    <foehn-input-number\n                        [name]=\"name + '_part4'\"\n                        [id]=\"buildId() + '_part4'\"\n                        [(model)]=\"part4\"\n                        (modelChange)=\"updateNavs()\"\n                        [maxlength]=\"2\"\n                        [autocomplete]=\"'off'\"\n                        [clearButton]=\"displayClearButton() | async\"\n                        (userInput)=\"handleUserInput()\"\n                        [isErrorInherited]=\"hasErrorsToDisplay()\"\n                        [disabled]=\"disabled\"\n                    ></foehn-input-number>\n                </div>\n            </div>\n        </div>\n    </fieldset>\n</div>\n"]}
@@ -1,30 +1,52 @@
1
1
  import { Component, Input } from '@angular/core';
2
2
  import { FoehnNavigationService } from '../foehn-navigation/foehn-navigation.service';
3
3
  import { SESSION_EXPIRED } from '../gesdem/gesdem-error-handler.service';
4
+ import { ActionStatut, GesdemStatutUtils } from '../gesdem/gesdem-statut-utils';
5
+ import { of } from 'rxjs';
6
+ import { catchError, map, tap } from 'rxjs/operators';
4
7
  import * as i0 from "@angular/core";
5
8
  import * as i1 from "@angular/router";
6
9
  import * as i2 from "../foehn-navigation/foehn-navigation.service";
7
10
  import * as i3 from "../gesdem/gesdem-handler.service";
8
- import * as i4 from "../foehn-page/foehn-page.service";
9
- import * as i5 from "../sdk-support-alert/support-alert.service";
10
- import * as i6 from "../foehn-debug-summary/foehn-debug-summary.component";
11
- import * as i7 from "../gesdem-action-recovery/gesdem-action-recovery-login/gesdem-action-recovery-login.component";
12
- import * as i8 from "@angular/common";
11
+ import * as i4 from "../gesdem/gesdem-event.service";
12
+ import * as i5 from "../foehn-page/foehn-page.service";
13
+ import * as i6 from "../sdk-support-alert/support-alert.service";
14
+ import * as i7 from "../sdk-appinfo/application-info.service";
15
+ import * as i8 from "../foehn-debug-summary/foehn-debug-summary.component";
16
+ import * as i9 from "../gesdem-action-recovery/gesdem-action-recovery-login/gesdem-action-recovery-login.component";
17
+ import * as i10 from "@angular/common";
18
+ import * as i11 from "../sdk-dictionary/sdk-dictionary.pipe";
13
19
  export class GesdemErrorComponent {
14
- constructor(activatedRoute, navigation, gesdemService, foehnPageService, supportAlertService) {
20
+ constructor(activatedRoute, navigation, gesdemService, gesdemEventService, foehnPageService, supportAlertService, applicationInfoService) {
15
21
  this.activatedRoute = activatedRoute;
16
22
  this.navigation = navigation;
17
23
  this.gesdemService = gesdemService;
24
+ this.gesdemEventService = gesdemEventService;
18
25
  this.foehnPageService = foehnPageService;
19
26
  this.supportAlertService = supportAlertService;
27
+ this.applicationInfoService = applicationInfoService;
20
28
  this.setPageTitle = true;
21
29
  this.hasSessionExpired = false;
22
30
  const route = FoehnNavigationService.getRootRouteRecursive(activatedRoute.snapshot);
23
31
  navigation.initRoute(route);
24
32
  this.link = this.getBasePath();
33
+ this.reference = this.activatedRoute.snapshot.params.reference;
34
+ this.supportLink = this.applicationInfoService.getSafeSupportFormUrl(this.reference);
35
+ if (!this.reference?.length) {
36
+ this.isPendingPayment = of(false);
37
+ }
38
+ else {
39
+ this.isPendingPayment = this.gesdemService
40
+ .retrieve(this.reference)
41
+ .pipe(map(() => ActionStatut[this.gesdemService.lastResponse.meta
42
+ .statut]), tap(statut => {
43
+ if (GesdemStatutUtils.isFinal(statut)) {
44
+ this.navigation.last();
45
+ }
46
+ }), map(statut => statut === ActionStatut.PENDING_PAYMENT), catchError(() => of(false)));
47
+ }
25
48
  }
26
49
  ngOnInit() {
27
- this.reference = this.activatedRoute.snapshot.params.reference;
28
50
  if (this.reference) {
29
51
  const firstPage = this.getFirstPage();
30
52
  if (this.gesdemService.prefix) {
@@ -55,12 +77,12 @@ export class GesdemErrorComponent {
55
77
  return '/';
56
78
  }
57
79
  }
58
- GesdemErrorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: GesdemErrorComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.FoehnNavigationService }, { token: i3.GesdemHandlerService }, { token: i4.FoehnPageService }, { token: i5.SupportAlertService }], target: i0.ɵɵFactoryTarget.Component });
59
- GesdemErrorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: GesdemErrorComponent, selector: "gesdem-error", inputs: { setPageTitle: "setPageTitle" }, ngImport: i0, template: "<div class=\"vd-card mb-3\" *ngIf=\"!hasSessionExpired\">\n <div class=\"container\">\n <div class=\"row\">\n <div class=\"col-xs-8\">\n <div class=\"card-body\">\n <p class=\"card-text vd-card-text\">\n {{\n !!reference\n ? 'Vous pouvez essayer de reprendre votre demande en cliquant sur le lien ci-dessous'\n : 'Vous pouvez recommencer une demande en cliquant sur le lien ci-dessous'\n }}\n </p>\n <ul class=\"vd-list-links\">\n <li>\n <a [href]=\"link\">\n {{\n !!reference\n ? 'Reprendre ma demande'\n : 'Recommencer'\n }}\n </a>\n </li>\n </ul>\n <foehn-debug-summary></foehn-debug-summary>\n </div>\n </div>\n </div>\n </div>\n</div>\n\n<gesdem-action-recovery-login\n *ngIf=\"hasSessionExpired\"\n [reference]=\"reference\"\n [redirectTarget]=\"link\"\n></gesdem-action-recovery-login>\n", components: [{ type: i6.FoehnDebugSummaryComponent, selector: "foehn-debug-summary" }, { type: i7.GesdemActionRecoveryLoginComponent, selector: "gesdem-action-recovery-login", inputs: ["reference", "redirectTarget"] }], directives: [{ type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
80
+ GesdemErrorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: GesdemErrorComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.FoehnNavigationService }, { token: i3.GesdemHandlerService }, { token: i4.GesdemEventService }, { token: i5.FoehnPageService }, { token: i6.SupportAlertService }, { token: i7.ApplicationInfoService }], target: i0.ɵɵFactoryTarget.Component });
81
+ GesdemErrorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: GesdemErrorComponent, selector: "gesdem-error", inputs: { setPageTitle: "setPageTitle" }, ngImport: i0, template: "<div class=\"vd-card mb-3\" *ngIf=\"!hasSessionExpired\">\n <div class=\"container\">\n <div class=\"row\">\n <div class=\"col-xs-8\">\n <div class=\"card-body\">\n <ng-container *ngIf=\"(isPendingPayment | async) === true\">\n <p\n class=\"card-text vd-card-text alert alert-danger\"\n [innerHTML]=\"\n 'gesdem-error.text.pending-payment'\n | fromDictionary\n : {\n supportLink: (supportLink | async)\n }\n \"\n ></p>\n </ng-container>\n <ng-container *ngIf=\"(isPendingPayment | async) === false\">\n <p class=\"card-text vd-card-text\">\n {{\n (!!reference\n ? 'gesdem-error.text.has-reference'\n : 'gesdem-error.text.has-no-reference'\n ) | fromDictionary\n }}\n </p>\n <ul class=\"vd-list-links\">\n <li>\n <a [href]=\"link\">\n {{\n (!!reference\n ? 'gesdem-error.link.has-reference'\n : 'gesdem-error.link.has-no-reference'\n ) | fromDictionary\n }}\n </a>\n </li>\n </ul>\n </ng-container>\n\n <foehn-debug-summary></foehn-debug-summary>\n </div>\n </div>\n </div>\n </div>\n</div>\n\n<gesdem-action-recovery-login\n *ngIf=\"hasSessionExpired\"\n [reference]=\"reference\"\n [redirectTarget]=\"link\"\n></gesdem-action-recovery-login>\n", components: [{ type: i8.FoehnDebugSummaryComponent, selector: "foehn-debug-summary" }, { type: i9.GesdemActionRecoveryLoginComponent, selector: "gesdem-action-recovery-login", inputs: ["reference", "redirectTarget"] }], directives: [{ type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i10.AsyncPipe, "fromDictionary": i11.SdkDictionaryPipe } });
60
82
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: GesdemErrorComponent, decorators: [{
61
83
  type: Component,
62
- args: [{ selector: 'gesdem-error', template: "<div class=\"vd-card mb-3\" *ngIf=\"!hasSessionExpired\">\n <div class=\"container\">\n <div class=\"row\">\n <div class=\"col-xs-8\">\n <div class=\"card-body\">\n <p class=\"card-text vd-card-text\">\n {{\n !!reference\n ? 'Vous pouvez essayer de reprendre votre demande en cliquant sur le lien ci-dessous'\n : 'Vous pouvez recommencer une demande en cliquant sur le lien ci-dessous'\n }}\n </p>\n <ul class=\"vd-list-links\">\n <li>\n <a [href]=\"link\">\n {{\n !!reference\n ? 'Reprendre ma demande'\n : 'Recommencer'\n }}\n </a>\n </li>\n </ul>\n <foehn-debug-summary></foehn-debug-summary>\n </div>\n </div>\n </div>\n </div>\n</div>\n\n<gesdem-action-recovery-login\n *ngIf=\"hasSessionExpired\"\n [reference]=\"reference\"\n [redirectTarget]=\"link\"\n></gesdem-action-recovery-login>\n" }]
63
- }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.FoehnNavigationService }, { type: i3.GesdemHandlerService }, { type: i4.FoehnPageService }, { type: i5.SupportAlertService }]; }, propDecorators: { setPageTitle: [{
84
+ args: [{ selector: 'gesdem-error', template: "<div class=\"vd-card mb-3\" *ngIf=\"!hasSessionExpired\">\n <div class=\"container\">\n <div class=\"row\">\n <div class=\"col-xs-8\">\n <div class=\"card-body\">\n <ng-container *ngIf=\"(isPendingPayment | async) === true\">\n <p\n class=\"card-text vd-card-text alert alert-danger\"\n [innerHTML]=\"\n 'gesdem-error.text.pending-payment'\n | fromDictionary\n : {\n supportLink: (supportLink | async)\n }\n \"\n ></p>\n </ng-container>\n <ng-container *ngIf=\"(isPendingPayment | async) === false\">\n <p class=\"card-text vd-card-text\">\n {{\n (!!reference\n ? 'gesdem-error.text.has-reference'\n : 'gesdem-error.text.has-no-reference'\n ) | fromDictionary\n }}\n </p>\n <ul class=\"vd-list-links\">\n <li>\n <a [href]=\"link\">\n {{\n (!!reference\n ? 'gesdem-error.link.has-reference'\n : 'gesdem-error.link.has-no-reference'\n ) | fromDictionary\n }}\n </a>\n </li>\n </ul>\n </ng-container>\n\n <foehn-debug-summary></foehn-debug-summary>\n </div>\n </div>\n </div>\n </div>\n</div>\n\n<gesdem-action-recovery-login\n *ngIf=\"hasSessionExpired\"\n [reference]=\"reference\"\n [redirectTarget]=\"link\"\n></gesdem-action-recovery-login>\n" }]
85
+ }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.FoehnNavigationService }, { type: i3.GesdemHandlerService }, { type: i4.GesdemEventService }, { type: i5.FoehnPageService }, { type: i6.SupportAlertService }, { type: i7.ApplicationInfoService }]; }, propDecorators: { setPageTitle: [{
64
86
  type: Input
65
87
  }] } });
66
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gesdem-error.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/gesdem-error/gesdem-error.component.ts","../../../../projects/prestations-ng/src/gesdem-error/gesdem-error.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AAEzD,OAAO,EAAE,sBAAsB,EAAE,MAAM,8CAA8C,CAAC;AAItF,OAAO,EAAE,eAAe,EAAE,MAAM,wCAAwC,CAAC;;;;;;;;;;AAOzE,MAAM,OAAO,oBAAoB;IAQ7B,YACY,cAA8B,EAC9B,UAAkC,EAClC,aAAmC,EACnC,gBAAkC,EAClC,mBAAwC;QAJxC,mBAAc,GAAd,cAAc,CAAgB;QAC9B,eAAU,GAAV,UAAU,CAAwB;QAClC,kBAAa,GAAb,aAAa,CAAsB;QACnC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,wBAAmB,GAAnB,mBAAmB,CAAqB;QAXpD,iBAAY,GAAG,IAAI,CAAC;QAIpB,sBAAiB,GAAG,KAAK,CAAC;QAStB,MAAM,KAAK,GAAG,sBAAsB,CAAC,qBAAqB,CACtD,cAAc,CAAC,QAAQ,CAC1B,CAAC;QACF,UAAU,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAC5B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;IACnC,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC;QAC/D,IAAI,IAAI,CAAC,SAAS,EAAE;YAChB,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;YACtC,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE;gBAC3B,IAAI,CAAC,IAAI,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC;aAChD;YAED,IAAI,CAAC,IAAI,IAAI,GAAG,IAAI,CAAC,SAAS,IAAI,SAAS,CAAC,IAAI,EAAE,CAAC;YAEnD,MAAM,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,aAAa,CAAC,GAAG,CAC5D,WAAW,CACd,CAAC;YACF,IAAI,CAAC,iBAAiB,GAAG,SAAS,KAAK,eAAe,CAAC;SAC1D;QAED,4FAA4F;QAC5F,0FAA0F;QAC1F,uEAAuE;QACvE,IAAI,CAAC,mBAAmB,CAAC,aAAa,EAAE,CAAC;QAEzC,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAC9B,IAAI,CAAC,iBAAiB;gBAClB,CAAC,CAAC,uBAAuB;gBACzB,CAAC,CAAC,mBAAmB,CAC5B,CAAC;SACL;IACL,CAAC;IAEO,YAAY;QAChB,OAAO,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC;IAC3C,CAAC;IAEO,WAAW;QACf,MAAM,IAAI,GAAG,QAAQ,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;QACnD,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE;YACnB,OAAO,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;SACvB;QACD,OAAO,GAAG,CAAC;IACf,CAAC;;iHA9DQ,oBAAoB;qGAApB,oBAAoB,8FCbjC,s2CAmCA;2FDtBa,oBAAoB;kBALhC,SAAS;+BAEI,cAAc;8OAKxB,YAAY;sBADX,KAAK","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { ActivatedRoute, Route } from '@angular/router';\nimport { FoehnNavigationService } from '../foehn-navigation/foehn-navigation.service';\nimport { GesdemHandlerService } from '../gesdem/gesdem-handler.service';\nimport { FoehnPageService } from '../foehn-page/foehn-page.service';\nimport { SupportAlertService } from '../sdk-support-alert/support-alert.service';\nimport { SESSION_EXPIRED } from '../gesdem/gesdem-error-handler.service';\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'gesdem-error',\n    templateUrl: './gesdem-error.component.html'\n})\nexport class GesdemErrorComponent implements OnInit {\n    @Input()\n    setPageTitle = true;\n\n    link: string;\n    reference: string;\n    hasSessionExpired = false;\n\n    constructor(\n        private activatedRoute: ActivatedRoute,\n        private navigation: FoehnNavigationService,\n        private gesdemService: GesdemHandlerService,\n        private foehnPageService: FoehnPageService,\n        private supportAlertService: SupportAlertService\n    ) {\n        const route = FoehnNavigationService.getRootRouteRecursive(\n            activatedRoute.snapshot\n        );\n        navigation.initRoute(route);\n        this.link = this.getBasePath();\n    }\n\n    ngOnInit(): void {\n        this.reference = this.activatedRoute.snapshot.params.reference;\n        if (this.reference) {\n            const firstPage = this.getFirstPage();\n            if (this.gesdemService.prefix) {\n                this.link += `${this.gesdemService.prefix}/`;\n            }\n\n            this.link += `${this.reference}/${firstPage.path}`;\n\n            const errorCode = this.activatedRoute.snapshot.queryParamMap.get(\n                'errorCode'\n            );\n            this.hasSessionExpired = errorCode === SESSION_EXPIRED;\n        }\n\n        // The error might have been caused by an issue with the prestation that has been identified\n        // whilst the user is using the prestation. This ensures that if any alert is added by the\n        // administrator, the user will at least see them if an error is shown.\n        this.supportAlertService.refreshAlerts();\n\n        if (this.setPageTitle) {\n            this.foehnPageService.setPageTitle(\n                this.hasSessionExpired\n                    ? 'Reprise de la demande'\n                    : 'Erreur rencontrée'\n            );\n        }\n    }\n\n    private getFirstPage(): Route {\n        return this.navigation.getFirstRoute();\n    }\n\n    private getBasePath(): string {\n        const base = document.getElementsByTagName('base');\n        if (base.length === 1) {\n            return base[0].href;\n        }\n        return '/';\n    }\n}\n","<div class=\"vd-card mb-3\" *ngIf=\"!hasSessionExpired\">\n    <div class=\"container\">\n        <div class=\"row\">\n            <div class=\"col-xs-8\">\n                <div class=\"card-body\">\n                    <p class=\"card-text vd-card-text\">\n                        {{\n                            !!reference\n                                ? 'Vous pouvez essayer de reprendre votre demande en cliquant sur le lien ci-dessous'\n                                : 'Vous pouvez recommencer une demande en cliquant sur le lien ci-dessous'\n                        }}\n                    </p>\n                    <ul class=\"vd-list-links\">\n                        <li>\n                            <a [href]=\"link\">\n                                {{\n                                    !!reference\n                                        ? 'Reprendre ma demande'\n                                        : 'Recommencer'\n                                }}\n                            </a>\n                        </li>\n                    </ul>\n                    <foehn-debug-summary></foehn-debug-summary>\n                </div>\n            </div>\n        </div>\n    </div>\n</div>\n\n<gesdem-action-recovery-login\n    *ngIf=\"hasSessionExpired\"\n    [reference]=\"reference\"\n    [redirectTarget]=\"link\"\n></gesdem-action-recovery-login>\n"]}
88
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gesdem-error.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/gesdem-error/gesdem-error.component.ts","../../../../projects/prestations-ng/src/gesdem-error/gesdem-error.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { ActivatedRoute, Route } from '@angular/router';\nimport { FoehnNavigationService } from '../foehn-navigation/foehn-navigation.service';\nimport { GesdemHandlerService } from '../gesdem/gesdem-handler.service';\nimport { FoehnPageService } from '../foehn-page/foehn-page.service';\nimport { SupportAlertService } from '../sdk-support-alert/support-alert.service';\nimport { SESSION_EXPIRED } from '../gesdem/gesdem-error-handler.service';\nimport { ActionStatut, GesdemStatutUtils } from '../gesdem/gesdem-statut-utils';\nimport { Observable, of } from 'rxjs';\nimport { GesdemEventService } from '../gesdem/gesdem-event.service';\nimport { catchError, map, tap } from 'rxjs/operators';\nimport { ApplicationInfoService } from '../sdk-appinfo/application-info.service';\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'gesdem-error',\n    templateUrl: './gesdem-error.component.html'\n})\nexport class GesdemErrorComponent implements OnInit {\n    @Input()\n    setPageTitle = true;\n\n    link: string;\n    reference: string;\n    supportLink: Observable<string>;\n    hasSessionExpired = false;\n    isPendingPayment: Observable<boolean>;\n\n    constructor(\n        private activatedRoute: ActivatedRoute,\n        private navigation: FoehnNavigationService,\n        private gesdemService: GesdemHandlerService,\n        private gesdemEventService: GesdemEventService,\n        private foehnPageService: FoehnPageService,\n        private supportAlertService: SupportAlertService,\n        private applicationInfoService: ApplicationInfoService\n    ) {\n        const route = FoehnNavigationService.getRootRouteRecursive(\n            activatedRoute.snapshot\n        );\n        navigation.initRoute(route);\n        this.link = this.getBasePath();\n        this.reference = this.activatedRoute.snapshot.params.reference;\n        this.supportLink = this.applicationInfoService.getSafeSupportFormUrl(\n            this.reference\n        );\n        if (!this.reference?.length) {\n            this.isPendingPayment = of(false);\n        } else {\n            this.isPendingPayment = this.gesdemService\n                .retrieve(this.reference)\n                .pipe(\n                    map(\n                        () =>\n                            ActionStatut[\n                                this.gesdemService.lastResponse.meta\n                                    .statut as ActionStatut\n                            ]\n                    ),\n                    tap(statut => {\n                        if (GesdemStatutUtils.isFinal(statut)) {\n                            this.navigation.last();\n                        }\n                    }),\n                    map(statut => statut === ActionStatut.PENDING_PAYMENT),\n                    catchError(() => of(false))\n                );\n        }\n    }\n\n    ngOnInit(): void {\n        if (this.reference) {\n            const firstPage = this.getFirstPage();\n            if (this.gesdemService.prefix) {\n                this.link += `${this.gesdemService.prefix}/`;\n            }\n\n            this.link += `${this.reference}/${firstPage.path}`;\n            const errorCode = this.activatedRoute.snapshot.queryParamMap.get(\n                'errorCode'\n            );\n            this.hasSessionExpired = errorCode === SESSION_EXPIRED;\n        }\n\n        // The error might have been caused by an issue with the prestation that has been identified\n        // whilst the user is using the prestation. This ensures that if any alert is added by the\n        // administrator, the user will at least see them if an error is shown.\n        this.supportAlertService.refreshAlerts();\n\n        if (this.setPageTitle) {\n            this.foehnPageService.setPageTitle(\n                this.hasSessionExpired\n                    ? 'Reprise de la demande'\n                    : 'Erreur rencontrée'\n            );\n        }\n    }\n\n    private getFirstPage(): Route {\n        return this.navigation.getFirstRoute();\n    }\n\n    private getBasePath(): string {\n        const base = document.getElementsByTagName('base');\n        if (base.length === 1) {\n            return base[0].href;\n        }\n        return '/';\n    }\n}\n","<div class=\"vd-card mb-3\" *ngIf=\"!hasSessionExpired\">\n    <div class=\"container\">\n        <div class=\"row\">\n            <div class=\"col-xs-8\">\n                <div class=\"card-body\">\n                    <ng-container *ngIf=\"(isPendingPayment | async) === true\">\n                        <p\n                            class=\"card-text vd-card-text alert alert-danger\"\n                            [innerHTML]=\"\n                                'gesdem-error.text.pending-payment'\n                                    | fromDictionary\n                                        : {\n                                              supportLink: (supportLink | async)\n                                          }\n                            \"\n                        ></p>\n                    </ng-container>\n                    <ng-container *ngIf=\"(isPendingPayment | async) === false\">\n                        <p class=\"card-text vd-card-text\">\n                            {{\n                                (!!reference\n                                    ? 'gesdem-error.text.has-reference'\n                                    : 'gesdem-error.text.has-no-reference'\n                                ) | fromDictionary\n                            }}\n                        </p>\n                        <ul class=\"vd-list-links\">\n                            <li>\n                                <a [href]=\"link\">\n                                    {{\n                                        (!!reference\n                                            ? 'gesdem-error.link.has-reference'\n                                            : 'gesdem-error.link.has-no-reference'\n                                        ) | fromDictionary\n                                    }}\n                                </a>\n                            </li>\n                        </ul>\n                    </ng-container>\n\n                    <foehn-debug-summary></foehn-debug-summary>\n                </div>\n            </div>\n        </div>\n    </div>\n</div>\n\n<gesdem-action-recovery-login\n    *ngIf=\"hasSessionExpired\"\n    [reference]=\"reference\"\n    [redirectTarget]=\"link\"\n></gesdem-action-recovery-login>\n"]}
@@ -4,6 +4,7 @@ import { GesdemErrorComponent } from './gesdem-error.component';
4
4
  import { RouterModule } from '@angular/router';
5
5
  import { GesdemActionRecoveryModule } from '../gesdem-action-recovery/gesdem-action-recovery.module';
6
6
  import { FoehnDebugSummaryComponentModule } from '../foehn-debug-summary/foehn-debug-summary.component.module';
7
+ import { SdkDictionaryModule } from '../sdk-dictionary/sdk-dictionary.module';
7
8
  import * as i0 from "@angular/core";
8
9
  export class GesdemErrorModule {
9
10
  }
@@ -11,12 +12,14 @@ GesdemErrorModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", versio
11
12
  GesdemErrorModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: GesdemErrorModule, declarations: [GesdemErrorComponent], imports: [CommonModule,
12
13
  RouterModule,
13
14
  GesdemActionRecoveryModule,
14
- FoehnDebugSummaryComponentModule], exports: [GesdemErrorComponent] });
15
+ FoehnDebugSummaryComponentModule,
16
+ SdkDictionaryModule], exports: [GesdemErrorComponent] });
15
17
  GesdemErrorModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: GesdemErrorModule, imports: [[
16
18
  CommonModule,
17
19
  RouterModule,
18
20
  GesdemActionRecoveryModule,
19
- FoehnDebugSummaryComponentModule
21
+ FoehnDebugSummaryComponentModule,
22
+ SdkDictionaryModule
20
23
  ]] });
21
24
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: GesdemErrorModule, decorators: [{
22
25
  type: NgModule,
@@ -25,10 +28,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImpor
25
28
  CommonModule,
26
29
  RouterModule,
27
30
  GesdemActionRecoveryModule,
28
- FoehnDebugSummaryComponentModule
31
+ FoehnDebugSummaryComponentModule,
32
+ SdkDictionaryModule
29
33
  ],
30
34
  declarations: [GesdemErrorComponent],
31
35
  exports: [GesdemErrorComponent]
32
36
  }]
33
37
  }] });
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VzZGVtLWVycm9yLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3ByZXN0YXRpb25zLW5nL3NyYy9nZXNkZW0tZXJyb3IvZ2VzZGVtLWVycm9yLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0seURBQXlELENBQUM7QUFDckcsT0FBTyxFQUFFLGdDQUFnQyxFQUFFLE1BQU0sNkRBQTZELENBQUM7O0FBWS9HLE1BQU0sT0FBTyxpQkFBaUI7OzhHQUFqQixpQkFBaUI7K0dBQWpCLGlCQUFpQixpQkFIWCxvQkFBb0IsYUFML0IsWUFBWTtRQUNaLFlBQVk7UUFDWiwwQkFBMEI7UUFDMUIsZ0NBQWdDLGFBRzFCLG9CQUFvQjsrR0FFckIsaUJBQWlCLFlBVGpCO1lBQ0wsWUFBWTtZQUNaLFlBQVk7WUFDWiwwQkFBMEI7WUFDMUIsZ0NBQWdDO1NBQ25DOzJGQUlRLGlCQUFpQjtrQkFWN0IsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFDWixZQUFZO3dCQUNaLDBCQUEwQjt3QkFDMUIsZ0NBQWdDO3FCQUNuQztvQkFDRCxZQUFZLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztvQkFDcEMsT0FBTyxFQUFFLENBQUMsb0JBQW9CLENBQUM7aUJBQ2xDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBHZXNkZW1FcnJvckNvbXBvbmVudCB9IGZyb20gJy4vZ2VzZGVtLWVycm9yLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBSb3V0ZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgR2VzZGVtQWN0aW9uUmVjb3ZlcnlNb2R1bGUgfSBmcm9tICcuLi9nZXNkZW0tYWN0aW9uLXJlY292ZXJ5L2dlc2RlbS1hY3Rpb24tcmVjb3ZlcnkubW9kdWxlJztcbmltcG9ydCB7IEZvZWhuRGVidWdTdW1tYXJ5Q29tcG9uZW50TW9kdWxlIH0gZnJvbSAnLi4vZm9laG4tZGVidWctc3VtbWFyeS9mb2Vobi1kZWJ1Zy1zdW1tYXJ5LmNvbXBvbmVudC5tb2R1bGUnO1xuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxuICAgICAgICBSb3V0ZXJNb2R1bGUsXG4gICAgICAgIEdlc2RlbUFjdGlvblJlY292ZXJ5TW9kdWxlLFxuICAgICAgICBGb2VobkRlYnVnU3VtbWFyeUNvbXBvbmVudE1vZHVsZVxuICAgIF0sXG4gICAgZGVjbGFyYXRpb25zOiBbR2VzZGVtRXJyb3JDb21wb25lbnRdLFxuICAgIGV4cG9ydHM6IFtHZXNkZW1FcnJvckNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgR2VzZGVtRXJyb3JNb2R1bGUge31cbiJdfQ==
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VzZGVtLWVycm9yLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3ByZXN0YXRpb25zLW5nL3NyYy9nZXNkZW0tZXJyb3IvZ2VzZGVtLWVycm9yLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0seURBQXlELENBQUM7QUFDckcsT0FBTyxFQUFFLGdDQUFnQyxFQUFFLE1BQU0sNkRBQTZELENBQUM7QUFDL0csT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0seUNBQXlDLENBQUM7O0FBYTlFLE1BQU0sT0FBTyxpQkFBaUI7OzhHQUFqQixpQkFBaUI7K0dBQWpCLGlCQUFpQixpQkFIWCxvQkFBb0IsYUFOL0IsWUFBWTtRQUNaLFlBQVk7UUFDWiwwQkFBMEI7UUFDMUIsZ0NBQWdDO1FBQ2hDLG1CQUFtQixhQUdiLG9CQUFvQjsrR0FFckIsaUJBQWlCLFlBVmpCO1lBQ0wsWUFBWTtZQUNaLFlBQVk7WUFDWiwwQkFBMEI7WUFDMUIsZ0NBQWdDO1lBQ2hDLG1CQUFtQjtTQUN0QjsyRkFJUSxpQkFBaUI7a0JBWDdCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osWUFBWTt3QkFDWiwwQkFBMEI7d0JBQzFCLGdDQUFnQzt3QkFDaEMsbUJBQW1CO3FCQUN0QjtvQkFDRCxZQUFZLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztvQkFDcEMsT0FBTyxFQUFFLENBQUMsb0JBQW9CLENBQUM7aUJBQ2xDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBHZXNkZW1FcnJvckNvbXBvbmVudCB9IGZyb20gJy4vZ2VzZGVtLWVycm9yLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBSb3V0ZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgR2VzZGVtQWN0aW9uUmVjb3ZlcnlNb2R1bGUgfSBmcm9tICcuLi9nZXNkZW0tYWN0aW9uLXJlY292ZXJ5L2dlc2RlbS1hY3Rpb24tcmVjb3ZlcnkubW9kdWxlJztcbmltcG9ydCB7IEZvZWhuRGVidWdTdW1tYXJ5Q29tcG9uZW50TW9kdWxlIH0gZnJvbSAnLi4vZm9laG4tZGVidWctc3VtbWFyeS9mb2Vobi1kZWJ1Zy1zdW1tYXJ5LmNvbXBvbmVudC5tb2R1bGUnO1xuaW1wb3J0IHsgU2RrRGljdGlvbmFyeU1vZHVsZSB9IGZyb20gJy4uL3Nkay1kaWN0aW9uYXJ5L3Nkay1kaWN0aW9uYXJ5Lm1vZHVsZSc7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIFJvdXRlck1vZHVsZSxcbiAgICAgICAgR2VzZGVtQWN0aW9uUmVjb3ZlcnlNb2R1bGUsXG4gICAgICAgIEZvZWhuRGVidWdTdW1tYXJ5Q29tcG9uZW50TW9kdWxlLFxuICAgICAgICBTZGtEaWN0aW9uYXJ5TW9kdWxlXG4gICAgXSxcbiAgICBkZWNsYXJhdGlvbnM6IFtHZXNkZW1FcnJvckNvbXBvbmVudF0sXG4gICAgZXhwb3J0czogW0dlc2RlbUVycm9yQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBHZXNkZW1FcnJvck1vZHVsZSB7fVxuIl19