@dsivd/prestations-ng 15.0.0-rc1 → 15.0.1-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.
Files changed (31) hide show
  1. package/CHANGELOG.md +15 -0
  2. package/UPGRADING_V15.md +3 -2
  3. package/dsivd-prestations-ng-v15.0.1-beta1.tgz +0 -0
  4. package/esm2020/foehn-agenda/calendar.type.mjs +3 -0
  5. package/esm2020/foehn-agenda/current-week.type.mjs +4 -0
  6. package/esm2020/foehn-agenda/day-slots.type.mjs +3 -0
  7. package/esm2020/foehn-agenda/foehn-agenda-navigation/foehn-agenda-navigation.component.mjs +70 -0
  8. package/esm2020/foehn-agenda/foehn-agenda-timeslot-panel/foehn-agenda-timeslot-panel.component.mjs +233 -0
  9. package/esm2020/foehn-agenda/foehn-agenda.component.mjs +95 -0
  10. package/esm2020/foehn-agenda/foehn-agenda.module.mjs +64 -0
  11. package/esm2020/foehn-agenda/pagination-week.type.mjs +3 -0
  12. package/esm2020/foehn-agenda/selected-slot.type.mjs +3 -0
  13. package/esm2020/foehn-multiselect-autocomplete/foehn-multiselect-autocomplete.component.mjs +2 -2
  14. package/esm2020/index.mjs +11 -1
  15. package/esm2020/sdk-dictionary/default-dictionary.mjs +18 -2
  16. package/fesm2015/dsivd-prestations-ng.mjs +459 -3
  17. package/fesm2015/dsivd-prestations-ng.mjs.map +1 -1
  18. package/fesm2020/dsivd-prestations-ng.mjs +459 -3
  19. package/fesm2020/dsivd-prestations-ng.mjs.map +1 -1
  20. package/foehn-agenda/calendar.type.d.ts +7 -0
  21. package/foehn-agenda/current-week.type.d.ts +5 -0
  22. package/foehn-agenda/day-slots.type.d.ts +5 -0
  23. package/foehn-agenda/foehn-agenda-navigation/foehn-agenda-navigation.component.d.ts +19 -0
  24. package/foehn-agenda/foehn-agenda-timeslot-panel/foehn-agenda-timeslot-panel.component.d.ts +49 -0
  25. package/foehn-agenda/foehn-agenda.component.d.ts +29 -0
  26. package/foehn-agenda/foehn-agenda.module.d.ts +17 -0
  27. package/foehn-agenda/pagination-week.type.d.ts +5 -0
  28. package/foehn-agenda/selected-slot.type.d.ts +7 -0
  29. package/index.d.ts +9 -0
  30. package/package.json +1 -1
  31. package/dsivd-prestations-ng-v15.0.0-rc1.tgz +0 -0
package/CHANGELOG.md CHANGED
@@ -26,6 +26,21 @@ A change is considered **breaking** if you have to change your code or update yo
26
26
 
27
27
  ---
28
28
 
29
+ ## [15.0.1]
30
+
31
+ ### Added
32
+
33
+ - New [agenda documentation](https://dsi-vd.github.io/prestations-ng/agenda) page
34
+
35
+ - [foehn-agenda.components.ts](projects/prestations-ng/src/foehn-agenda/foehn-agenda.component.ts)
36
+ - Model `calendar.type.ts` ([Calendar](projects/prestations-ng/src/foehn-agenda/calendar.type.ts))
37
+ - Model `current-week.type.ts` ([CurrentWeek](projects/prestations-ng/src/foehn-agenda/current-week.type.ts))
38
+ - Model `day-slots.type.ts` ([DaySlots](projects/prestations-ng/src/foehn-agenda/day-slots.type.ts))
39
+ - Model `pagination-week.type.ts` ([PaginationWeek](projects/prestations-ng/src/foehn-agenda/pagination-week.type.ts))
40
+ - `@Input() calendar: Observable<Calendar>`
41
+ - `@Input() nbVisibleElements: number` default number of visible elements is 22
42
+ - `@Output() paginationChange: EventEmitter<PaginationWeek>()`
43
+
29
44
  ## [15.0.0]
30
45
 
31
46
  ### Added
package/UPGRADING_V15.md CHANGED
@@ -16,7 +16,7 @@ yarn global add @angular/cli@13
16
16
  ng update @angular-eslint/builder@13
17
17
  ng update @angular-eslint/eslint-plugin @angular-eslint/eslint-plugin-template @angular-eslint/template-parser
18
18
  ng update @typescript-eslint/eslint-plugin @typescript-eslint/parser
19
- ng update eslint-plugin-import eslint-plugin-jasmine eslint-plugin-jsdoc eslint-plugin-prefer-arrow
19
+ ng update eslint-plugin-import eslint-plugin-jasmine eslint-plugin-jsdoc eslint-plugin-prefer-arrow eslint-plugin-rxjs-angular
20
20
  ng update eslint
21
21
  ng update eslint-plugin-rxjs@4
22
22
  ng update @angular/core@13 @angular/cli@13
@@ -26,7 +26,8 @@ ng update \
26
26
  @types/jasmine \
27
27
  @types/node@15 \
28
28
  ts-node@10
29
- ng update ngx-image-cropper@6
29
+ ng update ngx-image-cropper@~6.0.0
30
+ ng update ng-http-loader@11
30
31
  # Remove your resolutions in package.json before executing 'yarn upgrade'
31
32
  yarn upgrade
32
33
  ```
@@ -0,0 +1,3 @@
1
+ export class Calendar {
2
+ }
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIudHlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3ByZXN0YXRpb25zLW5nL3NyYy9mb2Vobi1hZ2VuZGEvY2FsZW5kYXIudHlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxNQUFNLE9BQU8sUUFBUTtDQUlwQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBhZ2luYXRpb25XZWVrIH0gZnJvbSAnLi9wYWdpbmF0aW9uLXdlZWsudHlwZSc7XG5pbXBvcnQgeyBDdXJyZW50V2VlayB9IGZyb20gJy4vY3VycmVudC13ZWVrLnR5cGUnO1xuXG5leHBvcnQgY2xhc3MgQ2FsZW5kYXIge1xuICAgIHByZXZpb3VzV2VlazogUGFnaW5hdGlvbldlZWs7XG4gICAgY3VycmVudFdlZWs6IEN1cnJlbnRXZWVrO1xuICAgIG5leHRXZWVrOiBQYWdpbmF0aW9uV2Vlaztcbn1cbiJdfQ==
@@ -0,0 +1,4 @@
1
+ import { PaginationWeek } from './pagination-week.type';
2
+ export class CurrentWeek extends PaginationWeek {
3
+ }
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VycmVudC13ZWVrLnR5cGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9wcmVzdGF0aW9ucy1uZy9zcmMvZm9laG4tYWdlbmRhL2N1cnJlbnQtd2Vlay50eXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUV4RCxNQUFNLE9BQU8sV0FBWSxTQUFRLGNBQWM7Q0FFOUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEYXlTbG90cyB9IGZyb20gJy4vZGF5LXNsb3RzLnR5cGUnO1xuaW1wb3J0IHsgUGFnaW5hdGlvbldlZWsgfSBmcm9tICcuL3BhZ2luYXRpb24td2Vlay50eXBlJztcblxuZXhwb3J0IGNsYXNzIEN1cnJlbnRXZWVrIGV4dGVuZHMgUGFnaW5hdGlvbldlZWsge1xuICAgIHdlZWs6IERheVNsb3RzW107XG59XG4iXX0=
@@ -0,0 +1,3 @@
1
+ export class DaySlots {
2
+ }
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF5LXNsb3RzLnR5cGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9wcmVzdGF0aW9ucy1uZy9zcmMvZm9laG4tYWdlbmRhL2RheS1zbG90cy50eXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sT0FBTyxRQUFRO0NBSXBCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNsYXNzIERheVNsb3RzIHtcbiAgICBkYXk6IHN0cmluZztcbiAgICBkYXRlOiBudW1iZXJbXTtcbiAgICB0aW1lU2xvdHM6IHN0cmluZ1tdO1xufVxuIl19
@@ -0,0 +1,70 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import dayjs from 'dayjs';
3
+ import weekOfYear from 'dayjs/plugin/weekOfYear';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../../foehn-icons/foehn-icon-chevron-left.component";
6
+ import * as i2 from "../../foehn-date-picker-button/foehn-date-picker-button.component";
7
+ import * as i3 from "../../foehn-icons/foehn-icon-chevron-right.component";
8
+ import * as i4 from "@angular/common";
9
+ import * as i5 from "../../sdk-dictionary/sdk-dictionary.pipe";
10
+ dayjs.extend(weekOfYear);
11
+ export class FoehnAgendaNavigationComponent {
12
+ constructor() {
13
+ this.isSrOnly = false;
14
+ this.paginationChange = new EventEmitter();
15
+ this.overrideWithCalendarDate = true;
16
+ }
17
+ static getCurrentDateAsArray() {
18
+ const now = dayjs();
19
+ return [now.year(), now.month() + 1, now.date()];
20
+ }
21
+ ngOnChanges(changes) {
22
+ this.onCalendarChange(changes.calendar);
23
+ }
24
+ paginate(paginationWeek) {
25
+ this.paginationChange.next(paginationWeek);
26
+ }
27
+ datePickerUserInput(selectedDate) {
28
+ this.overrideWithCalendarDate = false;
29
+ const dateAsString = `${selectedDate[0]}-${selectedDate[1]}-${selectedDate[2]}`;
30
+ const selectedDayjs = dayjs(dateAsString);
31
+ const numberWeek = selectedDayjs.week();
32
+ const paginationWeek = {
33
+ label: null,
34
+ weekNumber: numberWeek,
35
+ year: selectedDayjs.year()
36
+ };
37
+ this.paginationChange.next(paginationWeek);
38
+ }
39
+ onCalendarChange(change) {
40
+ if (change) {
41
+ const calendar = change.currentValue;
42
+ if (!this.overrideWithCalendarDate) {
43
+ this.overrideWithCalendarDate = true;
44
+ return;
45
+ }
46
+ if (!calendar ||
47
+ !calendar.currentWeek.week ||
48
+ !calendar.currentWeek.week.length) {
49
+ this.currentDay = FoehnAgendaNavigationComponent.getCurrentDateAsArray();
50
+ return;
51
+ }
52
+ this.currentDay = calendar.currentWeek.week[0].date;
53
+ }
54
+ }
55
+ }
56
+ FoehnAgendaNavigationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: FoehnAgendaNavigationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
57
+ FoehnAgendaNavigationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: FoehnAgendaNavigationComponent, selector: "foehn-agenda-navigation", inputs: { id: "id", calendar: "calendar", isSrOnly: "isSrOnly" }, outputs: { paginationChange: "paginationChange" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"row mb-3\" *ngIf=\"!!calendar\">\n <div class=\"col-12\">\n <nav\n class=\"vd-pagination calendar-week-navigation\"\n [attr.id]=\"id\"\n [attr.aria-label]=\"\n 'foehn-agenda-navigation.nav.aria-label' | fromDictionary\n \"\n >\n <ul class=\"vd-pagination__list\">\n <li\n class=\"vd-pagination__item vd-pagination__item--previous col-4\"\n *ngIf=\"!!calendar.previousWeek\"\n >\n <button\n [id]=\"id + 'ButtonPreviousWeek'\"\n class=\"btn-link vd-pagination__link vd-pagination__link-reset\"\n (click)=\"paginate(calendar.previousWeek)\"\n type=\"button\"\n >\n <div class=\"d-flex align-items-center\">\n <foehn-icon-chevron-left\n class=\"vd-pagination__title\"\n [title]=\"\n 'foehn-agenda-navigation.previous-week'\n | fromDictionary\n \"\n aria-hidden=\"true\"\n ></foehn-icon-chevron-left>\n <span\n class=\"vd-pagination__title ml-2 d-xs-none d-sm-block\"\n aria-hidden=\"true\"\n >\n {{\n 'foehn-agenda-navigation.previous-week'\n | fromDictionary\n }}\n </span>\n <span\n [id]=\"id + 'NavigationPreviousSrOnly'\"\n class=\"sr-only\"\n >\n {{\n 'foehn-agenda-navigation.previous-week-sr-only'\n | fromDictionary\n : {\n previousWeek:\n calendar.previousWeek\n .label\n }\n }}\n </span>\n </div>\n </button>\n </li>\n <li\n class=\"vd-pagination__item vd-pagination__item--previous col-4\"\n *ngIf=\"!calendar.previousWeek && !isSrOnly\"\n >\n <div\n [id]=\"id + 'NavigationPreviousDisabled'\"\n class=\"d-flex align-items-center link-week-disabled\"\n >\n <foehn-icon-chevron-left\n class=\"vd-pagination__title\"\n [title]=\"\n 'foehn-agenda-navigation.previous-week'\n | fromDictionary\n \"\n ></foehn-icon-chevron-left>\n <span\n class=\"vd-pagination__title ml-2 d-xs-none d-sm-block\"\n >\n {{\n 'foehn-agenda-navigation.previous-week'\n | fromDictionary\n }}\n </span>\n </div>\n </li>\n\n <li\n class=\"vd-pagination__item d-flex justify-content-center col-4\"\n *ngIf=\"!isSrOnly\"\n >\n <foehn-date-picker-button\n [model]=\"currentDay\"\n (userInput)=\"datePickerUserInput($event)\"\n ></foehn-date-picker-button>\n </li>\n\n <li\n class=\"vd-pagination__item vd-pagination__item--next col-4 d-flex justify-content-end\"\n *ngIf=\"!!calendar.nextWeek\"\n >\n <button\n [id]=\"id + 'ButtonNextWeek'\"\n class=\"btn-link vd-pagination__link vd-pagination__link-reset\"\n (click)=\"paginate(calendar.nextWeek)\"\n type=\"button\"\n >\n <div class=\"d-flex align-items-center\">\n <span\n aria-hidden=\"true\"\n class=\"vd-pagination__title d-xs-none d-sm-block\"\n >\n {{\n 'foehn-agenda-navigation.next-week'\n | fromDictionary\n }}\n </span>\n <span\n [id]=\"id + 'NavigationNextSrOnly'\"\n class=\"sr-only\"\n >\n {{\n 'foehn-agenda-navigation.next-week-sr-only'\n | fromDictionary\n : {\n nextWeek:\n calendar.nextWeek.label\n }\n }}\n </span>\n <foehn-icon-chevron-right\n class=\"vd-pagination__title ml-2\"\n [title]=\"\n 'foehn-agenda-navigation.next-week'\n | fromDictionary\n \"\n aria-hidden=\"true\"\n ></foehn-icon-chevron-right>\n </div>\n </button>\n </li>\n <li\n class=\"vd-pagination__item vd-pagination__item--next col-4 d-flex justify-content-end\"\n *ngIf=\"!calendar.nextWeek && !isSrOnly\"\n >\n <div\n [id]=\"id + 'NavigationNextDisabled'\"\n class=\"d-flex align-items-center link-week-disabled\"\n >\n <span class=\"vd-pagination__title d-xs-none d-sm-block\">\n {{\n 'foehn-agenda-navigation.next-week'\n | fromDictionary\n }}\n </span>\n <foehn-icon-chevron-right\n class=\"vd-pagination__title ml-2\"\n [title]=\"\n 'foehn-agenda-navigation.next-week'\n | fromDictionary\n \"\n ></foehn-icon-chevron-right>\n </div>\n </li>\n </ul>\n </nav>\n </div>\n</div>\n", styles: [".calendar-week-navigation{margin-bottom:0}.calendar-week-navigation li.vd-pagination__item{margin-top:0}.calendar-week-navigation span.vd-pagination__title{font-size:1em;line-height:1.2em;color:var(--gray-dark)}.calendar-week-navigation foehn-icon-chevron-right.vd-pagination__title,.calendar-week-navigation foehn-icon-chevron-left.vd-pagination__title{font-size:1.5em;color:var(--gray-dark)}.calendar-week-navigation .link-week-disabled .vd-pagination__title{color:#c3d1dc}.calendar-week-navigation .vd-pagination__link-reset{background:none;border:none;font-weight:inherit;-webkit-text-decoration-line:none;text-decoration-line:none;text-align:inherit;cursor:pointer}.calendar-week-navigation .vd-pagination__link-reset:focus{background-color:var(--focus)}nav ul{margin-bottom:0}\n"], components: [{ type: i1.FoehnIconChevronLeftComponent, selector: "foehn-icon-chevron-left" }, { type: i2.FoehnDatePickerButtonComponent, selector: "foehn-date-picker-button", inputs: ["minYear", "maxYear", "displaySelectedDate", "model"], outputs: ["modelChange", "userInput"] }, { type: i3.FoehnIconChevronRightComponent, selector: "foehn-icon-chevron-right" }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "fromDictionary": i5.SdkDictionaryPipe } });
58
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: FoehnAgendaNavigationComponent, decorators: [{
59
+ type: Component,
60
+ args: [{ selector: 'foehn-agenda-navigation', template: "<div class=\"row mb-3\" *ngIf=\"!!calendar\">\n <div class=\"col-12\">\n <nav\n class=\"vd-pagination calendar-week-navigation\"\n [attr.id]=\"id\"\n [attr.aria-label]=\"\n 'foehn-agenda-navigation.nav.aria-label' | fromDictionary\n \"\n >\n <ul class=\"vd-pagination__list\">\n <li\n class=\"vd-pagination__item vd-pagination__item--previous col-4\"\n *ngIf=\"!!calendar.previousWeek\"\n >\n <button\n [id]=\"id + 'ButtonPreviousWeek'\"\n class=\"btn-link vd-pagination__link vd-pagination__link-reset\"\n (click)=\"paginate(calendar.previousWeek)\"\n type=\"button\"\n >\n <div class=\"d-flex align-items-center\">\n <foehn-icon-chevron-left\n class=\"vd-pagination__title\"\n [title]=\"\n 'foehn-agenda-navigation.previous-week'\n | fromDictionary\n \"\n aria-hidden=\"true\"\n ></foehn-icon-chevron-left>\n <span\n class=\"vd-pagination__title ml-2 d-xs-none d-sm-block\"\n aria-hidden=\"true\"\n >\n {{\n 'foehn-agenda-navigation.previous-week'\n | fromDictionary\n }}\n </span>\n <span\n [id]=\"id + 'NavigationPreviousSrOnly'\"\n class=\"sr-only\"\n >\n {{\n 'foehn-agenda-navigation.previous-week-sr-only'\n | fromDictionary\n : {\n previousWeek:\n calendar.previousWeek\n .label\n }\n }}\n </span>\n </div>\n </button>\n </li>\n <li\n class=\"vd-pagination__item vd-pagination__item--previous col-4\"\n *ngIf=\"!calendar.previousWeek && !isSrOnly\"\n >\n <div\n [id]=\"id + 'NavigationPreviousDisabled'\"\n class=\"d-flex align-items-center link-week-disabled\"\n >\n <foehn-icon-chevron-left\n class=\"vd-pagination__title\"\n [title]=\"\n 'foehn-agenda-navigation.previous-week'\n | fromDictionary\n \"\n ></foehn-icon-chevron-left>\n <span\n class=\"vd-pagination__title ml-2 d-xs-none d-sm-block\"\n >\n {{\n 'foehn-agenda-navigation.previous-week'\n | fromDictionary\n }}\n </span>\n </div>\n </li>\n\n <li\n class=\"vd-pagination__item d-flex justify-content-center col-4\"\n *ngIf=\"!isSrOnly\"\n >\n <foehn-date-picker-button\n [model]=\"currentDay\"\n (userInput)=\"datePickerUserInput($event)\"\n ></foehn-date-picker-button>\n </li>\n\n <li\n class=\"vd-pagination__item vd-pagination__item--next col-4 d-flex justify-content-end\"\n *ngIf=\"!!calendar.nextWeek\"\n >\n <button\n [id]=\"id + 'ButtonNextWeek'\"\n class=\"btn-link vd-pagination__link vd-pagination__link-reset\"\n (click)=\"paginate(calendar.nextWeek)\"\n type=\"button\"\n >\n <div class=\"d-flex align-items-center\">\n <span\n aria-hidden=\"true\"\n class=\"vd-pagination__title d-xs-none d-sm-block\"\n >\n {{\n 'foehn-agenda-navigation.next-week'\n | fromDictionary\n }}\n </span>\n <span\n [id]=\"id + 'NavigationNextSrOnly'\"\n class=\"sr-only\"\n >\n {{\n 'foehn-agenda-navigation.next-week-sr-only'\n | fromDictionary\n : {\n nextWeek:\n calendar.nextWeek.label\n }\n }}\n </span>\n <foehn-icon-chevron-right\n class=\"vd-pagination__title ml-2\"\n [title]=\"\n 'foehn-agenda-navigation.next-week'\n | fromDictionary\n \"\n aria-hidden=\"true\"\n ></foehn-icon-chevron-right>\n </div>\n </button>\n </li>\n <li\n class=\"vd-pagination__item vd-pagination__item--next col-4 d-flex justify-content-end\"\n *ngIf=\"!calendar.nextWeek && !isSrOnly\"\n >\n <div\n [id]=\"id + 'NavigationNextDisabled'\"\n class=\"d-flex align-items-center link-week-disabled\"\n >\n <span class=\"vd-pagination__title d-xs-none d-sm-block\">\n {{\n 'foehn-agenda-navigation.next-week'\n | fromDictionary\n }}\n </span>\n <foehn-icon-chevron-right\n class=\"vd-pagination__title ml-2\"\n [title]=\"\n 'foehn-agenda-navigation.next-week'\n | fromDictionary\n \"\n ></foehn-icon-chevron-right>\n </div>\n </li>\n </ul>\n </nav>\n </div>\n</div>\n", styles: [".calendar-week-navigation{margin-bottom:0}.calendar-week-navigation li.vd-pagination__item{margin-top:0}.calendar-week-navigation span.vd-pagination__title{font-size:1em;line-height:1.2em;color:var(--gray-dark)}.calendar-week-navigation foehn-icon-chevron-right.vd-pagination__title,.calendar-week-navigation foehn-icon-chevron-left.vd-pagination__title{font-size:1.5em;color:var(--gray-dark)}.calendar-week-navigation .link-week-disabled .vd-pagination__title{color:#c3d1dc}.calendar-week-navigation .vd-pagination__link-reset{background:none;border:none;font-weight:inherit;-webkit-text-decoration-line:none;text-decoration-line:none;text-align:inherit;cursor:pointer}.calendar-week-navigation .vd-pagination__link-reset:focus{background-color:var(--focus)}nav ul{margin-bottom:0}\n"] }]
61
+ }], propDecorators: { id: [{
62
+ type: Input
63
+ }], calendar: [{
64
+ type: Input
65
+ }], isSrOnly: [{
66
+ type: Input
67
+ }], paginationChange: [{
68
+ type: Output
69
+ }] } });
70
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-agenda-navigation.component.js","sourceRoot":"","sources":["../../../../../projects/prestations-ng/src/foehn-agenda/foehn-agenda-navigation/foehn-agenda-navigation.component.ts","../../../../../projects/prestations-ng/src/foehn-agenda/foehn-agenda-navigation/foehn-agenda-navigation.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,MAAM,EAGT,MAAM,eAAe,CAAC;AACvB,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,UAAU,MAAM,yBAAyB,CAAC;;;;;;;AAIjD,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;AAOzB,MAAM,OAAO,8BAA8B;IAL3C;QAaI,aAAQ,GAAG,KAAK,CAAC;QAGjB,qBAAgB,GAAG,IAAI,YAAY,EAAkB,CAAC;QAI9C,6BAAwB,GAAG,IAAI,CAAC;KA8C3C;IA5CW,MAAM,CAAC,qBAAqB;QAChC,MAAM,GAAG,GAAG,KAAK,EAAE,CAAC;QACpB,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,EAAE,GAAG,CAAC,KAAK,EAAE,GAAG,CAAC,EAAE,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC;IACrD,CAAC;IAED,WAAW,CAAC,OAAsB;QAC9B,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IAC5C,CAAC;IAED,QAAQ,CAAC,cAA8B;QACnC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAC/C,CAAC;IAED,mBAAmB,CAAC,YAAsB;QACtC,IAAI,CAAC,wBAAwB,GAAG,KAAK,CAAC;QACtC,MAAM,YAAY,GAAG,GAAG,YAAY,CAAC,CAAC,CAAC,IAAI,YAAY,CAAC,CAAC,CAAC,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC;QAChF,MAAM,aAAa,GAAG,KAAK,CAAC,YAAY,CAAC,CAAC;QAC1C,MAAM,UAAU,GAAG,aAAa,CAAC,IAAI,EAAE,CAAC;QACxC,MAAM,cAAc,GAAmB;YACnC,KAAK,EAAE,IAAI;YACX,UAAU,EAAE,UAAU;YACtB,IAAI,EAAE,aAAa,CAAC,IAAI,EAAE;SAC7B,CAAC;QACF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAC/C,CAAC;IAEO,gBAAgB,CAAC,MAAoB;QACzC,IAAI,MAAM,EAAE;YACR,MAAM,QAAQ,GAAG,MAAM,CAAC,YAAY,CAAC;YACrC,IAAI,CAAC,IAAI,CAAC,wBAAwB,EAAE;gBAChC,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC;gBACrC,OAAO;aACV;YACD,IACI,CAAC,QAAQ;gBACT,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI;gBAC1B,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,EACnC;gBACE,IAAI,CAAC,UAAU,GAAG,8BAA8B,CAAC,qBAAqB,EAAE,CAAC;gBACzE,OAAO;aACV;YACD,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;SACvD;IACL,CAAC;;2HA5DQ,8BAA8B;+GAA9B,8BAA8B,yMCrB3C,89OAkKA;2FD7Ia,8BAA8B;kBAL1C,SAAS;+BACI,yBAAyB;8BAMnC,EAAE;sBADD,KAAK;gBAIN,QAAQ;sBADP,KAAK;gBAIN,QAAQ;sBADP,KAAK;gBAIN,gBAAgB;sBADf,MAAM","sourcesContent":["import {\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    Output,\n    SimpleChange,\n    SimpleChanges\n} from '@angular/core';\nimport dayjs from 'dayjs';\nimport weekOfYear from 'dayjs/plugin/weekOfYear';\nimport { Calendar } from '../calendar.type';\nimport { PaginationWeek } from '../pagination-week.type';\n\ndayjs.extend(weekOfYear);\n\n@Component({\n    selector: 'foehn-agenda-navigation',\n    templateUrl: './foehn-agenda-navigation.component.html',\n    styleUrls: ['./foehn-agenda-navigation.component.css']\n})\nexport class FoehnAgendaNavigationComponent implements OnChanges {\n    @Input()\n    id: string;\n\n    @Input()\n    calendar: Calendar;\n\n    @Input()\n    isSrOnly = false;\n\n    @Output()\n    paginationChange = new EventEmitter<PaginationWeek>();\n\n    currentDay: number[];\n\n    private overrideWithCalendarDate = true;\n\n    private static getCurrentDateAsArray(): number[] {\n        const now = dayjs();\n        return [now.year(), now.month() + 1, now.date()];\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        this.onCalendarChange(changes.calendar);\n    }\n\n    paginate(paginationWeek: PaginationWeek): void {\n        this.paginationChange.next(paginationWeek);\n    }\n\n    datePickerUserInput(selectedDate: number[]): void {\n        this.overrideWithCalendarDate = false;\n        const dateAsString = `${selectedDate[0]}-${selectedDate[1]}-${selectedDate[2]}`;\n        const selectedDayjs = dayjs(dateAsString);\n        const numberWeek = selectedDayjs.week();\n        const paginationWeek: PaginationWeek = {\n            label: null,\n            weekNumber: numberWeek,\n            year: selectedDayjs.year()\n        };\n        this.paginationChange.next(paginationWeek);\n    }\n\n    private onCalendarChange(change: SimpleChange): void {\n        if (change) {\n            const calendar = change.currentValue;\n            if (!this.overrideWithCalendarDate) {\n                this.overrideWithCalendarDate = true;\n                return;\n            }\n            if (\n                !calendar ||\n                !calendar.currentWeek.week ||\n                !calendar.currentWeek.week.length\n            ) {\n                this.currentDay = FoehnAgendaNavigationComponent.getCurrentDateAsArray();\n                return;\n            }\n            this.currentDay = calendar.currentWeek.week[0].date;\n        }\n    }\n}\n","<div class=\"row mb-3\" *ngIf=\"!!calendar\">\n    <div class=\"col-12\">\n        <nav\n            class=\"vd-pagination calendar-week-navigation\"\n            [attr.id]=\"id\"\n            [attr.aria-label]=\"\n                'foehn-agenda-navigation.nav.aria-label' | fromDictionary\n            \"\n        >\n            <ul class=\"vd-pagination__list\">\n                <li\n                    class=\"vd-pagination__item vd-pagination__item--previous col-4\"\n                    *ngIf=\"!!calendar.previousWeek\"\n                >\n                    <button\n                        [id]=\"id + 'ButtonPreviousWeek'\"\n                        class=\"btn-link vd-pagination__link vd-pagination__link-reset\"\n                        (click)=\"paginate(calendar.previousWeek)\"\n                        type=\"button\"\n                    >\n                        <div class=\"d-flex align-items-center\">\n                            <foehn-icon-chevron-left\n                                class=\"vd-pagination__title\"\n                                [title]=\"\n                                    'foehn-agenda-navigation.previous-week'\n                                        | fromDictionary\n                                \"\n                                aria-hidden=\"true\"\n                            ></foehn-icon-chevron-left>\n                            <span\n                                class=\"vd-pagination__title ml-2 d-xs-none d-sm-block\"\n                                aria-hidden=\"true\"\n                            >\n                                {{\n                                    'foehn-agenda-navigation.previous-week'\n                                        | fromDictionary\n                                }}\n                            </span>\n                            <span\n                                [id]=\"id + 'NavigationPreviousSrOnly'\"\n                                class=\"sr-only\"\n                            >\n                                {{\n                                    'foehn-agenda-navigation.previous-week-sr-only'\n                                        | fromDictionary\n                                            : {\n                                                  previousWeek:\n                                                      calendar.previousWeek\n                                                          .label\n                                              }\n                                }}\n                            </span>\n                        </div>\n                    </button>\n                </li>\n                <li\n                    class=\"vd-pagination__item vd-pagination__item--previous col-4\"\n                    *ngIf=\"!calendar.previousWeek && !isSrOnly\"\n                >\n                    <div\n                        [id]=\"id + 'NavigationPreviousDisabled'\"\n                        class=\"d-flex align-items-center link-week-disabled\"\n                    >\n                        <foehn-icon-chevron-left\n                            class=\"vd-pagination__title\"\n                            [title]=\"\n                                'foehn-agenda-navigation.previous-week'\n                                    | fromDictionary\n                            \"\n                        ></foehn-icon-chevron-left>\n                        <span\n                            class=\"vd-pagination__title ml-2 d-xs-none d-sm-block\"\n                        >\n                            {{\n                                'foehn-agenda-navigation.previous-week'\n                                    | fromDictionary\n                            }}\n                        </span>\n                    </div>\n                </li>\n\n                <li\n                    class=\"vd-pagination__item d-flex justify-content-center col-4\"\n                    *ngIf=\"!isSrOnly\"\n                >\n                    <foehn-date-picker-button\n                        [model]=\"currentDay\"\n                        (userInput)=\"datePickerUserInput($event)\"\n                    ></foehn-date-picker-button>\n                </li>\n\n                <li\n                    class=\"vd-pagination__item vd-pagination__item--next col-4 d-flex justify-content-end\"\n                    *ngIf=\"!!calendar.nextWeek\"\n                >\n                    <button\n                        [id]=\"id + 'ButtonNextWeek'\"\n                        class=\"btn-link vd-pagination__link vd-pagination__link-reset\"\n                        (click)=\"paginate(calendar.nextWeek)\"\n                        type=\"button\"\n                    >\n                        <div class=\"d-flex align-items-center\">\n                            <span\n                                aria-hidden=\"true\"\n                                class=\"vd-pagination__title d-xs-none d-sm-block\"\n                            >\n                                {{\n                                    'foehn-agenda-navigation.next-week'\n                                        | fromDictionary\n                                }}\n                            </span>\n                            <span\n                                [id]=\"id + 'NavigationNextSrOnly'\"\n                                class=\"sr-only\"\n                            >\n                                {{\n                                    'foehn-agenda-navigation.next-week-sr-only'\n                                        | fromDictionary\n                                            : {\n                                                  nextWeek:\n                                                      calendar.nextWeek.label\n                                              }\n                                }}\n                            </span>\n                            <foehn-icon-chevron-right\n                                class=\"vd-pagination__title ml-2\"\n                                [title]=\"\n                                    'foehn-agenda-navigation.next-week'\n                                        | fromDictionary\n                                \"\n                                aria-hidden=\"true\"\n                            ></foehn-icon-chevron-right>\n                        </div>\n                    </button>\n                </li>\n                <li\n                    class=\"vd-pagination__item vd-pagination__item--next col-4 d-flex justify-content-end\"\n                    *ngIf=\"!calendar.nextWeek && !isSrOnly\"\n                >\n                    <div\n                        [id]=\"id + 'NavigationNextDisabled'\"\n                        class=\"d-flex align-items-center link-week-disabled\"\n                    >\n                        <span class=\"vd-pagination__title d-xs-none d-sm-block\">\n                            {{\n                                'foehn-agenda-navigation.next-week'\n                                    | fromDictionary\n                            }}\n                        </span>\n                        <foehn-icon-chevron-right\n                            class=\"vd-pagination__title ml-2\"\n                            [title]=\"\n                                'foehn-agenda-navigation.next-week'\n                                    | fromDictionary\n                            \"\n                        ></foehn-icon-chevron-right>\n                    </div>\n                </li>\n            </ul>\n        </nav>\n    </div>\n</div>\n"]}
@@ -0,0 +1,233 @@
1
+ import { Component, forwardRef, HostListener, Input, ViewChildren } from '@angular/core';
2
+ import { FoehnInputComponent } from '../../foehn-input/foehn-input.component';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../../sdk-dictionary/sdk-dictionary.service";
5
+ import * as i2 from "@angular/common";
6
+ import * as i3 from "../../sdk-dictionary/sdk-dictionary.pipe";
7
+ export class FoehnAgendaTimeslotPanelComponent extends FoehnInputComponent {
8
+ constructor(dictionaryService) {
9
+ super();
10
+ this.dictionaryService = dictionaryService;
11
+ this.isClosed = true;
12
+ this.DEFAULT_NB_VISISBLE_ELEMENTS = 22;
13
+ this.keyboardNavigationAllowed = false;
14
+ this.hasSelectedSlotInPanel = false;
15
+ this.nbVisibleElements = this.DEFAULT_NB_VISISBLE_ELEMENTS;
16
+ }
17
+ get currentWeek() {
18
+ return this.currentWeek_;
19
+ }
20
+ set currentWeek(value) {
21
+ this.currentWeek_ = value;
22
+ this.sliceNbVisibleElements();
23
+ }
24
+ handleKeyboardDownEvent(event) {
25
+ if (this.keyboardNavigationAllowed) {
26
+ this.onKeyDownInner(event);
27
+ }
28
+ }
29
+ focus() {
30
+ const timeSlotButtonsElemRefArray = [
31
+ ...this.timeSlotButtonsElemRef.toArray()
32
+ ];
33
+ if (!!timeSlotButtonsElemRefArray.length) {
34
+ timeSlotButtonsElemRefArray[0].nativeElement.focus();
35
+ }
36
+ }
37
+ ngOnChanges(changes) {
38
+ this.onNbVisibleElementsChange(changes.nbVisibleElements);
39
+ }
40
+ capitalCaseFirstLetter(s) {
41
+ if (!s) {
42
+ return s;
43
+ }
44
+ if (s.length === 1) {
45
+ return s.toUpperCase();
46
+ }
47
+ return `${s.charAt(0).toUpperCase()}${s.slice(1)}`;
48
+ }
49
+ handleUserInput(day, date, time, calendar) {
50
+ const validValue = this.getValidValue(day, date, time, calendar);
51
+ if (typeof validValue !== 'undefined') {
52
+ this.userInput.next(validValue);
53
+ this.updateNgModel(validValue);
54
+ }
55
+ }
56
+ togglePanel() {
57
+ this.isClosed = !this.isClosed;
58
+ if (this.isClosed) {
59
+ this.sliceNbVisibleElements();
60
+ }
61
+ else {
62
+ // Need setTimeout because we are outside angular cicle when reloading page
63
+ setTimeout(() => {
64
+ this.timeSlots = this.currentWeek.timeSlots;
65
+ });
66
+ }
67
+ }
68
+ onModelChange(value) {
69
+ if (value) {
70
+ this.selectedTimeSlot = `${value.day}-${value.time}`;
71
+ this.timeInputValue = value.time;
72
+ this.dayInputValue = value.day;
73
+ }
74
+ else if (!value) {
75
+ this.selectedTimeSlot = null;
76
+ this.timeInputValue = null;
77
+ this.dayInputValue = null;
78
+ }
79
+ this.searchTimeValueInTimeSlot();
80
+ }
81
+ getTimeInputValue(s) {
82
+ if (!!s) {
83
+ const valueSplit = s.split('-');
84
+ if (valueSplit.length >= 2) {
85
+ return valueSplit[1];
86
+ }
87
+ }
88
+ return s;
89
+ }
90
+ searchTimeValueInTimeSlot() {
91
+ const positionValue = this.currentWeek.timeSlots.findIndex(x => x === this.timeInputValue &&
92
+ this.currentWeek.day === this.dayInputValue);
93
+ if (positionValue !== -1 && !!this.selectedTimeSlot) {
94
+ this.hasSelectedSlotInPanel = true;
95
+ if (this.isClosed && positionValue >= this.nbVisibleElements) {
96
+ this.togglePanel();
97
+ }
98
+ }
99
+ else {
100
+ this.hasSelectedSlotInPanel = false;
101
+ }
102
+ }
103
+ onTimeFocusin() {
104
+ this.keyboardNavigationAllowed = true;
105
+ this.currentActiveElement = document.activeElement;
106
+ }
107
+ onTimeFocusout() {
108
+ this.keyboardNavigationAllowed = false;
109
+ }
110
+ isSelected(timeSlot) {
111
+ if (!this.selectedTimeSlot) {
112
+ return false;
113
+ }
114
+ return (timeSlot === this.timeInputValue &&
115
+ this.currentWeek.day === this.dayInputValue);
116
+ }
117
+ getButtonTimeSlotAriaLabel(day, timeSlot) {
118
+ let result = `${day} ${timeSlot}`;
119
+ if (this.isSelected(timeSlot)) {
120
+ result += this.dictionaryService.getKeySync('foehn-agenda.timeslot.selected');
121
+ }
122
+ return result;
123
+ }
124
+ getTimeSlotTabIndex(timeSlot, index) {
125
+ if (this.isSelected(timeSlot)) {
126
+ return 0;
127
+ }
128
+ if (!index && !this.hasSelectedSlotInPanel) {
129
+ return 0;
130
+ }
131
+ return -1;
132
+ }
133
+ sliceNbVisibleElements() {
134
+ this.timeSlots = this.currentWeek.timeSlots.slice(0, this.nbVisibleElements);
135
+ this.timeslotRemaining =
136
+ this.currentWeek.timeSlots.length - this.nbVisibleElements;
137
+ }
138
+ getValidValue(day, date, time, calendar) {
139
+ if (!day || !time) {
140
+ if (this.model_ !== undefined) {
141
+ return null;
142
+ }
143
+ return undefined;
144
+ }
145
+ return {
146
+ day,
147
+ time,
148
+ year: calendar.currentWeek.year,
149
+ weekNumber: calendar.currentWeek.weekNumber,
150
+ date
151
+ };
152
+ }
153
+ onNbVisibleElementsChange(change) {
154
+ if (change && change.currentValue) {
155
+ this.sliceNbVisibleElements();
156
+ }
157
+ }
158
+ onKeyDownInner(keyEvent) {
159
+ // IE doesn't support keyEvent.code, and has different values
160
+ // in keyEvent.key (Down instead of ArrowDown for instance), hence the multi-support.
161
+ const ie11CompatibleCode = keyEvent.code || keyEvent.key;
162
+ switch (ie11CompatibleCode) {
163
+ case 'Down':
164
+ case 'ArrowDown':
165
+ case 'Right':
166
+ case 'ArrowRight':
167
+ this.focusTimeSlot(1);
168
+ break;
169
+ case 'Up':
170
+ case 'ArrowUp':
171
+ case 'Left':
172
+ case 'ArrowLeft':
173
+ this.focusTimeSlot(-1);
174
+ break;
175
+ case 'Space':
176
+ case 'Spacebar':
177
+ case 'Enter':
178
+ document.activeElement.dispatchEvent(new Event('click'));
179
+ break;
180
+ default:
181
+ return true;
182
+ }
183
+ keyEvent.preventDefault();
184
+ keyEvent.stopPropagation();
185
+ return false;
186
+ }
187
+ focusTimeSlot(inc) {
188
+ const buttonsArray = [...this.timeSlotButtonsElemRef.toArray()];
189
+ const indexselected = buttonsArray.findIndex(item => item.nativeElement.getAttribute('id') ===
190
+ this.currentActiveElement.getAttribute('id'));
191
+ const newIndex = indexselected + inc;
192
+ if (newIndex >= buttonsArray.length) {
193
+ buttonsArray[0].nativeElement.focus();
194
+ }
195
+ else if (newIndex < 0) {
196
+ buttonsArray[buttonsArray.length - 1].nativeElement.focus();
197
+ }
198
+ else {
199
+ buttonsArray[newIndex].nativeElement.focus();
200
+ }
201
+ }
202
+ }
203
+ FoehnAgendaTimeslotPanelComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: FoehnAgendaTimeslotPanelComponent, deps: [{ token: i1.SdkDictionaryService }], target: i0.ɵɵFactoryTarget.Component });
204
+ FoehnAgendaTimeslotPanelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: FoehnAgendaTimeslotPanelComponent, selector: "foehn-agenda-timeslot-panel", inputs: { calendar: "calendar", nbVisibleElements: "nbVisibleElements", currentWeek: "currentWeek" }, host: { listeners: { "keydown": "handleKeyboardDownEvent($event)" } }, providers: [
205
+ {
206
+ provide: FoehnInputComponent,
207
+ useExisting: forwardRef(() => FoehnAgendaTimeslotPanelComponent),
208
+ multi: true
209
+ }
210
+ ], 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]=\"currentWeek.day + '-' + timeSlot\"\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(--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 } });
211
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: FoehnAgendaTimeslotPanelComponent, decorators: [{
212
+ type: Component,
213
+ args: [{ selector: 'foehn-agenda-timeslot-panel', providers: [
214
+ {
215
+ provide: FoehnInputComponent,
216
+ useExisting: forwardRef(() => FoehnAgendaTimeslotPanelComponent),
217
+ multi: true
218
+ }
219
+ ], 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]=\"currentWeek.day + '-' + timeSlot\"\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(--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"] }]
220
+ }], ctorParameters: function () { return [{ type: i1.SdkDictionaryService }]; }, propDecorators: { timeSlotButtonsElemRef: [{
221
+ type: ViewChildren,
222
+ args: ['timeSlotButtonsElemRef']
223
+ }], calendar: [{
224
+ type: Input
225
+ }], nbVisibleElements: [{
226
+ type: Input
227
+ }], currentWeek: [{
228
+ type: Input
229
+ }], handleKeyboardDownEvent: [{
230
+ type: HostListener,
231
+ args: ['keydown', ['$event']]
232
+ }] } });
233
+ //# 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 cicle 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    private sliceNbVisibleElements(): void {\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 && change.currentValue) {\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]=\"currentWeek.day + '-' + timeSlot\"\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"]}