@dsivd/prestations-ng 16.0.0-beta1 → 16.0.0-beta2

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.
@@ -94,6 +94,10 @@ You can replace the content of your `.eslintrc.json` with the following `json`.
94
94
  },
95
95
  "ignorePatterns": [
96
96
  "/projects/**/*",
97
+ "/package.json",
98
+ "/angular.json",
99
+ "/karma.conf.js",
100
+ "/tsconfig*.json",
97
101
  "/src/test.ts",
98
102
  "/src/main.ts",
99
103
  "/src/polyfills.ts",
@@ -101,6 +105,20 @@ You can replace the content of your `.eslintrc.json` with the following `json`.
101
105
  "/src/typings.d.ts"
102
106
  ],
103
107
  "reportUnusedDisableDirectives": true,
108
+ "settings": {
109
+ "import/extensions": [
110
+ ".js",
111
+ ".ts",
112
+ ".mjs",
113
+ ".mts",
114
+ ".d.ts"
115
+ ],
116
+ "import/internal-regex": "^@dsivd/",
117
+ "import/resolver": {
118
+ "node": { "extensions": [".js", ".ts", ".d.ts"] },
119
+ "typescript": {}
120
+ }
121
+ },
104
122
  "overrides": [
105
123
  // Typescript
106
124
  {
@@ -108,8 +126,7 @@ You can replace the content of your `.eslintrc.json` with the following `json`.
108
126
  "parserOptions": {
109
127
  "ecmaVersion": 2020,
110
128
  "project": [
111
- "tsconfig.json",
112
- "e2e/tsconfig.e2e.json"
129
+ "tsconfig.json"
113
130
  ],
114
131
  "createDefaultProgram": true
115
132
  },
@@ -118,7 +135,8 @@ You can replace the content of your `.eslintrc.json` with the following `json`.
118
135
  "jsdoc",
119
136
  "prefer-arrow",
120
137
  "rxjs",
121
- "rxjs-angular"
138
+ "rxjs-angular",
139
+ "simple-import-sort"
122
140
  ],
123
141
  "extends": [
124
142
  "plugin:@angular-eslint/recommended",
@@ -152,7 +170,9 @@ You can replace the content of your `.eslintrc.json` with the following `json`.
152
170
  }],
153
171
  "@typescript-eslint/ban-ts-comment": "error",
154
172
  "@typescript-eslint/ban-tslint-comment": "error",
155
- "@typescript-eslint/brace-style": "error",
173
+ "@typescript-eslint/brace-style": ["error", "1tbs", {
174
+ "allowSingleLine": true
175
+ }],
156
176
  "@typescript-eslint/comma-dangle": ["error", {
157
177
  "objects": "never",
158
178
  "arrays": "always-multiline",
@@ -204,6 +224,7 @@ You can replace the content of your `.eslintrc.json` with the following `json`.
204
224
  "@typescript-eslint/no-unused-expressions": "error",
205
225
  "@typescript-eslint/no-use-before-define": "off",
206
226
  "@typescript-eslint/no-var-requires": "error",
227
+ "@typescript-eslint/object-curly-spacing": ["error", "always"],
207
228
  "@typescript-eslint/prefer-for-of": "error",
208
229
  "@typescript-eslint/prefer-function-type": "error",
209
230
  "@typescript-eslint/prefer-includes": "warn",
@@ -221,6 +242,7 @@ You can replace the content of your `.eslintrc.json` with the following `json`.
221
242
  }],
222
243
  "@typescript-eslint/unified-signatures": "error",
223
244
  /* @eslint */
245
+ "array-bracket-spacing": ["error", "never"],
224
246
  "arrow-body-style": "error",
225
247
  "arrow-parens": ["error", "as-needed"],
226
248
  "brace-style": "off",
@@ -269,11 +291,13 @@ You can replace the content of your `.eslintrc.json` with the following `json`.
269
291
  "no-unsafe-finally": "error",
270
292
  "no-unused-labels": "error",
271
293
  "no-var": "error",
294
+ "object-curly-spacing": "off",
272
295
  "object-shorthand": ["error", "always", {
273
296
  "avoidQuotes": true,
274
297
  "avoidExplicitReturnArrows": false
275
298
  }],
276
299
  "one-var": ["error", "never"],
300
+ "prefer-arrow-callback": "error",
277
301
  "prefer-template": "error",
278
302
  "quote-props": ["error", "as-needed"],
279
303
  "quotes": ["error", "single"],
@@ -284,6 +308,7 @@ You can replace the content of your `.eslintrc.json` with the following `json`.
284
308
  "asyncArrow": "always",
285
309
  "named": "never"
286
310
  }],
311
+ "space-in-parens": ["error", "never"],
287
312
  "spaced-comment": ["error", "always", {
288
313
  "markers": ["/"]
289
314
  }],
@@ -298,6 +323,11 @@ You can replace the content of your `.eslintrc.json` with the following `json`.
298
323
  "ignoreExternal": true
299
324
  }],
300
325
  "import/no-deprecated": "warn",
326
+ "simple-import-sort/imports": "error",
327
+ "simple-import-sort/exports": "error",
328
+ "import/first": "error",
329
+ "import/newline-after-import": "error",
330
+ "import/no-duplicates": "error",
301
331
  /* @jsdoc */
302
332
  "jsdoc/check-alignment": "error",
303
333
  "jsdoc/check-indentation": "error",
@@ -305,8 +335,6 @@ You can replace the content of your `.eslintrc.json` with the following `json`.
305
335
  "jsdoc/no-types": "error",
306
336
  "jsdoc/require-param-type": "off",
307
337
  "jsdoc/require-returns-type": "off",
308
- /* @preferArrow */
309
- "prefer-arrow/prefer-arrow-functions": "error"
310
338
  }
311
339
  },
312
340
  // HTML
package/UPGRADING_V16.md CHANGED
@@ -19,21 +19,15 @@ at this address:
19
19
  ```bash
20
20
  yarn global add @angular/cli@14
21
21
  ng update @angular/core@14 @angular/cli@14
22
- ng update @angular/cdk@14
23
22
 
24
23
  yarn global add @angular/cli@15
25
- ng update @angular/core@15 @angular/cli@15
26
- ng update @angular/cdk@15
24
+ ng update @angular/core@15 @angular/cli@15 --force
27
25
  ng update @angular-eslint/builder@15
28
26
  ng update @angular-eslint/eslint-plugin @angular-eslint/eslint-plugin-template @angular-eslint/template-parser
29
27
  ng update @typescript-eslint/eslint-plugin @typescript-eslint/parser
30
28
  ng update eslint-plugin-import eslint-plugin-jasmine eslint-plugin-jsdoc eslint-plugin-rxjs-angular
31
29
  ng update eslint
32
30
  ng update eslint-plugin-rxjs@5
33
- ng update ngx-image-cropper@~6.3.2
34
- ng update ng-http-loader@13
35
- ng update dayjs@~1.11.7
36
- ng update rxjs@7
37
31
  ng update \
38
32
  @types/jasmine \
39
33
  @types/node@16 \
@@ -41,7 +35,6 @@ ng update \
41
35
  ng update @dsivd/prestations-ng@latest
42
36
 
43
37
  yarn add eslint-import-resolver-typescript --dev
44
- yarn add eslint-plugin-rxjs-angular --dev
45
38
  yarn remove eslint-plugin-prefer-arrow
46
39
  # Remove your resolutions in package.json before executing 'yarn upgrade'
47
40
  yarn upgrade
@@ -150,9 +150,11 @@ export class FoehnDatePickerComponent {
150
150
  return date.isSame(this.selectedDate);
151
151
  }
152
152
  handleUserInput(date) {
153
- const dateAsArray = this.getDateAsArray(date);
154
- this.userInput.next(dateAsArray);
155
- this.updateNgModel(dateAsArray);
153
+ if (this.isDateInRange(date)) {
154
+ const dateAsArray = this.getDateAsArray(date);
155
+ this.userInput.next(dateAsArray);
156
+ this.updateNgModel(dateAsArray);
157
+ }
156
158
  }
157
159
  previousMonth() {
158
160
  this.weeks = this.datePickerHelper.getPreviousWeeksOfMonth();
@@ -384,4 +386,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.2", ngImpor
384
386
  type: HostListener,
385
387
  args: ['keydown', ['$event']]
386
388
  }] } });
387
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-date-picker.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-date-picker/foehn-date-picker.component.ts","../../../../projects/prestations-ng/src/foehn-date-picker/foehn-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    Output,\n    QueryList,\n    ViewChildren\n} from '@angular/core';\nimport dayjs from 'dayjs';\nimport isToday from 'dayjs/plugin/isToday';\nimport { Observable, Subscription } from 'rxjs';\nimport { distinctUntilChanged, first } from 'rxjs/operators';\n\nimport { FormSelectOption } from '../foehn-checkables/form-select-option';\nimport { SdkDictionaryService } from '../sdk-dictionary/sdk-dictionary.service';\nimport { DatePickerHelper } from './date-picker.helper';\nimport { DatePickerNavigationHelper } from './date-picker-navigation.helper';\nimport { DayMonth } from './day-month.type';\nimport { MonthYear } from './month-year.type';\n\ndayjs.extend(isToday);\n\n@Component({\n    selector: 'foehn-date-picker',\n    templateUrl: './foehn-date-picker.component.html',\n    styleUrls: ['./foehn-date-picker.component.css']\n})\nexport class FoehnDatePickerComponent\n    implements OnInit, OnDestroy, AfterViewInit {\n    @Input()\n    id: string;\n\n    @Input()\n    name: string;\n\n    @Input()\n    minYear = dayjs().year() - 100;\n\n    @Input()\n    maxYear = dayjs().year() + 10;\n\n    @Input()\n    minDate: number[];\n\n    @Input()\n    maxDate: number[];\n\n    @Input()\n    datepickerTriggerHtmlElement: HTMLElement;\n\n    @Input()\n    closeable = true;\n\n    @Output()\n    modelChange = new EventEmitter<number[]>();\n\n    @Output()\n    userInput = new EventEmitter<number[]>();\n\n    @Output()\n    isDatepickerVisibleChange = new EventEmitter();\n\n    @HostBinding('attr.id')\n    hostId: string;\n\n    @ViewChildren('dayButtonElemRef')\n    daysButtonsElemRef: QueryList<ElementRef>;\n\n    weekDays: string[] = [];\n    weeks: DayMonth[][];\n\n    selectedDate: dayjs.Dayjs;\n    currentMonthYear: Observable<MonthYear>;\n\n    model_: number[];\n    monthListItem: FormSelectOption[] = [];\n    yearListItem: FormSelectOption[] = [];\n\n    private isVisible = false;\n    private keyboardNavigationAllowed = false;\n    private currentLanguageCodeSubscription: Subscription;\n    private datePickerHelper = new DatePickerHelper();\n    private datePickerNavigationHelper = new DatePickerNavigationHelper();\n\n    private readonly displayNextMonthSubscription: Subscription;\n    private readonly displayPreviousMonthSubscription: Subscription;\n\n    constructor(\n        private dictionary: SdkDictionaryService,\n        private ngZone: NgZone,\n        private changeDetector: ChangeDetectorRef\n    ) {\n        this.currentMonthYear = this.datePickerHelper.displayedMonthYear;\n        // eslint-disable-next-line rxjs-angular/prefer-async-pipe\n        this.displayNextMonthSubscription = this.datePickerNavigationHelper.displayNextMonth.subscribe(\n            () => this.nextMonth()\n        );\n        // eslint-disable-next-line rxjs-angular/prefer-async-pipe\n        this.displayPreviousMonthSubscription = this.datePickerNavigationHelper.displayPreviousMonth.subscribe(\n            () => this.previousMonth()\n        );\n    }\n\n    get isDatepickerVisible(): boolean {\n        return this.isVisible;\n    }\n\n    @Input()\n    set isDatepickerVisible(val: boolean) {\n        // Store the previous value to handle transitions from one state to another.\n        const wasOpen = this.isVisible;\n\n        // Ensure we always initialize date picker depending on it's model\n        if (!wasOpen && this.closeable) {\n            this.onModelChange(this.model);\n        }\n\n        this.isVisible = val;\n        this.isDatepickerVisibleChange.emit(this.isVisible);\n\n        this.focusDefaultDay();\n        this.focusOnDatepickerTrigger(wasOpen, val);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/member-ordering\n    get model(): number[] {\n        return this.model_;\n    }\n\n    @Input()\n    set model(value: number[]) {\n        this.onModelChange(value);\n    }\n\n    @HostListener('keyup', ['$event'])\n    handleKeyboardUpEvent(event: KeyboardEvent): void {\n        if (this.closeable && event.key === 'Escape') {\n            this.isDatepickerVisible = false;\n        }\n    }\n\n    @HostListener('keydown', ['$event'])\n    handleKeyboardDownEvent(event: KeyboardEvent): void {\n        if (this.keyboardNavigationAllowed) {\n            this.onKeyDownInner(event);\n        }\n    }\n\n    ngOnInit(): void {\n        // Ensures that the host has an Id for instrumentalization of the DOM by automated tests.\n        this.hostId = this.buildId();\n        this.datePickerNavigationHelper.hostId = this.hostId;\n\n        this.currentLanguageCodeSubscription = this.dictionary\n            .getCurrentLanguageCode()\n            .pipe(distinctUntilChanged())\n            // eslint-disable-next-line rxjs-angular/prefer-async-pipe\n            .subscribe((code: string) => {\n                this.datePickerHelper\n                    .loadLocale(code)\n                    .catch(() => {\n                        console.warn(\n                            `locale '${code}' does not exist. Fallback to 'en.'`\n                        );\n                    })\n                    .then(() => {\n                        this.initializeDatepicker();\n                    });\n            });\n    }\n\n    ngAfterViewInit(): void {\n        // eslint-disable-next-line rxjs-angular/prefer-async-pipe\n        this.daysButtonsElemRef.changes.subscribe(() => {\n            // For tests purpose, when setting component minDate, avoids having error:\n            // \"NG0100: ExpressionChangedAfterItHasBeenCheckedError: Expression has changed after it was checked.\n            // Previous value for 'tabindex': '-1'. Current value: '0'\"\n            this.changeDetector.detectChanges();\n            this.datePickerNavigationHelper.daysButtonsElemRef = this.daysButtonsElemRef;\n        });\n    }\n\n    ngOnDestroy(): void {\n        if (!!this.currentLanguageCodeSubscription) {\n            this.currentLanguageCodeSubscription.unsubscribe();\n        }\n        if (!!this.displayNextMonthSubscription) {\n            this.displayNextMonthSubscription.unsubscribe();\n        }\n        if (!!this.displayPreviousMonthSubscription) {\n            this.displayPreviousMonthSubscription.unsubscribe();\n        }\n    }\n\n    onModelChange(value: number[]): void {\n        if (\n            !!value &&\n            value.length > 2 &&\n            !!value[0] &&\n            value[0] >= this.minYear &&\n            !!value[1] &&\n            !!value[2]\n        ) {\n            const dateAsString = `${value[0]}-${value[1]}-${value[2]}`;\n            if (dayjs(dateAsString).isValid()) {\n                this.setDate(dayjs(dateAsString));\n            }\n        } else if (this.selectedDate) {\n            this.setDate(null);\n        }\n        this.updateNgModel(value);\n    }\n\n    updateNgModel(value: number[]): void {\n        this.model_ = value;\n        this.modelChange.emit(value);\n    }\n\n    buildId(suffix: string = ''): string {\n        // The baseId is either an id given by the user or the value of the name.\n        // For integration purposes, the container foehn-* must have an Id.\n        const baseId = this.id || this.name;\n        if (!baseId) {\n            return !!suffix ? suffix : null;\n        }\n\n        return `${baseId}${suffix}`;\n    }\n\n    isToday(date: dayjs.Dayjs): boolean {\n        return date.isToday();\n    }\n\n    isSelected(date: dayjs.Dayjs): boolean {\n        if (!this.selectedDate) {\n            return false;\n        }\n        return date.isSame(this.selectedDate);\n    }\n\n    handleUserInput(date: dayjs.Dayjs): void {\n        const dateAsArray = this.getDateAsArray(date);\n\n        this.userInput.next(dateAsArray);\n        this.updateNgModel(dateAsArray);\n    }\n\n    previousMonth(): void {\n        this.weeks = this.datePickerHelper.getPreviousWeeksOfMonth();\n    }\n\n    nextMonth(): void {\n        this.weeks = this.datePickerHelper.getNextWeeksOfMonth();\n    }\n\n    userInputMonth(month: string): void {\n        this.weeks = this.datePickerHelper.getWeeksOfMonth(\n            this.datePickerHelper.initialYear,\n            (+month + 1).toString(),\n            this.datePickerHelper.initialDay\n        );\n    }\n\n    userInputYear(year: string): void {\n        this.weeks = this.datePickerHelper.getWeeksOfMonth(\n            year,\n            this.datePickerHelper.initialMonth,\n            this.datePickerHelper.initialDay\n        );\n    }\n\n    getMonthAsReadable(monthIndex: string): string {\n        return this.monthListItem.find(elem => elem.value === monthIndex).label;\n    }\n\n    onDaysFocusin(): void {\n        this.keyboardNavigationAllowed = true;\n        this.datePickerNavigationHelper.currentFocusedElement =\n            document.activeElement;\n    }\n\n    onDaysFocusout(): void {\n        this.keyboardNavigationAllowed = false;\n    }\n\n    getDayTabIndex(day: DayMonth): number {\n        if (!this.isDateInRange(day.date)) {\n            return -1;\n        }\n        if (\n            this.selectedDate &&\n            this.selectedDate.month() === day.date.month() &&\n            this.selectedDate.year() === day.date.year()\n        ) {\n            if (this.selectedDate.date() === day.date.date()) {\n                return 0;\n            }\n            return -1;\n        }\n        if (this.isToday(day.date)) {\n            return 0;\n        }\n        const daysInWeek = [...this.daysButtonsElemRef.toArray()].filter(\n            value => value.nativeElement.getAttribute('disabled') === null\n        );\n        if (\n            !!daysInWeek.length &&\n            day.isCurrentMonth &&\n            day.dayOfMonth.toString() ===\n                daysInWeek[0].nativeElement.getAttribute('day-number') &&\n            (day.date.month() !== dayjs().month() ||\n                day.date.year() !== dayjs().year())\n        ) {\n            return 0;\n        }\n        return -1;\n    }\n\n    focusDefaultDay(): void {\n        // Have to wait for a micro task empty as we're affecting the DOM outside of the Angular lifecycle.\n        // eslint-disable-next-line rxjs-angular/prefer-async-pipe\n        this.ngZone.onMicrotaskEmpty.pipe(first()).subscribe(() => {\n            if (this.isVisible && this.datepickerTriggerHtmlElement) {\n                this.datePickerNavigationHelper.focusDefaultDay(\n                    !!this.selectedDate\n                );\n            }\n        });\n    }\n\n    getDayDisabledAttribute(dayOfWeek: DayMonth): string {\n        if (!dayOfWeek.isCurrentMonth) {\n            return 'disabled';\n        }\n        if (!this.isDateInRange(dayOfWeek.date)) {\n            return 'disabled';\n        }\n        return null;\n    }\n\n    isPreviousMonthDisabled(monthYear: MonthYear): string {\n        return monthYear.year === this.minYear.toString() &&\n            monthYear.month === '0'\n            ? 'disabled'\n            : null;\n    }\n\n    isNextMonthDisabled(monthYear: MonthYear): string {\n        return monthYear.year === this.maxYear.toString() &&\n            monthYear.month === '11'\n            ? 'disabled'\n            : null;\n    }\n\n    private isDateInRange(date: dayjs.Dayjs): boolean {\n        // Min year and date management\n        const minDateAsString = DatePickerHelper.getDateAsString(this.minDate);\n        if (minDateAsString) {\n            const minDateAsDayjs = dayjs(minDateAsString);\n            if (minDateAsDayjs.isValid() && date.isBefore(minDateAsDayjs)) {\n                return false;\n            }\n        }\n        if (date.year() < this.minYear) {\n            return false;\n        }\n        // Max year and date management\n        const maxDateAsString = DatePickerHelper.getDateAsString(this.maxDate);\n        if (maxDateAsString) {\n            const maxDateAsDayjs = dayjs(maxDateAsString);\n            if (\n                maxDateAsDayjs.isValid() &&\n                date.isAfter(maxDateAsDayjs) &&\n                date.year() <= maxDateAsDayjs.year()\n            ) {\n                return false;\n            }\n        }\n        return date.year() <= this.maxYear;\n    }\n\n    private initializeDatepicker(): void {\n        this.populateMonthList();\n        this.populateYearList();\n        this.weekDays = this.datePickerHelper.getWeekDays();\n        this.weeks = this.datePickerHelper.getWeeksOfMonth(\n            dayjs().format(this.datePickerHelper.YEAR_STRING_FORMAT),\n            dayjs().format(this.datePickerHelper.MONTH_STRING_NUMBER_FORMAT)\n        );\n    }\n\n    private setDate(date: dayjs.Dayjs): void {\n        this.selectedDate = date;\n\n        // Either we have a date to set or we take today\n        const dateToFormat = date ? date : dayjs();\n        this.weeks = this.datePickerHelper.getWeeksOfMonth(\n            dateToFormat.format(this.datePickerHelper.YEAR_STRING_FORMAT),\n            dateToFormat.format(\n                this.datePickerHelper.MONTH_STRING_NUMBER_FORMAT\n            ),\n            dateToFormat.format(this.datePickerHelper.DAY_STRING_NUMBER_FORMAT)\n        );\n    }\n\n    private getDateAsArray(date: dayjs.Dayjs): number[] {\n        return [\n            +date.format(this.datePickerHelper.YEAR_STRING_FORMAT),\n            +date.format(this.datePickerHelper.MONTH_STRING_NUMBER_FORMAT),\n            +date.format(this.datePickerHelper.DAY_STRING_NUMBER_FORMAT)\n        ];\n    }\n\n    private focusOnDatepickerTrigger(\n        wasOpen: boolean,\n        isVisible: boolean\n    ): void {\n        // Focus back on the trigger. No need for a setTimeout as the trigger should still be in the DOM.\n        // Only does it when the modal is closed from a open state to avoid to set\n        // the focus when the page loads.\n        if (wasOpen && !isVisible && this.datepickerTriggerHtmlElement) {\n            this.datepickerTriggerHtmlElement.focus();\n        }\n    }\n\n    private populateMonthList(): void {\n        this.monthListItem = dayjs()\n            .localeData()\n            .months()\n            .map((month: string, index: number) => ({\n                label: month,\n                value: index.toString()\n            }));\n    }\n\n    private populateYearList(): void {\n        const range = (start: number, end: number): number[] =>\n            Array.from({ length: end - start + 1 }, (v, k) => k + start);\n\n        if (!!this.minDate && !!this.minDate.length) {\n            this.minYear = this.minDate[0];\n        }\n        if (!!this.maxDate && !!this.maxDate.length) {\n            this.maxYear = this.maxDate[0];\n        }\n\n        this.yearListItem = range(this.minYear, this.maxYear).map(\n            (year: number) => ({\n                label: year.toString(),\n                value: year.toString()\n            })\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                this.datePickerNavigationHelper.focusNextWeekDay();\n                break;\n            case 'Up':\n            case 'ArrowUp':\n                this.datePickerNavigationHelper.focusPreviousWeekDay();\n                break;\n            case 'Space':\n            case 'Spacebar':\n            case 'Enter':\n                document.activeElement.dispatchEvent(new Event('click'));\n                break;\n            case 'Right':\n            case 'ArrowRight':\n                this.datePickerNavigationHelper.focusNextDay();\n                break;\n            case 'Left':\n            case 'ArrowLeft':\n                this.datePickerNavigationHelper.focusPreviousDay();\n                break;\n            default:\n                return true;\n        }\n\n        keyEvent.preventDefault();\n        keyEvent.stopPropagation();\n\n        return false;\n    }\n}\n","<div\n    [id]=\"buildId('datepicker_wrapper')\"\n    class=\"datepicker_wrapper\"\n    *ngIf=\"isDatepickerVisible\"\n    [cdkTrapFocus]=\"!!datepickerTriggerHtmlElement\"\n    tabindex=\"-1\"\n    role=\"application\"\n    [attr.aria-label]=\"\n        'foehn-date-picker.container.aria-label' | fromDictionary\n    \"\n>\n    <button\n        *ngIf=\"closeable\"\n        (click)=\"isDatepickerVisible = false\"\n        type=\"button\"\n        class=\"btn close\"\n        [attr.aria-label]=\"\n            'foehn-date-picker.close-button.aria-label' | fromDictionary\n        \"\n        [id]=\"buildId('closeButton')\"\n    >\n        <span aria-hidden=\"true\">&times;</span>\n    </button>\n    <div\n        [id]=\"buildId('datepicker_header')\"\n        class=\"d-flex justify-content-between datepicker_header\"\n    >\n        <ng-container *ngIf=\"currentMonthYear | async as monthYear\">\n            <button\n                [id]=\"buildId('previous-month')\"\n                class=\"btn btn-link datepicker-nav-month-btn\"\n                (click)=\"previousMonth()\"\n                [attr.disabled]=\"isPreviousMonthDisabled(monthYear)\"\n            >\n                <foehn-icon-chevron-left\n                    [title]=\"\n                        'foehn-date-picker.previous-month-button.title'\n                            | fromDictionary\n                    \"\n                ></foehn-icon-chevron-left>\n            </button>\n            <span\n                [id]=\"buildId('month-year-label')\"\n                aria-live=\"polite\"\n                class=\"sr-only\"\n            >\n                {{\n                    'foehn-date-picker.screen-reader.actual-month-displayed'\n                        | fromDictionary\n                }}\n                {{ getMonthAsReadable(monthYear.month) }} {{ monthYear.year }}\n            </span>\n            <foehn-select\n                [id]=\"buildId('month-input')\"\n                class=\"align-self-center month-input\"\n                [label]=\"\n                    'foehn-date-picker.screen-reader.month-input.label'\n                        | fromDictionary\n                \"\n                [isLabelSrOnly]=\"true\"\n                [elements]=\"monthListItem\"\n                [model]=\"monthYear.month\"\n                [required]=\"true\"\n                (userInput)=\"userInputMonth($event)\"\n            ></foehn-select>\n            <foehn-select\n                [id]=\"buildId('year-input')\"\n                class=\"align-self-center\"\n                [label]=\"\n                    'foehn-date-picker.screen-reader.year-input.label'\n                        | fromDictionary\n                \"\n                [isLabelSrOnly]=\"true\"\n                [elements]=\"yearListItem\"\n                [model]=\"monthYear.year\"\n                [required]=\"true\"\n                (userInput)=\"userInputYear($event)\"\n            ></foehn-select>\n            <button\n                [id]=\"buildId('next-month')\"\n                class=\"btn btn-link datepicker-nav-month-btn\"\n                (click)=\"nextMonth()\"\n                [attr.disabled]=\"isNextMonthDisabled(monthYear)\"\n            >\n                <foehn-icon-chevron-right\n                    [title]=\"\n                        'foehn-date-picker.next-month-button.title'\n                            | fromDictionary\n                    \"\n                ></foehn-icon-chevron-right>\n            </button>\n        </ng-container>\n    </div>\n    <table\n        [id]=\"buildId('datepicker_table')\"\n        role=\"grid\"\n        (focusin)=\"onDaysFocusin()\"\n        (focusout)=\"onDaysFocusout()\"\n    >\n        <thead role=\"presentation\" aria-hidden=\"true\">\n            <tr role=\"row\">\n                <th\n                    scope=\"col\"\n                    role=\"columnheader\"\n                    *ngFor=\"let weekday of weekDays\"\n                >\n                    <foehn-abbr\n                        [text]=\"weekday.substr(0, 2)\"\n                        [title]=\"weekday\"\n                    ></foehn-abbr>\n                </th>\n            </tr>\n        </thead>\n        <tbody role=\"presentation\">\n            <tr role=\"row\" *ngFor=\"let week of weeks; let indexRow = index\">\n                <td\n                    role=\"gridcell\"\n                    *ngFor=\"let dayOfWeek of week; let indexColumn = index\"\n                >\n                    <button\n                        class=\"btn w-100\"\n                        #dayButtonElemRef\n                        [hidden]=\"!dayOfWeek.isCurrentMonth\"\n                        [id]=\"buildId('day_' + indexRow + '_' + indexColumn)\"\n                        [tabindex]=\"getDayTabIndex(dayOfWeek)\"\n                        [class.btn-info]=\"!isToday(dayOfWeek.date)\"\n                        [class.btn-secondary]=\"isToday(dayOfWeek.date)\"\n                        [class.btn-danger]=\"isSelected(dayOfWeek.date)\"\n                        [attr.aria-label]=\"\n                            weekDays[indexColumn] +\n                            ' ' +\n                            dayOfWeek.dateAsReadable\n                        \"\n                        [attr.data-is-today]=\"isToday(dayOfWeek.date)\"\n                        [attr.data-is-selected]=\"isSelected(dayOfWeek.date)\"\n                        [attr.data-row-index]=\"indexRow\"\n                        [attr.data-column-index]=\"indexColumn\"\n                        [attr.day-number]=\"dayOfWeek.dayOfMonth\"\n                        [attr.disabled]=\"getDayDisabledAttribute(dayOfWeek)\"\n                        (click)=\"handleUserInput(dayOfWeek.date)\"\n                    >\n                        {{ dayOfWeek.dayOfMonth }}\n                    </button>\n                </td>\n            </tr>\n        </tbody>\n    </table>\n</div>\n"]}
389
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-date-picker.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-date-picker/foehn-date-picker.component.ts","../../../../projects/prestations-ng/src/foehn-date-picker/foehn-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    Output,\n    QueryList,\n    ViewChildren\n} from '@angular/core';\nimport dayjs from 'dayjs';\nimport isToday from 'dayjs/plugin/isToday';\nimport { Observable, Subscription } from 'rxjs';\nimport { distinctUntilChanged, first } from 'rxjs/operators';\n\nimport { FormSelectOption } from '../foehn-checkables/form-select-option';\nimport { SdkDictionaryService } from '../sdk-dictionary/sdk-dictionary.service';\nimport { DatePickerHelper } from './date-picker.helper';\nimport { DatePickerNavigationHelper } from './date-picker-navigation.helper';\nimport { DayMonth } from './day-month.type';\nimport { MonthYear } from './month-year.type';\n\ndayjs.extend(isToday);\n\n@Component({\n    selector: 'foehn-date-picker',\n    templateUrl: './foehn-date-picker.component.html',\n    styleUrls: ['./foehn-date-picker.component.css']\n})\nexport class FoehnDatePickerComponent\n    implements OnInit, OnDestroy, AfterViewInit {\n    @Input()\n    id: string;\n\n    @Input()\n    name: string;\n\n    @Input()\n    minYear = dayjs().year() - 100;\n\n    @Input()\n    maxYear = dayjs().year() + 10;\n\n    @Input()\n    minDate: number[];\n\n    @Input()\n    maxDate: number[];\n\n    @Input()\n    datepickerTriggerHtmlElement: HTMLElement;\n\n    @Input()\n    closeable = true;\n\n    @Output()\n    modelChange = new EventEmitter<number[]>();\n\n    @Output()\n    userInput = new EventEmitter<number[]>();\n\n    @Output()\n    isDatepickerVisibleChange = new EventEmitter();\n\n    @HostBinding('attr.id')\n    hostId: string;\n\n    @ViewChildren('dayButtonElemRef')\n    daysButtonsElemRef: QueryList<ElementRef>;\n\n    weekDays: string[] = [];\n    weeks: DayMonth[][];\n\n    selectedDate: dayjs.Dayjs;\n    currentMonthYear: Observable<MonthYear>;\n\n    model_: number[];\n    monthListItem: FormSelectOption[] = [];\n    yearListItem: FormSelectOption[] = [];\n\n    private isVisible = false;\n    private keyboardNavigationAllowed = false;\n    private currentLanguageCodeSubscription: Subscription;\n    private datePickerHelper = new DatePickerHelper();\n    private datePickerNavigationHelper = new DatePickerNavigationHelper();\n\n    private readonly displayNextMonthSubscription: Subscription;\n    private readonly displayPreviousMonthSubscription: Subscription;\n\n    constructor(\n        private dictionary: SdkDictionaryService,\n        private ngZone: NgZone,\n        private changeDetector: ChangeDetectorRef\n    ) {\n        this.currentMonthYear = this.datePickerHelper.displayedMonthYear;\n        // eslint-disable-next-line rxjs-angular/prefer-async-pipe\n        this.displayNextMonthSubscription = this.datePickerNavigationHelper.displayNextMonth.subscribe(\n            () => this.nextMonth()\n        );\n        // eslint-disable-next-line rxjs-angular/prefer-async-pipe\n        this.displayPreviousMonthSubscription = this.datePickerNavigationHelper.displayPreviousMonth.subscribe(\n            () => this.previousMonth()\n        );\n    }\n\n    get isDatepickerVisible(): boolean {\n        return this.isVisible;\n    }\n\n    @Input()\n    set isDatepickerVisible(val: boolean) {\n        // Store the previous value to handle transitions from one state to another.\n        const wasOpen = this.isVisible;\n\n        // Ensure we always initialize date picker depending on it's model\n        if (!wasOpen && this.closeable) {\n            this.onModelChange(this.model);\n        }\n\n        this.isVisible = val;\n        this.isDatepickerVisibleChange.emit(this.isVisible);\n\n        this.focusDefaultDay();\n        this.focusOnDatepickerTrigger(wasOpen, val);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/member-ordering\n    get model(): number[] {\n        return this.model_;\n    }\n\n    @Input()\n    set model(value: number[]) {\n        this.onModelChange(value);\n    }\n\n    @HostListener('keyup', ['$event'])\n    handleKeyboardUpEvent(event: KeyboardEvent): void {\n        if (this.closeable && event.key === 'Escape') {\n            this.isDatepickerVisible = false;\n        }\n    }\n\n    @HostListener('keydown', ['$event'])\n    handleKeyboardDownEvent(event: KeyboardEvent): void {\n        if (this.keyboardNavigationAllowed) {\n            this.onKeyDownInner(event);\n        }\n    }\n\n    ngOnInit(): void {\n        // Ensures that the host has an Id for instrumentalization of the DOM by automated tests.\n        this.hostId = this.buildId();\n        this.datePickerNavigationHelper.hostId = this.hostId;\n\n        this.currentLanguageCodeSubscription = this.dictionary\n            .getCurrentLanguageCode()\n            .pipe(distinctUntilChanged())\n            // eslint-disable-next-line rxjs-angular/prefer-async-pipe\n            .subscribe((code: string) => {\n                this.datePickerHelper\n                    .loadLocale(code)\n                    .catch(() => {\n                        console.warn(\n                            `locale '${code}' does not exist. Fallback to 'en.'`\n                        );\n                    })\n                    .then(() => {\n                        this.initializeDatepicker();\n                    });\n            });\n    }\n\n    ngAfterViewInit(): void {\n        // eslint-disable-next-line rxjs-angular/prefer-async-pipe\n        this.daysButtonsElemRef.changes.subscribe(() => {\n            // For tests purpose, when setting component minDate, avoids having error:\n            // \"NG0100: ExpressionChangedAfterItHasBeenCheckedError: Expression has changed after it was checked.\n            // Previous value for 'tabindex': '-1'. Current value: '0'\"\n            this.changeDetector.detectChanges();\n            this.datePickerNavigationHelper.daysButtonsElemRef = this.daysButtonsElemRef;\n        });\n    }\n\n    ngOnDestroy(): void {\n        if (!!this.currentLanguageCodeSubscription) {\n            this.currentLanguageCodeSubscription.unsubscribe();\n        }\n        if (!!this.displayNextMonthSubscription) {\n            this.displayNextMonthSubscription.unsubscribe();\n        }\n        if (!!this.displayPreviousMonthSubscription) {\n            this.displayPreviousMonthSubscription.unsubscribe();\n        }\n    }\n\n    onModelChange(value: number[]): void {\n        if (\n            !!value &&\n            value.length > 2 &&\n            !!value[0] &&\n            value[0] >= this.minYear &&\n            !!value[1] &&\n            !!value[2]\n        ) {\n            const dateAsString = `${value[0]}-${value[1]}-${value[2]}`;\n            if (dayjs(dateAsString).isValid()) {\n                this.setDate(dayjs(dateAsString));\n            }\n        } else if (this.selectedDate) {\n            this.setDate(null);\n        }\n        this.updateNgModel(value);\n    }\n\n    updateNgModel(value: number[]): void {\n        this.model_ = value;\n        this.modelChange.emit(value);\n    }\n\n    buildId(suffix: string = ''): string {\n        // The baseId is either an id given by the user or the value of the name.\n        // For integration purposes, the container foehn-* must have an Id.\n        const baseId = this.id || this.name;\n        if (!baseId) {\n            return !!suffix ? suffix : null;\n        }\n\n        return `${baseId}${suffix}`;\n    }\n\n    isToday(date: dayjs.Dayjs): boolean {\n        return date.isToday();\n    }\n\n    isSelected(date: dayjs.Dayjs): boolean {\n        if (!this.selectedDate) {\n            return false;\n        }\n        return date.isSame(this.selectedDate);\n    }\n\n    handleUserInput(date: dayjs.Dayjs): void {\n        if (this.isDateInRange(date)) {\n            const dateAsArray = this.getDateAsArray(date);\n\n            this.userInput.next(dateAsArray);\n            this.updateNgModel(dateAsArray);\n        }\n    }\n\n    previousMonth(): void {\n        this.weeks = this.datePickerHelper.getPreviousWeeksOfMonth();\n    }\n\n    nextMonth(): void {\n        this.weeks = this.datePickerHelper.getNextWeeksOfMonth();\n    }\n\n    userInputMonth(month: string): void {\n        this.weeks = this.datePickerHelper.getWeeksOfMonth(\n            this.datePickerHelper.initialYear,\n            (+month + 1).toString(),\n            this.datePickerHelper.initialDay\n        );\n    }\n\n    userInputYear(year: string): void {\n        this.weeks = this.datePickerHelper.getWeeksOfMonth(\n            year,\n            this.datePickerHelper.initialMonth,\n            this.datePickerHelper.initialDay\n        );\n    }\n\n    getMonthAsReadable(monthIndex: string): string {\n        return this.monthListItem.find(elem => elem.value === monthIndex).label;\n    }\n\n    onDaysFocusin(): void {\n        this.keyboardNavigationAllowed = true;\n        this.datePickerNavigationHelper.currentFocusedElement =\n            document.activeElement;\n    }\n\n    onDaysFocusout(): void {\n        this.keyboardNavigationAllowed = false;\n    }\n\n    getDayTabIndex(day: DayMonth): number {\n        if (!this.isDateInRange(day.date)) {\n            return -1;\n        }\n        if (\n            this.selectedDate &&\n            this.selectedDate.month() === day.date.month() &&\n            this.selectedDate.year() === day.date.year()\n        ) {\n            if (this.selectedDate.date() === day.date.date()) {\n                return 0;\n            }\n            return -1;\n        }\n        if (this.isToday(day.date)) {\n            return 0;\n        }\n        const daysInWeek = [...this.daysButtonsElemRef.toArray()].filter(\n            value => value.nativeElement.getAttribute('disabled') === null\n        );\n        if (\n            !!daysInWeek.length &&\n            day.isCurrentMonth &&\n            day.dayOfMonth.toString() ===\n                daysInWeek[0].nativeElement.getAttribute('day-number') &&\n            (day.date.month() !== dayjs().month() ||\n                day.date.year() !== dayjs().year())\n        ) {\n            return 0;\n        }\n        return -1;\n    }\n\n    focusDefaultDay(): void {\n        // Have to wait for a micro task empty as we're affecting the DOM outside of the Angular lifecycle.\n        // eslint-disable-next-line rxjs-angular/prefer-async-pipe\n        this.ngZone.onMicrotaskEmpty.pipe(first()).subscribe(() => {\n            if (this.isVisible && this.datepickerTriggerHtmlElement) {\n                this.datePickerNavigationHelper.focusDefaultDay(\n                    !!this.selectedDate\n                );\n            }\n        });\n    }\n\n    getDayDisabledAttribute(dayOfWeek: DayMonth): string {\n        if (!dayOfWeek.isCurrentMonth) {\n            return 'disabled';\n        }\n        if (!this.isDateInRange(dayOfWeek.date)) {\n            return 'disabled';\n        }\n        return null;\n    }\n\n    isPreviousMonthDisabled(monthYear: MonthYear): string {\n        return monthYear.year === this.minYear.toString() &&\n            monthYear.month === '0'\n            ? 'disabled'\n            : null;\n    }\n\n    isNextMonthDisabled(monthYear: MonthYear): string {\n        return monthYear.year === this.maxYear.toString() &&\n            monthYear.month === '11'\n            ? 'disabled'\n            : null;\n    }\n\n    private isDateInRange(date: dayjs.Dayjs): boolean {\n        // Min year and date management\n        const minDateAsString = DatePickerHelper.getDateAsString(this.minDate);\n        if (minDateAsString) {\n            const minDateAsDayjs = dayjs(minDateAsString);\n            if (minDateAsDayjs.isValid() && date.isBefore(minDateAsDayjs)) {\n                return false;\n            }\n        }\n        if (date.year() < this.minYear) {\n            return false;\n        }\n        // Max year and date management\n        const maxDateAsString = DatePickerHelper.getDateAsString(this.maxDate);\n        if (maxDateAsString) {\n            const maxDateAsDayjs = dayjs(maxDateAsString);\n            if (\n                maxDateAsDayjs.isValid() &&\n                date.isAfter(maxDateAsDayjs) &&\n                date.year() <= maxDateAsDayjs.year()\n            ) {\n                return false;\n            }\n        }\n        return date.year() <= this.maxYear;\n    }\n\n    private initializeDatepicker(): void {\n        this.populateMonthList();\n        this.populateYearList();\n        this.weekDays = this.datePickerHelper.getWeekDays();\n        this.weeks = this.datePickerHelper.getWeeksOfMonth(\n            dayjs().format(this.datePickerHelper.YEAR_STRING_FORMAT),\n            dayjs().format(this.datePickerHelper.MONTH_STRING_NUMBER_FORMAT)\n        );\n    }\n\n    private setDate(date: dayjs.Dayjs): void {\n        this.selectedDate = date;\n\n        // Either we have a date to set or we take today\n        const dateToFormat = date ? date : dayjs();\n        this.weeks = this.datePickerHelper.getWeeksOfMonth(\n            dateToFormat.format(this.datePickerHelper.YEAR_STRING_FORMAT),\n            dateToFormat.format(\n                this.datePickerHelper.MONTH_STRING_NUMBER_FORMAT\n            ),\n            dateToFormat.format(this.datePickerHelper.DAY_STRING_NUMBER_FORMAT)\n        );\n    }\n\n    private getDateAsArray(date: dayjs.Dayjs): number[] {\n        return [\n            +date.format(this.datePickerHelper.YEAR_STRING_FORMAT),\n            +date.format(this.datePickerHelper.MONTH_STRING_NUMBER_FORMAT),\n            +date.format(this.datePickerHelper.DAY_STRING_NUMBER_FORMAT)\n        ];\n    }\n\n    private focusOnDatepickerTrigger(\n        wasOpen: boolean,\n        isVisible: boolean\n    ): void {\n        // Focus back on the trigger. No need for a setTimeout as the trigger should still be in the DOM.\n        // Only does it when the modal is closed from a open state to avoid to set\n        // the focus when the page loads.\n        if (wasOpen && !isVisible && this.datepickerTriggerHtmlElement) {\n            this.datepickerTriggerHtmlElement.focus();\n        }\n    }\n\n    private populateMonthList(): void {\n        this.monthListItem = dayjs()\n            .localeData()\n            .months()\n            .map((month: string, index: number) => ({\n                label: month,\n                value: index.toString()\n            }));\n    }\n\n    private populateYearList(): void {\n        const range = (start: number, end: number): number[] =>\n            Array.from({ length: end - start + 1 }, (v, k) => k + start);\n\n        if (!!this.minDate && !!this.minDate.length) {\n            this.minYear = this.minDate[0];\n        }\n        if (!!this.maxDate && !!this.maxDate.length) {\n            this.maxYear = this.maxDate[0];\n        }\n\n        this.yearListItem = range(this.minYear, this.maxYear).map(\n            (year: number) => ({\n                label: year.toString(),\n                value: year.toString()\n            })\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                this.datePickerNavigationHelper.focusNextWeekDay();\n                break;\n            case 'Up':\n            case 'ArrowUp':\n                this.datePickerNavigationHelper.focusPreviousWeekDay();\n                break;\n            case 'Space':\n            case 'Spacebar':\n            case 'Enter':\n                document.activeElement.dispatchEvent(new Event('click'));\n                break;\n            case 'Right':\n            case 'ArrowRight':\n                this.datePickerNavigationHelper.focusNextDay();\n                break;\n            case 'Left':\n            case 'ArrowLeft':\n                this.datePickerNavigationHelper.focusPreviousDay();\n                break;\n            default:\n                return true;\n        }\n\n        keyEvent.preventDefault();\n        keyEvent.stopPropagation();\n\n        return false;\n    }\n}\n","<div\n    [id]=\"buildId('datepicker_wrapper')\"\n    class=\"datepicker_wrapper\"\n    *ngIf=\"isDatepickerVisible\"\n    [cdkTrapFocus]=\"!!datepickerTriggerHtmlElement\"\n    tabindex=\"-1\"\n    role=\"application\"\n    [attr.aria-label]=\"\n        'foehn-date-picker.container.aria-label' | fromDictionary\n    \"\n>\n    <button\n        *ngIf=\"closeable\"\n        (click)=\"isDatepickerVisible = false\"\n        type=\"button\"\n        class=\"btn close\"\n        [attr.aria-label]=\"\n            'foehn-date-picker.close-button.aria-label' | fromDictionary\n        \"\n        [id]=\"buildId('closeButton')\"\n    >\n        <span aria-hidden=\"true\">&times;</span>\n    </button>\n    <div\n        [id]=\"buildId('datepicker_header')\"\n        class=\"d-flex justify-content-between datepicker_header\"\n    >\n        <ng-container *ngIf=\"currentMonthYear | async as monthYear\">\n            <button\n                [id]=\"buildId('previous-month')\"\n                class=\"btn btn-link datepicker-nav-month-btn\"\n                (click)=\"previousMonth()\"\n                [attr.disabled]=\"isPreviousMonthDisabled(monthYear)\"\n            >\n                <foehn-icon-chevron-left\n                    [title]=\"\n                        'foehn-date-picker.previous-month-button.title'\n                            | fromDictionary\n                    \"\n                ></foehn-icon-chevron-left>\n            </button>\n            <span\n                [id]=\"buildId('month-year-label')\"\n                aria-live=\"polite\"\n                class=\"sr-only\"\n            >\n                {{\n                    'foehn-date-picker.screen-reader.actual-month-displayed'\n                        | fromDictionary\n                }}\n                {{ getMonthAsReadable(monthYear.month) }} {{ monthYear.year }}\n            </span>\n            <foehn-select\n                [id]=\"buildId('month-input')\"\n                class=\"align-self-center month-input\"\n                [label]=\"\n                    'foehn-date-picker.screen-reader.month-input.label'\n                        | fromDictionary\n                \"\n                [isLabelSrOnly]=\"true\"\n                [elements]=\"monthListItem\"\n                [model]=\"monthYear.month\"\n                [required]=\"true\"\n                (userInput)=\"userInputMonth($event)\"\n            ></foehn-select>\n            <foehn-select\n                [id]=\"buildId('year-input')\"\n                class=\"align-self-center\"\n                [label]=\"\n                    'foehn-date-picker.screen-reader.year-input.label'\n                        | fromDictionary\n                \"\n                [isLabelSrOnly]=\"true\"\n                [elements]=\"yearListItem\"\n                [model]=\"monthYear.year\"\n                [required]=\"true\"\n                (userInput)=\"userInputYear($event)\"\n            ></foehn-select>\n            <button\n                [id]=\"buildId('next-month')\"\n                class=\"btn btn-link datepicker-nav-month-btn\"\n                (click)=\"nextMonth()\"\n                [attr.disabled]=\"isNextMonthDisabled(monthYear)\"\n            >\n                <foehn-icon-chevron-right\n                    [title]=\"\n                        'foehn-date-picker.next-month-button.title'\n                            | fromDictionary\n                    \"\n                ></foehn-icon-chevron-right>\n            </button>\n        </ng-container>\n    </div>\n    <table\n        [id]=\"buildId('datepicker_table')\"\n        role=\"grid\"\n        (focusin)=\"onDaysFocusin()\"\n        (focusout)=\"onDaysFocusout()\"\n    >\n        <thead role=\"presentation\" aria-hidden=\"true\">\n            <tr role=\"row\">\n                <th\n                    scope=\"col\"\n                    role=\"columnheader\"\n                    *ngFor=\"let weekday of weekDays\"\n                >\n                    <foehn-abbr\n                        [text]=\"weekday.substr(0, 2)\"\n                        [title]=\"weekday\"\n                    ></foehn-abbr>\n                </th>\n            </tr>\n        </thead>\n        <tbody role=\"presentation\">\n            <tr role=\"row\" *ngFor=\"let week of weeks; let indexRow = index\">\n                <td\n                    role=\"gridcell\"\n                    *ngFor=\"let dayOfWeek of week; let indexColumn = index\"\n                >\n                    <button\n                        class=\"btn w-100\"\n                        #dayButtonElemRef\n                        [hidden]=\"!dayOfWeek.isCurrentMonth\"\n                        [id]=\"buildId('day_' + indexRow + '_' + indexColumn)\"\n                        [tabindex]=\"getDayTabIndex(dayOfWeek)\"\n                        [class.btn-info]=\"!isToday(dayOfWeek.date)\"\n                        [class.btn-secondary]=\"isToday(dayOfWeek.date)\"\n                        [class.btn-danger]=\"isSelected(dayOfWeek.date)\"\n                        [attr.aria-label]=\"\n                            weekDays[indexColumn] +\n                            ' ' +\n                            dayOfWeek.dateAsReadable\n                        \"\n                        [attr.data-is-today]=\"isToday(dayOfWeek.date)\"\n                        [attr.data-is-selected]=\"isSelected(dayOfWeek.date)\"\n                        [attr.data-row-index]=\"indexRow\"\n                        [attr.data-column-index]=\"indexColumn\"\n                        [attr.day-number]=\"dayOfWeek.dayOfMonth\"\n                        [attr.disabled]=\"getDayDisabledAttribute(dayOfWeek)\"\n                        (click)=\"handleUserInput(dayOfWeek.date)\"\n                    >\n                        {{ dayOfWeek.dayOfMonth }}\n                    </button>\n                </td>\n            </tr>\n        </tbody>\n    </table>\n</div>\n"]}
@@ -7489,9 +7489,11 @@ class FoehnDatePickerComponent {
7489
7489
  return date.isSame(this.selectedDate);
7490
7490
  }
7491
7491
  handleUserInput(date) {
7492
- const dateAsArray = this.getDateAsArray(date);
7493
- this.userInput.next(dateAsArray);
7494
- this.updateNgModel(dateAsArray);
7492
+ if (this.isDateInRange(date)) {
7493
+ const dateAsArray = this.getDateAsArray(date);
7494
+ this.userInput.next(dateAsArray);
7495
+ this.updateNgModel(dateAsArray);
7496
+ }
7495
7497
  }
7496
7498
  previousMonth() {
7497
7499
  this.weeks = this.datePickerHelper.getPreviousWeeksOfMonth();