@dsivd/prestations-ng 15.1.1 → 15.1.4-beta1
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 +18 -0
- package/dsivd-prestations-ng-v15.1.4-beta1.tgz +0 -0
- package/esm2020/foehn-agenda/calendar.type.mjs +1 -1
- package/esm2020/foehn-agenda/foehn-agenda-timeslot-panel/foehn-agenda-timeslot-panel.component.mjs +5 -3
- package/esm2020/foehn-agenda/foehn-agenda.component.mjs +4 -8
- package/esm2020/foehn-date-picker/foehn-date-picker.component.mjs +3 -3
- package/esm2020/foehn-nav13/foehn-input-nav13.component.mjs +8 -2
- package/esm2020/gesdem/gesdem-loader.guard.mjs +3 -2
- package/esm2020/gesdem-error/gesdem-error.component.mjs +31 -12
- package/esm2020/gesdem-error/gesdem-error.module.mjs +8 -4
- package/esm2020/sdk-dictionary/default-dictionary.mjs +10 -2
- package/fesm2015/dsivd-prestations-ng.mjs +54 -23
- package/fesm2015/dsivd-prestations-ng.mjs.map +1 -1
- package/fesm2020/dsivd-prestations-ng.mjs +53 -23
- package/fesm2020/dsivd-prestations-ng.mjs.map +1 -1
- package/foehn-agenda/calendar.type.d.ts +2 -0
- package/foehn-agenda/foehn-agenda-timeslot-panel/foehn-agenda-timeslot-panel.component.d.ts +1 -0
- package/foehn-agenda/foehn-agenda.component.d.ts +1 -3
- package/gesdem-error/gesdem-error.component.d.ts +5 -1
- package/gesdem-error/gesdem-error.module.d.ts +2 -1
- package/package.json +1 -1
- package/dsivd-prestations-ng-v15.1.1.tgz +0 -0
package/CHANGELOG.md
CHANGED
|
@@ -26,6 +26,24 @@ A change is considered **breaking** if you have to change your code or update yo
|
|
|
26
26
|
|
|
27
27
|
---
|
|
28
28
|
|
|
29
|
+
## [15.1.3]
|
|
30
|
+
|
|
31
|
+
### Updated
|
|
32
|
+
- [foehn-input-nav13.component.ts](projects/prestations-ng/src/foehn-nav13/foehn-input-nav13.component.ts)
|
|
33
|
+
- pasting an AVS number (witouht the prefix `756`) in the first editable input will now expand it to the other inputs.
|
|
34
|
+
|
|
35
|
+
- [foehn-agenda-timeslot-panel.component.ts](projects/prestations-ng/src/foehn-agenda/foehn-agenda-timeslot-panel/foehn-agenda-timeslot-panel.component.ts)
|
|
36
|
+
- don't allow closing the panel if it would hide the selected slot
|
|
37
|
+
|
|
38
|
+
## [15.1.2]
|
|
39
|
+
|
|
40
|
+
- [foehn-agenda.components.ts](projects/prestations-ng/src/foehn-agenda/foehn-agenda.component.ts)
|
|
41
|
+
- removed `@Input() minDate: number[]`, replaced by `Calendar.minAvailableDate`
|
|
42
|
+
- removed `@Input() maxDate: number[]`, replaced by `Calendar.maxAvailableDate`
|
|
43
|
+
|
|
44
|
+
- [foehn-date-picker.component.html](projects/prestations-ng/src/foehn-date-picker/foehn-date-picker.component.html)
|
|
45
|
+
- do not display (`hidden`) days that are not in the current month (to avoid confusion with actually disabled days)
|
|
46
|
+
|
|
29
47
|
## [15.1.1]
|
|
30
48
|
|
|
31
49
|
### Updated
|
|
Binary file
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
export class Calendar {
|
|
2
2
|
}
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIudHlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3ByZXN0YXRpb25zLW5nL3NyYy9mb2Vobi1hZ2VuZGEvY2FsZW5kYXIudHlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxNQUFNLE9BQU8sUUFBUTtDQU1wQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBhZ2luYXRpb25XZWVrIH0gZnJvbSAnLi9wYWdpbmF0aW9uLXdlZWsudHlwZSc7XG5pbXBvcnQgeyBDdXJyZW50V2VlayB9IGZyb20gJy4vY3VycmVudC13ZWVrLnR5cGUnO1xuXG5leHBvcnQgY2xhc3MgQ2FsZW5kYXIge1xuICAgIHByZXZpb3VzV2VlazogUGFnaW5hdGlvbldlZWs7XG4gICAgY3VycmVudFdlZWs6IEN1cnJlbnRXZWVrO1xuICAgIG5leHRXZWVrOiBQYWdpbmF0aW9uV2VlaztcbiAgICBtaW5BdmFpbGFibGVEYXRlOiBudW1iZXJbXTtcbiAgICBtYXhBdmFpbGFibGVEYXRlOiBudW1iZXJbXTtcbn1cbiJdfQ==
|
package/esm2020/foehn-agenda/foehn-agenda-timeslot-panel/foehn-agenda-timeslot-panel.component.mjs
CHANGED
|
@@ -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 {{\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 {{\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 {{\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 {{\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"]}
|
|
@@ -66,13 +66,13 @@ export class FoehnAgendaComponent extends FoehnInputComponent {
|
|
|
66
66
|
}
|
|
67
67
|
}
|
|
68
68
|
FoehnAgendaComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnAgendaComponent, deps: [{ token: i1.SdkDictionaryService }], target: i0.ɵɵFactoryTarget.Component });
|
|
69
|
-
FoehnAgendaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: FoehnAgendaComponent, selector: "foehn-agenda", inputs: { calendar: "calendar", nbVisibleElements: "nbVisibleElements"
|
|
69
|
+
FoehnAgendaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: FoehnAgendaComponent, selector: "foehn-agenda", inputs: { calendar: "calendar", nbVisibleElements: "nbVisibleElements" }, outputs: { paginationChange: "paginationChange" }, providers: [
|
|
70
70
|
{
|
|
71
71
|
provide: FoehnInputComponent,
|
|
72
72
|
useExisting: forwardRef(() => FoehnAgendaComponent),
|
|
73
73
|
multi: true
|
|
74
74
|
}
|
|
75
|
-
], viewQueries: [{ propertyName: "timeSlotPanelsElemRef", predicate: ["timeSlotPanelElemRef"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrors()\"\n [class.vd-form-group-danger]=\"hasErrors()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <p\n [attr.id]=\"buildChildId() + 'Label'\"\n [attr.for]=\"buildChildId()\"\n *ngIf=\"label && type !== 'hidden'\"\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 </p>\n\n <small\n *ngIf=\"helpText && type !== 'hidden'\"\n [attr.id]=\"buildChildId() + 'Help'\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-container *ngIf=\"!(calendar | async)\">\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n <p class=\"alert alert-warning\">\n {{ 'foehn-agenda.calendar-indisponible' | fromDictionary }}\n </p>\n </ng-container>\n\n <!-- Fake input with NgModel to be registered into Form controls -->\n <input type=\"hidden\" [name]=\"name || label\" [ngModel]=\"model\" />\n\n <p\n [id]=\"buildChildId('srOnlyAnnouncements')\"\n class=\"sr-only\"\n aria-live=\"polite\"\n aria-atomic=\"true\"\n >\n {{ srAnnouncements }}\n </p>\n\n <ng-content></ng-content>\n\n <ng-container *ngIf=\"calendar | async as loadedCalendar\">\n <section\n class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrors() || null\"\n >\n <h2 class=\"h3 mt-3\">\n <span aria-live=\"polite\" role=\"status\" aria-atomic=\"true\">\n {{ loadedCalendar.currentWeek.label }}\n </span>\n </h2>\n\n <!-- Rappel de l'heure actuellement s\u00E9lectionn\u00E9e -->\n <p [id]=\"buildChildId('timeSlotSelectedSrOnly')\" class=\"sr-only\">\n {{ extractDayTime(model) }}\n </p>\n\n <!-- Navigation top hidden from screen reader-->\n <foehn-agenda-navigation\n [id]=\"buildChildId() + 'week-pagination-top'\"\n [calendar]=\"loadedCalendar\"\n [minDate]=\"
|
|
75
|
+
], viewQueries: [{ propertyName: "timeSlotPanelsElemRef", predicate: ["timeSlotPanelElemRef"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrors()\"\n [class.vd-form-group-danger]=\"hasErrors()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <p\n [attr.id]=\"buildChildId() + 'Label'\"\n [attr.for]=\"buildChildId()\"\n *ngIf=\"label && type !== 'hidden'\"\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 </p>\n\n <small\n *ngIf=\"helpText && type !== 'hidden'\"\n [attr.id]=\"buildChildId() + 'Help'\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-container *ngIf=\"!(calendar | async)\">\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n <p class=\"alert alert-warning\">\n {{ 'foehn-agenda.calendar-indisponible' | fromDictionary }}\n </p>\n </ng-container>\n\n <!-- Fake input with NgModel to be registered into Form controls -->\n <input type=\"hidden\" [name]=\"name || label\" [ngModel]=\"model\" />\n\n <p\n [id]=\"buildChildId('srOnlyAnnouncements')\"\n class=\"sr-only\"\n aria-live=\"polite\"\n aria-atomic=\"true\"\n >\n {{ srAnnouncements }}\n </p>\n\n <ng-content></ng-content>\n\n <ng-container *ngIf=\"calendar | async as loadedCalendar\">\n <section\n class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrors() || null\"\n >\n <h2 class=\"h3 mt-3\">\n <span aria-live=\"polite\" role=\"status\" aria-atomic=\"true\">\n {{ loadedCalendar.currentWeek.label }}\n </span>\n </h2>\n\n <!-- Rappel de l'heure actuellement s\u00E9lectionn\u00E9e -->\n <p [id]=\"buildChildId('timeSlotSelectedSrOnly')\" class=\"sr-only\">\n {{ extractDayTime(model) }}\n </p>\n\n <!-- Navigation top hidden from screen reader-->\n <foehn-agenda-navigation\n [id]=\"buildChildId() + 'week-pagination-top'\"\n [calendar]=\"loadedCalendar\"\n [minDate]=\"loadedCalendar.minAvailableDate\"\n [maxDate]=\"loadedCalendar.maxAvailableDate\"\n (paginationChange)=\"paginate($event)\"\n aria-hidden=\"true\"\n ></foehn-agenda-navigation>\n\n <!-- Link to navigation bottom only for screen reader -->\n <p [id]=\"buildChildId('navigationBottomAnchor')\" class=\"sr-only\">\n {{\n 'foehn-agenda.pagination-anchor.first-part' | fromDictionary\n }}\n <a\n href=\"#\"\n (click)=\"$event.preventDefault(); scrollToNavigation(true)\"\n >\n {{\n 'foehn-agenda.pagination-anchor.top-next-part'\n | fromDictionary\n }}\n </a>\n </p>\n\n <foehn-validation-alerts\n [component]=\"this\"\n ></foehn-validation-alerts>\n\n <div\n class=\"row\"\n [tabIndex]=\"hasErrors() ? 0 : -1\"\n [attr.id]=\"buildChildId()\"\n #entryComponent\n >\n <foehn-agenda-timeslot-panel\n *ngFor=\"let currentWeek of loadedCalendar.currentWeek.week\"\n class=\"col-12\"\n #timeSlotPanelElemRef\n [currentWeek]=\"currentWeek\"\n [calendar]=\"calendar\"\n [nbVisibleElements]=\"nbVisibleElements\"\n [(model)]=\"model\"\n (userInput)=\"handleUserInput($event)\"\n ></foehn-agenda-timeslot-panel>\n </div>\n </section>\n\n <!-- Navigation bottom used for screen reader only -->\n <foehn-agenda-navigation\n class=\"sr-only\"\n [id]=\"buildChildId() + 'week-pagination-bottom'\"\n [calendar]=\"loadedCalendar\"\n [isSrOnly]=\"true\"\n [minDate]=\"loadedCalendar.minAvailableDate\"\n [maxDate]=\"loadedCalendar.maxAvailableDate\"\n (paginationChange)=\"paginate($event)\"\n ></foehn-agenda-navigation>\n\n <!-- Link to navigation top hidden from screen reader -->\n <p [id]=\"buildChildId('navigationTopAnchor')\" aria-hidden=\"true\">\n {{ 'foehn-agenda.pagination-anchor.first-part' | fromDictionary }}\n <a\n href=\"#\"\n (click)=\"$event.preventDefault(); scrollToNavigation(false)\"\n >\n {{\n 'foehn-agenda.pagination-anchor.bottom-next-part'\n | fromDictionary\n }}\n </a>\n </p>\n </ng-container>\n</div>\n", components: [{ type: i2.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { type: i3.FoehnAgendaNavigationComponent, selector: "foehn-agenda-navigation", inputs: ["id", "calendar", "isSrOnly", "minDate", "maxDate"], outputs: ["paginationChange"] }, { type: i4.FoehnAgendaTimeslotPanelComponent, selector: "foehn-agenda-timeslot-panel", inputs: ["calendar", "nbVisibleElements", "currentWeek"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "fromDictionary": i7.SdkDictionaryPipe, "async": i5.AsyncPipe } });
|
|
76
76
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnAgendaComponent, decorators: [{
|
|
77
77
|
type: Component,
|
|
78
78
|
args: [{ selector: 'foehn-agenda', providers: [
|
|
@@ -81,19 +81,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImpor
|
|
|
81
81
|
useExisting: forwardRef(() => FoehnAgendaComponent),
|
|
82
82
|
multi: true
|
|
83
83
|
}
|
|
84
|
-
], template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrors()\"\n [class.vd-form-group-danger]=\"hasErrors()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <p\n [attr.id]=\"buildChildId() + 'Label'\"\n [attr.for]=\"buildChildId()\"\n *ngIf=\"label && type !== 'hidden'\"\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 </p>\n\n <small\n *ngIf=\"helpText && type !== 'hidden'\"\n [attr.id]=\"buildChildId() + 'Help'\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-container *ngIf=\"!(calendar | async)\">\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n <p class=\"alert alert-warning\">\n {{ 'foehn-agenda.calendar-indisponible' | fromDictionary }}\n </p>\n </ng-container>\n\n <!-- Fake input with NgModel to be registered into Form controls -->\n <input type=\"hidden\" [name]=\"name || label\" [ngModel]=\"model\" />\n\n <p\n [id]=\"buildChildId('srOnlyAnnouncements')\"\n class=\"sr-only\"\n aria-live=\"polite\"\n aria-atomic=\"true\"\n >\n {{ srAnnouncements }}\n </p>\n\n <ng-content></ng-content>\n\n <ng-container *ngIf=\"calendar | async as loadedCalendar\">\n <section\n class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrors() || null\"\n >\n <h2 class=\"h3 mt-3\">\n <span aria-live=\"polite\" role=\"status\" aria-atomic=\"true\">\n {{ loadedCalendar.currentWeek.label }}\n </span>\n </h2>\n\n <!-- Rappel de l'heure actuellement s\u00E9lectionn\u00E9e -->\n <p [id]=\"buildChildId('timeSlotSelectedSrOnly')\" class=\"sr-only\">\n {{ extractDayTime(model) }}\n </p>\n\n <!-- Navigation top hidden from screen reader-->\n <foehn-agenda-navigation\n [id]=\"buildChildId() + 'week-pagination-top'\"\n [calendar]=\"loadedCalendar\"\n [minDate]=\"
|
|
84
|
+
], template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrors()\"\n [class.vd-form-group-danger]=\"hasErrors()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <p\n [attr.id]=\"buildChildId() + 'Label'\"\n [attr.for]=\"buildChildId()\"\n *ngIf=\"label && type !== 'hidden'\"\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 </p>\n\n <small\n *ngIf=\"helpText && type !== 'hidden'\"\n [attr.id]=\"buildChildId() + 'Help'\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-container *ngIf=\"!(calendar | async)\">\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n <p class=\"alert alert-warning\">\n {{ 'foehn-agenda.calendar-indisponible' | fromDictionary }}\n </p>\n </ng-container>\n\n <!-- Fake input with NgModel to be registered into Form controls -->\n <input type=\"hidden\" [name]=\"name || label\" [ngModel]=\"model\" />\n\n <p\n [id]=\"buildChildId('srOnlyAnnouncements')\"\n class=\"sr-only\"\n aria-live=\"polite\"\n aria-atomic=\"true\"\n >\n {{ srAnnouncements }}\n </p>\n\n <ng-content></ng-content>\n\n <ng-container *ngIf=\"calendar | async as loadedCalendar\">\n <section\n class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrors() || null\"\n >\n <h2 class=\"h3 mt-3\">\n <span aria-live=\"polite\" role=\"status\" aria-atomic=\"true\">\n {{ loadedCalendar.currentWeek.label }}\n </span>\n </h2>\n\n <!-- Rappel de l'heure actuellement s\u00E9lectionn\u00E9e -->\n <p [id]=\"buildChildId('timeSlotSelectedSrOnly')\" class=\"sr-only\">\n {{ extractDayTime(model) }}\n </p>\n\n <!-- Navigation top hidden from screen reader-->\n <foehn-agenda-navigation\n [id]=\"buildChildId() + 'week-pagination-top'\"\n [calendar]=\"loadedCalendar\"\n [minDate]=\"loadedCalendar.minAvailableDate\"\n [maxDate]=\"loadedCalendar.maxAvailableDate\"\n (paginationChange)=\"paginate($event)\"\n aria-hidden=\"true\"\n ></foehn-agenda-navigation>\n\n <!-- Link to navigation bottom only for screen reader -->\n <p [id]=\"buildChildId('navigationBottomAnchor')\" class=\"sr-only\">\n {{\n 'foehn-agenda.pagination-anchor.first-part' | fromDictionary\n }}\n <a\n href=\"#\"\n (click)=\"$event.preventDefault(); scrollToNavigation(true)\"\n >\n {{\n 'foehn-agenda.pagination-anchor.top-next-part'\n | fromDictionary\n }}\n </a>\n </p>\n\n <foehn-validation-alerts\n [component]=\"this\"\n ></foehn-validation-alerts>\n\n <div\n class=\"row\"\n [tabIndex]=\"hasErrors() ? 0 : -1\"\n [attr.id]=\"buildChildId()\"\n #entryComponent\n >\n <foehn-agenda-timeslot-panel\n *ngFor=\"let currentWeek of loadedCalendar.currentWeek.week\"\n class=\"col-12\"\n #timeSlotPanelElemRef\n [currentWeek]=\"currentWeek\"\n [calendar]=\"calendar\"\n [nbVisibleElements]=\"nbVisibleElements\"\n [(model)]=\"model\"\n (userInput)=\"handleUserInput($event)\"\n ></foehn-agenda-timeslot-panel>\n </div>\n </section>\n\n <!-- Navigation bottom used for screen reader only -->\n <foehn-agenda-navigation\n class=\"sr-only\"\n [id]=\"buildChildId() + 'week-pagination-bottom'\"\n [calendar]=\"loadedCalendar\"\n [isSrOnly]=\"true\"\n [minDate]=\"loadedCalendar.minAvailableDate\"\n [maxDate]=\"loadedCalendar.maxAvailableDate\"\n (paginationChange)=\"paginate($event)\"\n ></foehn-agenda-navigation>\n\n <!-- Link to navigation top hidden from screen reader -->\n <p [id]=\"buildChildId('navigationTopAnchor')\" aria-hidden=\"true\">\n {{ 'foehn-agenda.pagination-anchor.first-part' | fromDictionary }}\n <a\n href=\"#\"\n (click)=\"$event.preventDefault(); scrollToNavigation(false)\"\n >\n {{\n 'foehn-agenda.pagination-anchor.bottom-next-part'\n | fromDictionary\n }}\n </a>\n </p>\n </ng-container>\n</div>\n" }]
|
|
85
85
|
}], ctorParameters: function () { return [{ type: i1.SdkDictionaryService }]; }, propDecorators: { calendar: [{
|
|
86
86
|
type: Input
|
|
87
87
|
}], nbVisibleElements: [{
|
|
88
88
|
type: Input
|
|
89
|
-
}], minDate: [{
|
|
90
|
-
type: Input
|
|
91
|
-
}], maxDate: [{
|
|
92
|
-
type: Input
|
|
93
89
|
}], paginationChange: [{
|
|
94
90
|
type: Output
|
|
95
91
|
}], timeSlotPanelsElemRef: [{
|
|
96
92
|
type: ViewChildren,
|
|
97
93
|
args: ['timeSlotPanelElemRef']
|
|
98
94
|
}] } });
|
|
99
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-agenda.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-agenda/foehn-agenda.component.ts","../../../../projects/prestations-ng/src/foehn-agenda/foehn-agenda.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    EventEmitter,\n    forwardRef,\n    Input,\n    Output,\n    QueryList,\n    ViewChildren\n} from '@angular/core';\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\nimport { Observable } from 'rxjs';\nimport { SelectedSlot } from './selected-slot.type';\nimport { Calendar } from './calendar.type';\nimport { PaginationWeek } from './pagination-week.type';\nimport { SdkDictionaryService } from '../sdk-dictionary/sdk-dictionary.service';\nimport { FoehnAgendaTimeslotPanelComponent } from './foehn-agenda-timeslot-panel/foehn-agenda-timeslot-panel.component';\n\n@Component({\n    selector: 'foehn-agenda',\n    templateUrl: './foehn-agenda.component.html',\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnAgendaComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnAgendaComponent extends FoehnInputComponent<SelectedSlot> {\n    @Input()\n    calendar: Observable<Calendar>;\n\n    @Input()\n    nbVisibleElements: number;\n\n    @Input()\n    minDate: number[];\n\n    @Input()\n    maxDate: number[];\n\n    @Output()\n    paginationChange = new EventEmitter<PaginationWeek>();\n\n    @ViewChildren('timeSlotPanelElemRef')\n    timeSlotPanelsElemRef: QueryList<FoehnAgendaTimeslotPanelComponent>;\n\n    srAnnouncements = '';\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    private srAnnouncementClearTimer: any;\n    private readonly SR_ANNOUNCEMENT_CLEAR_TIMEOUT_INTERVAL_MS = 1000;\n\n    constructor(private dictionaryService: SdkDictionaryService) {\n        super();\n    }\n\n    private static cleanIdForQuerySelector(s: string): string {\n        return s.replace(new RegExp('\\\\.', 'g'), '\\\\.');\n    }\n\n    focus(): void {\n        const timeSlotPanelsElemRefArray = [\n            ...this.timeSlotPanelsElemRef.toArray()\n        ];\n        if (!!timeSlotPanelsElemRefArray.length) {\n            const timeSlotPanel = timeSlotPanelsElemRefArray.find(\n                elem => !!elem.timeSlots && !!elem.timeSlots.length\n            );\n            if (!!timeSlotPanel) {\n                timeSlotPanel.focus();\n            }\n        }\n    }\n\n    paginate(paginationWeek: PaginationWeek): void {\n        this.paginationChange.next(paginationWeek);\n    }\n\n    handleUserInput(selectedTimeSlot: SelectedSlot): void {\n        // markAsDirty hides error by simulating the control on ngModel as dirty\n        this.markAsDirty();\n        this.manageScreenReaderAnnouncement(\n            `${selectedTimeSlot.day} ${\n                selectedTimeSlot.time\n            } ${this.dictionaryService.getKeySync(\n                'foehn-agenda.timeslot.selected'\n            )}`\n        );\n    }\n\n    scrollToNavigation(isTop: boolean): void {\n        let navigationId = `#${FoehnAgendaComponent.cleanIdForQuerySelector(\n            this.buildChildId('week-pagination')\n        )}`;\n        navigationId += isTop ? '-bottom' : '-top';\n        const navigationElement = document.querySelector(navigationId);\n        if (navigationElement) {\n            navigationElement.scrollIntoView();\n        }\n        const navigationLinkId = `${navigationId} .vd-pagination__link`;\n        const navigationLink: HTMLElement = document.querySelector(\n            navigationLinkId\n        );\n        if (navigationLink) {\n            navigationLink.focus();\n        }\n    }\n\n    extractDayTime(selected: SelectedSlot): string {\n        if (!selected) {\n            return '';\n        }\n        return `${selected.day} ${selected.time}`;\n    }\n\n    private manageScreenReaderAnnouncement(msg: string): void {\n        clearTimeout(this.srAnnouncementClearTimer);\n        this.srAnnouncements = msg;\n        this.srAnnouncementClearTimer = setTimeout(() => {\n            this.srAnnouncements = '';\n        }, this.SR_ANNOUNCEMENT_CLEAR_TIMEOUT_INTERVAL_MS);\n    }\n}\n","<div\n    class=\"form-group\"\n    [class.has-danger]=\"hasErrors()\"\n    [class.vd-form-group-danger]=\"hasErrors()\"\n    [attr.id]=\"buildId('Container')\"\n    tabindex=\"-1\"\n>\n    <p\n        [attr.id]=\"buildChildId() + 'Label'\"\n        [attr.for]=\"buildChildId()\"\n        *ngIf=\"label && type !== 'hidden'\"\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    </p>\n\n    <small\n        *ngIf=\"helpText && type !== 'hidden'\"\n        [attr.id]=\"buildChildId() + 'Help'\"\n        class=\"form-text text-secondary\"\n        [innerHTML]=\"helpText\"\n    ></small>\n\n    <ng-container *ngIf=\"!(calendar | async)\">\n        <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n        <p class=\"alert alert-warning\">\n            {{ 'foehn-agenda.calendar-indisponible' | fromDictionary }}\n        </p>\n    </ng-container>\n\n    <!-- Fake input with NgModel to be registered into Form controls -->\n    <input type=\"hidden\" [name]=\"name || label\" [ngModel]=\"model\" />\n\n    <p\n        [id]=\"buildChildId('srOnlyAnnouncements')\"\n        class=\"sr-only\"\n        aria-live=\"polite\"\n        aria-atomic=\"true\"\n    >\n        {{ srAnnouncements }}\n    </p>\n\n    <ng-content></ng-content>\n\n    <ng-container *ngIf=\"calendar | async as loadedCalendar\">\n        <section\n            class=\"mb-3\"\n            [attr.aria-describedby]=\"getDescribedBy()\"\n            [attr.aria-invalid]=\"hasErrors() || null\"\n        >\n            <h2 class=\"h3 mt-3\">\n                <span aria-live=\"polite\" role=\"status\" aria-atomic=\"true\">\n                    {{ loadedCalendar.currentWeek.label }}\n                </span>\n            </h2>\n\n            <!-- Rappel de l'heure actuellement sélectionnée -->\n            <p [id]=\"buildChildId('timeSlotSelectedSrOnly')\" class=\"sr-only\">\n                {{ extractDayTime(model) }}\n            </p>\n\n            <!-- Navigation top hidden from screen reader-->\n            <foehn-agenda-navigation\n                [id]=\"buildChildId() + 'week-pagination-top'\"\n                [calendar]=\"loadedCalendar\"\n                [minDate]=\"minDate\"\n                [maxDate]=\"maxDate\"\n                (paginationChange)=\"paginate($event)\"\n                aria-hidden=\"true\"\n            ></foehn-agenda-navigation>\n\n            <!-- Link to navigation bottom only for screen reader -->\n            <p [id]=\"buildChildId('navigationBottomAnchor')\" class=\"sr-only\">\n                {{\n                    'foehn-agenda.pagination-anchor.first-part' | fromDictionary\n                }}\n                <a\n                    href=\"#\"\n                    (click)=\"$event.preventDefault(); scrollToNavigation(true)\"\n                >\n                    {{\n                        'foehn-agenda.pagination-anchor.top-next-part'\n                            | fromDictionary\n                    }}\n                </a>\n            </p>\n\n            <foehn-validation-alerts\n                [component]=\"this\"\n            ></foehn-validation-alerts>\n\n            <div\n                class=\"row\"\n                [tabIndex]=\"hasErrors() ? 0 : -1\"\n                [attr.id]=\"buildChildId()\"\n                #entryComponent\n            >\n                <foehn-agenda-timeslot-panel\n                    *ngFor=\"let currentWeek of loadedCalendar.currentWeek.week\"\n                    class=\"col-12\"\n                    #timeSlotPanelElemRef\n                    [currentWeek]=\"currentWeek\"\n                    [calendar]=\"calendar\"\n                    [nbVisibleElements]=\"nbVisibleElements\"\n                    [(model)]=\"model\"\n                    (userInput)=\"handleUserInput($event)\"\n                ></foehn-agenda-timeslot-panel>\n            </div>\n        </section>\n\n        <!-- Navigation bottom used for screen reader only -->\n        <foehn-agenda-navigation\n            class=\"sr-only\"\n            [id]=\"buildChildId() + 'week-pagination-bottom'\"\n            [calendar]=\"loadedCalendar\"\n            [isSrOnly]=\"true\"\n            [minDate]=\"minDate\"\n            [maxDate]=\"maxDate\"\n            (paginationChange)=\"paginate($event)\"\n        ></foehn-agenda-navigation>\n\n        <!-- Link to navigation top hidden from screen reader -->\n        <p [id]=\"buildChildId('navigationTopAnchor')\" aria-hidden=\"true\">\n            {{ 'foehn-agenda.pagination-anchor.first-part' | fromDictionary }}\n            <a\n                href=\"#\"\n                (click)=\"$event.preventDefault(); scrollToNavigation(false)\"\n            >\n                {{\n                    'foehn-agenda.pagination-anchor.bottom-next-part'\n                        | fromDictionary\n                }}\n            </a>\n        </p>\n    </ng-container>\n</div>\n"]}
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-agenda.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-agenda/foehn-agenda.component.ts","../../../../projects/prestations-ng/src/foehn-agenda/foehn-agenda.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    EventEmitter,\n    forwardRef,\n    Input,\n    Output,\n    QueryList,\n    ViewChildren\n} from '@angular/core';\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\nimport { Observable } from 'rxjs';\nimport { SelectedSlot } from './selected-slot.type';\nimport { Calendar } from './calendar.type';\nimport { PaginationWeek } from './pagination-week.type';\nimport { SdkDictionaryService } from '../sdk-dictionary/sdk-dictionary.service';\nimport { FoehnAgendaTimeslotPanelComponent } from './foehn-agenda-timeslot-panel/foehn-agenda-timeslot-panel.component';\n\n@Component({\n    selector: 'foehn-agenda',\n    templateUrl: './foehn-agenda.component.html',\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnAgendaComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnAgendaComponent extends FoehnInputComponent<SelectedSlot> {\n    @Input()\n    calendar: Observable<Calendar>;\n\n    @Input()\n    nbVisibleElements: number;\n\n    @Output()\n    paginationChange = new EventEmitter<PaginationWeek>();\n\n    @ViewChildren('timeSlotPanelElemRef')\n    timeSlotPanelsElemRef: QueryList<FoehnAgendaTimeslotPanelComponent>;\n\n    srAnnouncements = '';\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    private srAnnouncementClearTimer: any;\n    private readonly SR_ANNOUNCEMENT_CLEAR_TIMEOUT_INTERVAL_MS = 1000;\n\n    constructor(private dictionaryService: SdkDictionaryService) {\n        super();\n    }\n\n    private static cleanIdForQuerySelector(s: string): string {\n        return s.replace(new RegExp('\\\\.', 'g'), '\\\\.');\n    }\n\n    focus(): void {\n        const timeSlotPanelsElemRefArray = [\n            ...this.timeSlotPanelsElemRef.toArray()\n        ];\n        if (!!timeSlotPanelsElemRefArray.length) {\n            const timeSlotPanel = timeSlotPanelsElemRefArray.find(\n                elem => !!elem.timeSlots && !!elem.timeSlots.length\n            );\n            if (!!timeSlotPanel) {\n                timeSlotPanel.focus();\n            }\n        }\n    }\n\n    paginate(paginationWeek: PaginationWeek): void {\n        this.paginationChange.next(paginationWeek);\n    }\n\n    handleUserInput(selectedTimeSlot: SelectedSlot): void {\n        // markAsDirty hides error by simulating the control on ngModel as dirty\n        this.markAsDirty();\n        this.manageScreenReaderAnnouncement(\n            `${selectedTimeSlot.day} ${\n                selectedTimeSlot.time\n            } ${this.dictionaryService.getKeySync(\n                'foehn-agenda.timeslot.selected'\n            )}`\n        );\n    }\n\n    scrollToNavigation(isTop: boolean): void {\n        let navigationId = `#${FoehnAgendaComponent.cleanIdForQuerySelector(\n            this.buildChildId('week-pagination')\n        )}`;\n        navigationId += isTop ? '-bottom' : '-top';\n        const navigationElement = document.querySelector(navigationId);\n        if (navigationElement) {\n            navigationElement.scrollIntoView();\n        }\n        const navigationLinkId = `${navigationId} .vd-pagination__link`;\n        const navigationLink: HTMLElement = document.querySelector(\n            navigationLinkId\n        );\n        if (navigationLink) {\n            navigationLink.focus();\n        }\n    }\n\n    extractDayTime(selected: SelectedSlot): string {\n        if (!selected) {\n            return '';\n        }\n        return `${selected.day} ${selected.time}`;\n    }\n\n    private manageScreenReaderAnnouncement(msg: string): void {\n        clearTimeout(this.srAnnouncementClearTimer);\n        this.srAnnouncements = msg;\n        this.srAnnouncementClearTimer = setTimeout(() => {\n            this.srAnnouncements = '';\n        }, this.SR_ANNOUNCEMENT_CLEAR_TIMEOUT_INTERVAL_MS);\n    }\n}\n","<div\n    class=\"form-group\"\n    [class.has-danger]=\"hasErrors()\"\n    [class.vd-form-group-danger]=\"hasErrors()\"\n    [attr.id]=\"buildId('Container')\"\n    tabindex=\"-1\"\n>\n    <p\n        [attr.id]=\"buildChildId() + 'Label'\"\n        [attr.for]=\"buildChildId()\"\n        *ngIf=\"label && type !== 'hidden'\"\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    </p>\n\n    <small\n        *ngIf=\"helpText && type !== 'hidden'\"\n        [attr.id]=\"buildChildId() + 'Help'\"\n        class=\"form-text text-secondary\"\n        [innerHTML]=\"helpText\"\n    ></small>\n\n    <ng-container *ngIf=\"!(calendar | async)\">\n        <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n        <p class=\"alert alert-warning\">\n            {{ 'foehn-agenda.calendar-indisponible' | fromDictionary }}\n        </p>\n    </ng-container>\n\n    <!-- Fake input with NgModel to be registered into Form controls -->\n    <input type=\"hidden\" [name]=\"name || label\" [ngModel]=\"model\" />\n\n    <p\n        [id]=\"buildChildId('srOnlyAnnouncements')\"\n        class=\"sr-only\"\n        aria-live=\"polite\"\n        aria-atomic=\"true\"\n    >\n        {{ srAnnouncements }}\n    </p>\n\n    <ng-content></ng-content>\n\n    <ng-container *ngIf=\"calendar | async as loadedCalendar\">\n        <section\n            class=\"mb-3\"\n            [attr.aria-describedby]=\"getDescribedBy()\"\n            [attr.aria-invalid]=\"hasErrors() || null\"\n        >\n            <h2 class=\"h3 mt-3\">\n                <span aria-live=\"polite\" role=\"status\" aria-atomic=\"true\">\n                    {{ loadedCalendar.currentWeek.label }}\n                </span>\n            </h2>\n\n            <!-- Rappel de l'heure actuellement sélectionnée -->\n            <p [id]=\"buildChildId('timeSlotSelectedSrOnly')\" class=\"sr-only\">\n                {{ extractDayTime(model) }}\n            </p>\n\n            <!-- Navigation top hidden from screen reader-->\n            <foehn-agenda-navigation\n                [id]=\"buildChildId() + 'week-pagination-top'\"\n                [calendar]=\"loadedCalendar\"\n                [minDate]=\"loadedCalendar.minAvailableDate\"\n                [maxDate]=\"loadedCalendar.maxAvailableDate\"\n                (paginationChange)=\"paginate($event)\"\n                aria-hidden=\"true\"\n            ></foehn-agenda-navigation>\n\n            <!-- Link to navigation bottom only for screen reader -->\n            <p [id]=\"buildChildId('navigationBottomAnchor')\" class=\"sr-only\">\n                {{\n                    'foehn-agenda.pagination-anchor.first-part' | fromDictionary\n                }}\n                <a\n                    href=\"#\"\n                    (click)=\"$event.preventDefault(); scrollToNavigation(true)\"\n                >\n                    {{\n                        'foehn-agenda.pagination-anchor.top-next-part'\n                            | fromDictionary\n                    }}\n                </a>\n            </p>\n\n            <foehn-validation-alerts\n                [component]=\"this\"\n            ></foehn-validation-alerts>\n\n            <div\n                class=\"row\"\n                [tabIndex]=\"hasErrors() ? 0 : -1\"\n                [attr.id]=\"buildChildId()\"\n                #entryComponent\n            >\n                <foehn-agenda-timeslot-panel\n                    *ngFor=\"let currentWeek of loadedCalendar.currentWeek.week\"\n                    class=\"col-12\"\n                    #timeSlotPanelElemRef\n                    [currentWeek]=\"currentWeek\"\n                    [calendar]=\"calendar\"\n                    [nbVisibleElements]=\"nbVisibleElements\"\n                    [(model)]=\"model\"\n                    (userInput)=\"handleUserInput($event)\"\n                ></foehn-agenda-timeslot-panel>\n            </div>\n        </section>\n\n        <!-- Navigation bottom used for screen reader only -->\n        <foehn-agenda-navigation\n            class=\"sr-only\"\n            [id]=\"buildChildId() + 'week-pagination-bottom'\"\n            [calendar]=\"loadedCalendar\"\n            [isSrOnly]=\"true\"\n            [minDate]=\"loadedCalendar.minAvailableDate\"\n            [maxDate]=\"loadedCalendar.maxAvailableDate\"\n            (paginationChange)=\"paginate($event)\"\n        ></foehn-agenda-navigation>\n\n        <!-- Link to navigation top hidden from screen reader -->\n        <p [id]=\"buildChildId('navigationTopAnchor')\" aria-hidden=\"true\">\n            {{ 'foehn-agenda.pagination-anchor.first-part' | fromDictionary }}\n            <a\n                href=\"#\"\n                (click)=\"$event.preventDefault(); scrollToNavigation(false)\"\n            >\n                {{\n                    'foehn-agenda.pagination-anchor.bottom-next-part'\n                        | fromDictionary\n                }}\n            </a>\n        </p>\n    </ng-container>\n</div>\n"]}
|