@sbb-esta/lyne-elements 2.3.0 → 2.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/autocomplete/autocomplete-base-element.d.ts +1 -0
- package/autocomplete/autocomplete-base-element.d.ts.map +1 -1
- package/autocomplete/autocomplete.d.ts.map +1 -1
- package/autocomplete-grid/autocomplete-grid/autocomplete-grid.d.ts.map +1 -1
- package/autocomplete-grid/autocomplete-grid.js +0 -1
- package/autocomplete.js +28 -28
- package/button/common/button-common.d.ts.map +1 -1
- package/calendar/calendar.d.ts +55 -11
- package/calendar/calendar.d.ts.map +1 -1
- package/calendar.js +374 -224
- package/card/common/card-action-common.d.ts.map +1 -1
- package/checkbox/checkbox-group/checkbox-group.d.ts.map +1 -1
- package/checkbox/checkbox-group.js +1 -1
- package/checkbox/common/checkbox-common.d.ts.map +1 -1
- package/core/controllers/escapable-overlay-controller.d.ts +11 -0
- package/core/controllers/escapable-overlay-controller.d.ts.map +1 -0
- package/core/controllers.d.ts +1 -0
- package/core/controllers.d.ts.map +1 -1
- package/core/controllers.js +73 -47
- package/core/datetime/date-adapter.d.ts +4 -2
- package/core/datetime/date-adapter.d.ts.map +1 -1
- package/core/datetime/native-date-adapter.d.ts +1 -1
- package/core/datetime/native-date-adapter.d.ts.map +1 -1
- package/core/datetime.js +51 -43
- package/core/decorators/date-converter.d.ts +8 -0
- package/core/decorators/date-converter.d.ts.map +1 -0
- package/core/decorators/date-only-type.d.ts +8 -0
- package/core/decorators/date-only-type.d.ts.map +1 -0
- package/core/decorators/get-override.d.ts.map +1 -1
- package/core/decorators/handle-distinct-change.d.ts.map +1 -1
- package/core/decorators/host-attributes.d.ts.map +1 -1
- package/core/decorators/slot-state.d.ts.map +1 -1
- package/core/decorators.d.ts +2 -0
- package/core/decorators.d.ts.map +1 -1
- package/core/decorators.js +52 -31
- package/core/dom/input-element.d.ts +1 -1
- package/core/dom/input-element.d.ts.map +1 -1
- package/core/dom.js +5 -5
- package/core/eventing/throttle.d.ts.map +1 -1
- package/core/i18n/i18n.d.ts +4 -0
- package/core/i18n/i18n.d.ts.map +1 -1
- package/core/i18n.js +87 -63
- package/core/mixins/disabled-mixin.d.ts.map +1 -1
- package/core/mixins/form-associated-checkbox-mixin.d.ts.map +1 -1
- package/core/mixins/form-associated-input-mixin.d.ts +25 -0
- package/core/mixins/form-associated-input-mixin.d.ts.map +1 -0
- package/core/mixins/form-associated-mixin.d.ts +13 -0
- package/core/mixins/form-associated-mixin.d.ts.map +1 -1
- package/core/mixins/form-associated-radio-button-mixin.d.ts.map +1 -1
- package/core/mixins/hydration-mixin.d.ts.map +1 -1
- package/core/mixins/named-slot-list-mixin.d.ts.map +1 -1
- package/core/mixins/negative-mixin.d.ts.map +1 -1
- package/core/mixins/panel-mixin.d.ts.map +1 -1
- package/core/mixins/required-mixin.d.ts.map +1 -1
- package/core/mixins/update-scheduler-mixin.d.ts.map +1 -1
- package/core/mixins.d.ts +1 -0
- package/core/mixins.d.ts.map +1 -1
- package/core/mixins.js +518 -333
- package/core/styles/core.scss +3 -1
- package/core/testing/mocha-extensions.d.ts.map +1 -1
- package/core/testing/wait-for-render.d.ts.map +1 -1
- package/core.css +2 -2
- package/custom-elements.json +18176 -14267
- package/date-input/date-input.d.ts +67 -0
- package/date-input/date-input.d.ts.map +1 -0
- package/date-input.d.ts +2 -0
- package/date-input.d.ts.map +1 -0
- package/date-input.js +149 -0
- package/datepicker/common/datepicker-button.d.ts.map +1 -1
- package/datepicker/common.js +49 -45
- package/datepicker/datepicker/datepicker.d.ts +16 -6
- package/datepicker/datepicker/datepicker.d.ts.map +1 -1
- package/datepicker/datepicker-toggle/datepicker-toggle.d.ts.map +1 -1
- package/datepicker/datepicker-toggle.js +41 -38
- package/datepicker/datepicker.js +94 -76
- package/development/autocomplete/autocomplete-base-element.d.ts +1 -0
- package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
- package/development/autocomplete/autocomplete.d.ts.map +1 -1
- package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.d.ts.map +1 -1
- package/development/autocomplete-grid/autocomplete-grid.js +1 -2
- package/development/autocomplete.js +9 -4
- package/development/button/common/button-common.d.ts.map +1 -1
- package/development/calendar/calendar.d.ts +55 -11
- package/development/calendar/calendar.d.ts.map +1 -1
- package/development/calendar.js +301 -87
- package/development/card/common/card-action-common.d.ts.map +1 -1
- package/development/checkbox/checkbox-group/checkbox-group.d.ts.map +1 -1
- package/development/checkbox/checkbox-group.js +2 -2
- package/development/checkbox/common/checkbox-common.d.ts.map +1 -1
- package/development/core/controllers/escapable-overlay-controller.d.ts +11 -0
- package/development/core/controllers/escapable-overlay-controller.d.ts.map +1 -0
- package/development/core/controllers.d.ts +1 -0
- package/development/core/controllers.d.ts.map +1 -1
- package/development/core/controllers.js +36 -1
- package/development/core/datetime/date-adapter.d.ts +4 -2
- package/development/core/datetime/date-adapter.d.ts.map +1 -1
- package/development/core/datetime/native-date-adapter.d.ts +1 -1
- package/development/core/datetime/native-date-adapter.d.ts.map +1 -1
- package/development/core/datetime.js +14 -2
- package/development/core/decorators/date-converter.d.ts +8 -0
- package/development/core/decorators/date-converter.d.ts.map +1 -0
- package/development/core/decorators/date-only-type.d.ts +8 -0
- package/development/core/decorators/date-only-type.d.ts.map +1 -0
- package/development/core/decorators/get-override.d.ts.map +1 -1
- package/development/core/decorators/handle-distinct-change.d.ts.map +1 -1
- package/development/core/decorators/host-attributes.d.ts.map +1 -1
- package/development/core/decorators/slot-state.d.ts.map +1 -1
- package/development/core/decorators.d.ts +2 -0
- package/development/core/decorators.d.ts.map +1 -1
- package/development/core/decorators.js +23 -2
- package/development/core/dom/input-element.d.ts +1 -1
- package/development/core/dom/input-element.d.ts.map +1 -1
- package/development/core/dom.js +3 -3
- package/development/core/eventing/throttle.d.ts.map +1 -1
- package/development/core/i18n/i18n.d.ts +4 -0
- package/development/core/i18n/i18n.d.ts.map +1 -1
- package/development/core/i18n.js +29 -1
- package/development/core/mixins/disabled-mixin.d.ts.map +1 -1
- package/development/core/mixins/form-associated-checkbox-mixin.d.ts.map +1 -1
- package/development/core/mixins/form-associated-input-mixin.d.ts +25 -0
- package/development/core/mixins/form-associated-input-mixin.d.ts.map +1 -0
- package/development/core/mixins/form-associated-mixin.d.ts +13 -0
- package/development/core/mixins/form-associated-mixin.d.ts.map +1 -1
- package/development/core/mixins/form-associated-radio-button-mixin.d.ts.map +1 -1
- package/development/core/mixins/hydration-mixin.d.ts.map +1 -1
- package/development/core/mixins/named-slot-list-mixin.d.ts.map +1 -1
- package/development/core/mixins/negative-mixin.d.ts.map +1 -1
- package/development/core/mixins/panel-mixin.d.ts.map +1 -1
- package/development/core/mixins/required-mixin.d.ts.map +1 -1
- package/development/core/mixins/update-scheduler-mixin.d.ts.map +1 -1
- package/development/core/mixins.d.ts +1 -0
- package/development/core/mixins.d.ts.map +1 -1
- package/development/core/mixins.js +379 -88
- package/development/core/testing/mocha-extensions.d.ts.map +1 -1
- package/development/core/testing/wait-for-render.d.ts.map +1 -1
- package/development/date-input/date-input.d.ts +67 -0
- package/development/date-input/date-input.d.ts.map +1 -0
- package/development/date-input.d.ts +2 -0
- package/development/date-input.d.ts.map +1 -0
- package/development/date-input.js +259 -0
- package/development/datepicker/common/datepicker-button.d.ts.map +1 -1
- package/development/datepicker/common.js +11 -2
- package/development/datepicker/datepicker/datepicker.d.ts +16 -6
- package/development/datepicker/datepicker/datepicker.d.ts.map +1 -1
- package/development/datepicker/datepicker-toggle/datepicker-toggle.d.ts.map +1 -1
- package/development/datepicker/datepicker-toggle.js +12 -3
- package/development/datepicker/datepicker.js +65 -39
- package/development/dialog/dialog/dialog.d.ts.map +1 -1
- package/development/dialog/dialog.js +3 -1
- package/development/expansion-panel/expansion-panel/expansion-panel.d.ts.map +1 -1
- package/development/expansion-panel/expansion-panel.js +2 -2
- package/development/file-selector/common/file-selector-common.d.ts.map +1 -1
- package/development/form-field/form-field/form-field.d.ts +1 -1
- package/development/form-field/form-field/form-field.d.ts.map +1 -1
- package/development/form-field/form-field.js +19 -13
- package/development/header/common/header-action-common.d.ts.map +1 -1
- package/development/icon/icon-name-mixin.d.ts.map +1 -1
- package/development/icon/icon-request.d.ts.map +1 -1
- package/development/icon/icon-validate.d.ts.map +1 -1
- package/development/link/common/block-link-common.d.ts.map +1 -1
- package/development/link/common/inline-link-common.d.ts.map +1 -1
- package/development/link/common/link-common.d.ts.map +1 -1
- package/development/menu/common/menu-action-common.d.ts.map +1 -1
- package/development/menu/menu/menu.d.ts +1 -1
- package/development/menu/menu/menu.d.ts.map +1 -1
- package/development/menu/menu.js +5 -15
- package/development/navigation/common/navigation-action-common.d.ts.map +1 -1
- package/development/navigation/navigation/navigation.d.ts +1 -3
- package/development/navigation/navigation/navigation.d.ts.map +1 -1
- package/development/navigation/navigation.js +8 -21
- package/development/overlay/overlay-base-element.d.ts +2 -2
- package/development/overlay/overlay-base-element.d.ts.map +1 -1
- package/development/overlay/overlay.d.ts.map +1 -1
- package/development/overlay.js +6 -13
- package/development/paginator/common/paginator-common.d.ts.map +1 -1
- package/development/popover/popover/popover.d.ts +1 -1
- package/development/popover/popover/popover.d.ts.map +1 -1
- package/development/popover/popover.js +5 -15
- package/development/radio-button/common/radio-button-common.d.ts.map +1 -1
- package/development/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
- package/development/radio-button/radio-button-group.js +2 -2
- package/development/select/select.d.ts +3 -1
- package/development/select/select.d.ts.map +1 -1
- package/development/select.js +12 -8
- package/development/selection-expansion-panel/selection-expansion-panel.d.ts.map +1 -1
- package/development/selection-expansion-panel.js +2 -2
- package/development/stepper/step/step.d.ts +0 -2
- package/development/stepper/step/step.d.ts.map +1 -1
- package/development/stepper/step.js +1 -16
- package/development/stepper/stepper/stepper.d.ts +11 -0
- package/development/stepper/stepper/stepper.d.ts.map +1 -1
- package/development/stepper/stepper.js +30 -3
- package/development/tag/tag/tag.d.ts +11 -0
- package/development/tag/tag/tag.d.ts.map +1 -1
- package/development/tag/tag-group/tag-group.d.ts +1 -1
- package/development/tag/tag-group/tag-group.d.ts.map +1 -1
- package/development/tag/tag-group.js +9 -3
- package/development/tag/tag.js +37 -10
- package/development/teaser-product/common/teaser-product-common.d.ts.map +1 -1
- package/dialog/dialog/dialog.d.ts.map +1 -1
- package/dialog/dialog.js +2 -2
- package/expansion-panel/expansion-panel/expansion-panel.d.ts.map +1 -1
- package/expansion-panel/expansion-panel.js +1 -1
- package/file-selector/common/file-selector-common.d.ts.map +1 -1
- package/form-field/form-field/form-field.d.ts +1 -1
- package/form-field/form-field/form-field.d.ts.map +1 -1
- package/form-field/form-field.js +30 -24
- package/header/common/header-action-common.d.ts.map +1 -1
- package/icon/icon-name-mixin.d.ts.map +1 -1
- package/icon/icon-request.d.ts.map +1 -1
- package/icon/icon-validate.d.ts.map +1 -1
- package/index.d.ts +2 -0
- package/index.js +2 -0
- package/link/common/block-link-common.d.ts.map +1 -1
- package/link/common/inline-link-common.d.ts.map +1 -1
- package/link/common/link-common.d.ts.map +1 -1
- package/menu/common/menu-action-common.d.ts.map +1 -1
- package/menu/menu/menu.d.ts +1 -1
- package/menu/menu/menu.d.ts.map +1 -1
- package/menu/menu.js +25 -34
- package/navigation/common/navigation-action-common.d.ts.map +1 -1
- package/navigation/navigation/navigation.d.ts +1 -3
- package/navigation/navigation/navigation.d.ts.map +1 -1
- package/navigation/navigation.js +45 -54
- package/overlay/overlay-base-element.d.ts +2 -2
- package/overlay/overlay-base-element.d.ts.map +1 -1
- package/overlay/overlay.d.ts.map +1 -1
- package/overlay.js +57 -63
- package/package.json +6 -1
- package/paginator/common/paginator-common.d.ts.map +1 -1
- package/popover/popover/popover.d.ts +1 -1
- package/popover/popover/popover.d.ts.map +1 -1
- package/popover/popover.js +101 -110
- package/radio-button/common/radio-button-common.d.ts.map +1 -1
- package/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
- package/radio-button/radio-button-group.js +1 -1
- package/select/select.d.ts +3 -1
- package/select/select.d.ts.map +1 -1
- package/select.js +39 -37
- package/selection-expansion-panel/selection-expansion-panel.d.ts.map +1 -1
- package/selection-expansion-panel.js +1 -1
- package/standard-theme.css +2 -2
- package/stepper/step/step.d.ts +0 -2
- package/stepper/step/step.d.ts.map +1 -1
- package/stepper/step.js +24 -36
- package/stepper/stepper/stepper.d.ts +11 -0
- package/stepper/stepper/stepper.d.ts.map +1 -1
- package/stepper/stepper.js +59 -41
- package/tag/tag/tag.d.ts +11 -0
- package/tag/tag/tag.d.ts.map +1 -1
- package/tag/tag-group/tag-group.d.ts +1 -1
- package/tag/tag-group/tag-group.d.ts.map +1 -1
- package/tag/tag-group.js +32 -29
- package/tag/tag.js +60 -41
- package/teaser-product/common/teaser-product-common.d.ts.map +1 -1
package/development/calendar.js
CHANGED
|
@@ -12,7 +12,7 @@ import { classMap } from "lit/directives/class-map.js";
|
|
|
12
12
|
import { sbbInputModalityDetector, isArrowKeyOrPageKeysPressed } from "./core/a11y.js";
|
|
13
13
|
import { readConfig } from "./core/config.js";
|
|
14
14
|
import { SbbLanguageController, SbbMediaMatcherController, SbbMediaQueryBreakpointMediumAndAbove } from "./core/controllers.js";
|
|
15
|
-
import { defaultDateAdapter, YEARS_PER_PAGE, DAYS_PER_ROW, MONTHS_PER_ROW, YEARS_PER_ROW } from "./core/datetime.js";
|
|
15
|
+
import { defaultDateAdapter, YEARS_PER_PAGE, DAYS_PER_ROW, MONTHS_PER_ROW, YEARS_PER_ROW, MONTHS_PER_PAGE } from "./core/datetime.js";
|
|
16
16
|
import { forceType } from "./core/decorators.js";
|
|
17
17
|
import { EventEmitter } from "./core/eventing.js";
|
|
18
18
|
import { i18nPreviousMonth, i18nNextMonth, i18nYearMonthSelection, i18nPreviousYear, i18nNextYear, i18nCalendarDateSelection, i18nPreviousYearRange, i18nNextYearRange } from "./core/i18n.js";
|
|
@@ -161,6 +161,15 @@ const style = css`*,
|
|
|
161
161
|
);
|
|
162
162
|
--sbb-calendar-margin: calc(0.5 * var(--sbb-calendar-start-offset));
|
|
163
163
|
}
|
|
164
|
+
:host([orientation=vertical]) .sbb-calendar__table-container {
|
|
165
|
+
min-width: var(--sbb-calendar-min-width);
|
|
166
|
+
--sbb-calendar-start-offset: 0;
|
|
167
|
+
}
|
|
168
|
+
:host([orientation=vertical][data-wide]) .sbb-calendar__table-container {
|
|
169
|
+
--sbb-calendar-min-width: calc(
|
|
170
|
+
13 * var(--sbb-calendar-cell-size) + var(--sbb-calendar-tables-gap)
|
|
171
|
+
);
|
|
172
|
+
}
|
|
164
173
|
|
|
165
174
|
.sbb-calendar__table {
|
|
166
175
|
width: 100%;
|
|
@@ -188,9 +197,14 @@ const style = css`*,
|
|
|
188
197
|
color: var(--sbb-calendar-header-color);
|
|
189
198
|
width: var(--sbb-calendar-cell-size);
|
|
190
199
|
padding: 0;
|
|
191
|
-
padding-block-end: var(--sbb-spacing-fixed-4x);
|
|
192
200
|
text-align: center;
|
|
193
201
|
}
|
|
202
|
+
:host([orientation=horizontal]) .sbb-calendar__table-header {
|
|
203
|
+
padding-block-end: var(--sbb-spacing-fixed-4x);
|
|
204
|
+
}
|
|
205
|
+
:host([orientation=vertical]) .sbb-calendar__table-header {
|
|
206
|
+
padding-inline-end: var(--sbb-spacing-fixed-1x);
|
|
207
|
+
}
|
|
194
208
|
|
|
195
209
|
.sbb-calendar__table-data {
|
|
196
210
|
position: relative;
|
|
@@ -331,7 +345,7 @@ const style = css`*,
|
|
|
331
345
|
}
|
|
332
346
|
}`;
|
|
333
347
|
let SbbCalendarElement = (() => {
|
|
334
|
-
var _wide_accessor_storage, _view_accessor_storage, _dateFilter_accessor_storage, __activeDate_accessor_storage, __selected_accessor_storage, __calendarView_accessor_storage, __initialized_accessor_storage, _a;
|
|
348
|
+
var _wide_accessor_storage, _view_accessor_storage, _dateFilter_accessor_storage, _orientation_accessor_storage, __activeDate_accessor_storage, __selected_accessor_storage, __calendarView_accessor_storage, __initialized_accessor_storage, _a;
|
|
335
349
|
let _classDecorators = [customElement("sbb-calendar")];
|
|
336
350
|
let _classDescriptor;
|
|
337
351
|
let _classExtraInitializers = [];
|
|
@@ -351,6 +365,9 @@ let SbbCalendarElement = (() => {
|
|
|
351
365
|
let _dateFilter_decorators;
|
|
352
366
|
let _dateFilter_initializers = [];
|
|
353
367
|
let _dateFilter_extraInitializers = [];
|
|
368
|
+
let _orientation_decorators;
|
|
369
|
+
let _orientation_initializers = [];
|
|
370
|
+
let _orientation_extraInitializers = [];
|
|
354
371
|
let __activeDate_decorators;
|
|
355
372
|
let __activeDate_initializers = [];
|
|
356
373
|
let __activeDate_extraInitializers = [];
|
|
@@ -371,6 +388,7 @@ let SbbCalendarElement = (() => {
|
|
|
371
388
|
__privateAdd(this, _wide_accessor_storage);
|
|
372
389
|
__privateAdd(this, _view_accessor_storage);
|
|
373
390
|
__privateAdd(this, _dateFilter_accessor_storage);
|
|
391
|
+
__privateAdd(this, _orientation_accessor_storage);
|
|
374
392
|
__privateAdd(this, __activeDate_accessor_storage);
|
|
375
393
|
__privateAdd(this, __selected_accessor_storage);
|
|
376
394
|
__privateAdd(this, __calendarView_accessor_storage);
|
|
@@ -380,12 +398,20 @@ let SbbCalendarElement = (() => {
|
|
|
380
398
|
this._min = __runInitializers(this, _view_extraInitializers);
|
|
381
399
|
this._now = null;
|
|
382
400
|
__privateSet(this, _dateFilter_accessor_storage, __runInitializers(this, _dateFilter_initializers, null));
|
|
383
|
-
this
|
|
401
|
+
__privateSet(this, _orientation_accessor_storage, (__runInitializers(this, _dateFilter_extraInitializers), __runInitializers(this, _orientation_initializers, "horizontal")));
|
|
402
|
+
this._dateAdapter = (__runInitializers(this, _orientation_extraInitializers), ((_a2 = readConfig().datetime) == null ? void 0 : _a2.dateAdapter) ?? defaultDateAdapter);
|
|
384
403
|
this._dateSelected = new EventEmitter(this, SbbCalendarElement2.events.dateSelected);
|
|
385
404
|
__privateSet(this, __activeDate_accessor_storage, __runInitializers(this, __activeDate_initializers, this.now));
|
|
386
405
|
__privateSet(this, __selected_accessor_storage, (__runInitializers(this, __activeDate_extraInitializers), __runInitializers(this, __selected_initializers, void 0)));
|
|
387
406
|
__privateSet(this, __calendarView_accessor_storage, (__runInitializers(this, __selected_extraInitializers), __runInitializers(this, __calendarView_initializers, "day")));
|
|
388
407
|
this._nextCalendarView = (__runInitializers(this, __calendarView_extraInitializers), "day");
|
|
408
|
+
this._keyboardNavigationDayViewParameters = {
|
|
409
|
+
firstDayInView: null,
|
|
410
|
+
lastDayInView: null,
|
|
411
|
+
firstMonthOffset: 0,
|
|
412
|
+
firstMonthLength: 0,
|
|
413
|
+
secondMonthOffset: 0
|
|
414
|
+
};
|
|
389
415
|
this._weeks = [];
|
|
390
416
|
this._monthNames = this._dateAdapter.getMonthNames("long");
|
|
391
417
|
this._resetFocus = false;
|
|
@@ -454,6 +480,13 @@ let SbbCalendarElement = (() => {
|
|
|
454
480
|
set dateFilter(value) {
|
|
455
481
|
__privateSet(this, _dateFilter_accessor_storage, value);
|
|
456
482
|
}
|
|
483
|
+
/** The orientation of days in the calendar. */
|
|
484
|
+
get orientation() {
|
|
485
|
+
return __privateGet(this, _orientation_accessor_storage);
|
|
486
|
+
}
|
|
487
|
+
set orientation(value) {
|
|
488
|
+
__privateSet(this, _orientation_accessor_storage, value);
|
|
489
|
+
}
|
|
457
490
|
/** The currently active date. */
|
|
458
491
|
get _activeDate() {
|
|
459
492
|
return __privateGet(this, __activeDate_accessor_storage);
|
|
@@ -513,7 +546,7 @@ let SbbCalendarElement = (() => {
|
|
|
513
546
|
if (!this._initialized) {
|
|
514
547
|
return;
|
|
515
548
|
}
|
|
516
|
-
if (changedProperties.has("wide")) {
|
|
549
|
+
if (changedProperties.has("wide") || changedProperties.has("orientation")) {
|
|
517
550
|
this.resetPosition();
|
|
518
551
|
}
|
|
519
552
|
if (changedProperties.has("view")) {
|
|
@@ -547,7 +580,7 @@ let SbbCalendarElement = (() => {
|
|
|
547
580
|
this._nextMonthYears = [[]];
|
|
548
581
|
if (this._wide) {
|
|
549
582
|
const nextMonthDate = this._dateAdapter.addCalendarMonths(this._activeDate, 1);
|
|
550
|
-
this._nextMonthWeeks = this._createWeekRows(nextMonthDate);
|
|
583
|
+
this._nextMonthWeeks = this._createWeekRows(nextMonthDate, true);
|
|
551
584
|
this._nextMonthYears = this._createYearRows(YEARS_PER_PAGE);
|
|
552
585
|
}
|
|
553
586
|
this._initialized = true;
|
|
@@ -571,12 +604,32 @@ let SbbCalendarElement = (() => {
|
|
|
571
604
|
const firstDayOfWeek = this._dateAdapter.getFirstDayOfWeek();
|
|
572
605
|
this._weekdays = weekdays.slice(firstDayOfWeek).concat(weekdays.slice(0, firstDayOfWeek));
|
|
573
606
|
}
|
|
574
|
-
/** Creates the rows for each week. */
|
|
575
|
-
_createWeekRows(value) {
|
|
576
|
-
const daysInMonth = this._dateAdapter.getNumDaysInMonth(value);
|
|
607
|
+
/** Creates the rows for each week and sets the parameters used in keyboard navigation. */
|
|
608
|
+
_createWeekRows(value, isSecondMonthInView = false) {
|
|
577
609
|
const dateNames = this._dateAdapter.getDateNames();
|
|
578
|
-
const
|
|
610
|
+
const daysInMonth = this._dateAdapter.getNumDaysInMonth(value);
|
|
579
611
|
const weekOffset = this._dateAdapter.getFirstWeekOffset(value);
|
|
612
|
+
if (!isSecondMonthInView) {
|
|
613
|
+
this._keyboardNavigationDayViewParameters.firstMonthLength = daysInMonth;
|
|
614
|
+
this._keyboardNavigationDayViewParameters.firstMonthOffset = weekOffset;
|
|
615
|
+
this._keyboardNavigationDayViewParameters.firstDayInView = this._dateAdapter.toIso8601(this._dateAdapter.createDate(this._dateAdapter.getYear(value), this._dateAdapter.getMonth(value), 1));
|
|
616
|
+
this._keyboardNavigationDayViewParameters.lastDayInView = this._dateAdapter.toIso8601(this._dateAdapter.createDate(this._dateAdapter.getYear(value), this._dateAdapter.getMonth(value), daysInMonth));
|
|
617
|
+
} else {
|
|
618
|
+
this._keyboardNavigationDayViewParameters.secondMonthOffset = weekOffset;
|
|
619
|
+
this._keyboardNavigationDayViewParameters.lastDayInView = this._dateAdapter.toIso8601(this._dateAdapter.createDate(this._dateAdapter.getYear(value), this._dateAdapter.getMonth(value), daysInMonth));
|
|
620
|
+
}
|
|
621
|
+
return this.orientation === "horizontal" ? this._createWeekRowsHorizontal(value, dateNames, daysInMonth, weekOffset) : this._createWeekRowsVertical(value, dateNames, daysInMonth, weekOffset);
|
|
622
|
+
}
|
|
623
|
+
/**
|
|
624
|
+
* Creates the rows for each week in orientation='horizontal'.
|
|
625
|
+
*
|
|
626
|
+
* Iterates through the days of the months, creates a Day object for each and pushes it into and array.
|
|
627
|
+
* Each seven days (considering the offset at the beginning of the month) restarts from an empty array.
|
|
628
|
+
*
|
|
629
|
+
* The result is a matrix in which every row is a week (or part of it, considering offset).
|
|
630
|
+
*/
|
|
631
|
+
_createWeekRowsHorizontal(value, dateNames, daysInMonth, weekOffset) {
|
|
632
|
+
const weeks = [[]];
|
|
580
633
|
for (let i = 0, cell = weekOffset; i < daysInMonth; i++, cell++) {
|
|
581
634
|
if (cell === DAYS_PER_ROW) {
|
|
582
635
|
weeks.push([]);
|
|
@@ -585,6 +638,38 @@ let SbbCalendarElement = (() => {
|
|
|
585
638
|
const date = this._dateAdapter.createDate(this._dateAdapter.getYear(value), this._dateAdapter.getMonth(value), i + 1);
|
|
586
639
|
weeks[weeks.length - 1].push({
|
|
587
640
|
value: this._dateAdapter.toIso8601(date),
|
|
641
|
+
dateValue: date,
|
|
642
|
+
dayValue: dateNames[i],
|
|
643
|
+
monthValue: String(this._dateAdapter.getMonth(date)),
|
|
644
|
+
yearValue: String(this._dateAdapter.getYear(date))
|
|
645
|
+
});
|
|
646
|
+
}
|
|
647
|
+
return weeks;
|
|
648
|
+
}
|
|
649
|
+
/**
|
|
650
|
+
* Creates the rows for each week in orientation='vertical'.
|
|
651
|
+
*
|
|
652
|
+
* Creates a matrix with seven empty rows.
|
|
653
|
+
* Iterates through the days of the months, creates a Day object for each
|
|
654
|
+
* and pushes it into the correct array considering the offset at the beginning of the month.
|
|
655
|
+
* Each seven days (including offset) restarts from the first.
|
|
656
|
+
*
|
|
657
|
+
* The result is a matrix in which every row is a set of weekdays, so:
|
|
658
|
+
* - row 0: all the Mondays;
|
|
659
|
+
* - row 1: all the Tuesdays;
|
|
660
|
+
* - ...
|
|
661
|
+
* - row 7: all the Sundays.
|
|
662
|
+
*/
|
|
663
|
+
_createWeekRowsVertical(value, dateNames, daysInMonth, weekOffset) {
|
|
664
|
+
const weeks = Array.from({ length: DAYS_PER_ROW }, () => []);
|
|
665
|
+
for (let i = 0, cell = weekOffset; i < daysInMonth; i++, cell++) {
|
|
666
|
+
if (cell === DAYS_PER_ROW) {
|
|
667
|
+
cell = 0;
|
|
668
|
+
}
|
|
669
|
+
const date = this._dateAdapter.createDate(this._dateAdapter.getYear(value), this._dateAdapter.getMonth(value), i + 1);
|
|
670
|
+
weeks[cell].push({
|
|
671
|
+
value: this._dateAdapter.toIso8601(date),
|
|
672
|
+
dateValue: date,
|
|
588
673
|
dayValue: dateNames[i],
|
|
589
674
|
monthValue: String(this._dateAdapter.getMonth(date)),
|
|
590
675
|
yearValue: String(this._dateAdapter.getYear(date))
|
|
@@ -647,6 +732,7 @@ let SbbCalendarElement = (() => {
|
|
|
647
732
|
const isAfterMax = this._dateAdapter.isValid(this.max) && this._dateAdapter.compareDate(this.max, this._dateAdapter.deserialize(date)) < 0;
|
|
648
733
|
return !(isBeforeMin || isAfterMax);
|
|
649
734
|
}
|
|
735
|
+
/** Checks if date is within the min-max range in month view. */
|
|
650
736
|
_isMonthInRange(month, year) {
|
|
651
737
|
if (!this.min && !this.max) {
|
|
652
738
|
return true;
|
|
@@ -655,6 +741,7 @@ let SbbCalendarElement = (() => {
|
|
|
655
741
|
const isAfterMax = this._dateAdapter.isValid(this.max) && (year > this._dateAdapter.getYear(this.max) || year === this._dateAdapter.getYear(this.max) && month > this._dateAdapter.getMonth(this.max));
|
|
656
742
|
return !(isBeforeMin || isAfterMax);
|
|
657
743
|
}
|
|
744
|
+
/** Checks if date is within the min-max range in year view. */
|
|
658
745
|
_isYearInRange(year) {
|
|
659
746
|
if (!this.min && !this.max) {
|
|
660
747
|
return true;
|
|
@@ -751,18 +838,22 @@ let SbbCalendarElement = (() => {
|
|
|
751
838
|
nextMonth = this._dateAdapter.createDate(this._dateAdapter.getYear(nextMonth), this._dateAdapter.getMonth(nextMonth), 1);
|
|
752
839
|
return this._nextDisabled(nextMonth);
|
|
753
840
|
}
|
|
841
|
+
/** Checks if the "previous year" button should be disabled. */
|
|
754
842
|
_previousYearDisabled() {
|
|
755
843
|
const prevYear = this._dateAdapter.createDate(this._dateAdapter.getYear(this._activeDate) - 1, 12, 31);
|
|
756
844
|
return this._prevDisabled(prevYear);
|
|
757
845
|
}
|
|
846
|
+
/** Checks if the "next year" button should be disabled. */
|
|
758
847
|
_nextYearDisabled() {
|
|
759
848
|
const nextYear = this._dateAdapter.createDate(this._dateAdapter.getYear(this._activeDate) + (this._wide ? 2 : 1), 1, 1);
|
|
760
849
|
return this._nextDisabled(nextYear);
|
|
761
850
|
}
|
|
851
|
+
/** Checks if the "previous year" button should be disabled in year view. */
|
|
762
852
|
_previousYearRangeDisabled() {
|
|
763
853
|
const prevYear = this._dateAdapter.createDate(this._years[0][0] - 1, 12, 31);
|
|
764
854
|
return this._prevDisabled(prevYear);
|
|
765
855
|
}
|
|
856
|
+
/** Checks if the "next year" button should be disabled in year view. */
|
|
766
857
|
_nextYearRangeDisabled() {
|
|
767
858
|
const years = this._wide ? this._nextMonthYears : this._years;
|
|
768
859
|
const lastYearRange = years[years.length - 1];
|
|
@@ -782,21 +873,43 @@ let SbbCalendarElement = (() => {
|
|
|
782
873
|
firstFocusable.tabIndex = 0;
|
|
783
874
|
}
|
|
784
875
|
}
|
|
876
|
+
/** Get the element in the calendar to assign focus. */
|
|
785
877
|
_getFirstFocusable() {
|
|
786
878
|
const active = this._selected ? this._dateAdapter.deserialize(this._selected) : this.now;
|
|
787
|
-
let firstFocusable = this.shadowRoot.querySelector(".sbb-calendar__selected") ?? this.shadowRoot.querySelector(`[
|
|
879
|
+
let firstFocusable = this.shadowRoot.querySelector(".sbb-calendar__selected") ?? this.shadowRoot.querySelector(`[value="${this._dateAdapter.toIso8601(active)}"]`) ?? this.shadowRoot.querySelector(`[data-month="${this._dateAdapter.getMonth(active)}"]`) ?? this.shadowRoot.querySelector(`[data-year="${this._dateAdapter.getYear(active)}"]`);
|
|
788
880
|
if (!firstFocusable || (firstFocusable == null ? void 0 : firstFocusable.disabled)) {
|
|
789
|
-
firstFocusable = this.shadowRoot.querySelector(".sbb-calendar__cell:not([disabled])");
|
|
881
|
+
firstFocusable = this._calendarView === "day" ? this._getFirstFocusableDay() : this.shadowRoot.querySelector(".sbb-calendar__cell:not([disabled])");
|
|
790
882
|
}
|
|
791
883
|
return firstFocusable || null;
|
|
792
884
|
}
|
|
885
|
+
/**
|
|
886
|
+
* In `day` view in `vertical` orientation,
|
|
887
|
+
* if the first of the month is not a Monday, it is not the first rendered element in the table,
|
|
888
|
+
* so `this.shadowRoot!.querySelector('.sbb-calendar__cell:not([disabled])')` will return a wrong value.
|
|
889
|
+
*
|
|
890
|
+
* To solve this, the element with the lowest `value` is taken (ISO String are ordered).
|
|
891
|
+
*/
|
|
892
|
+
_getFirstFocusableDay() {
|
|
893
|
+
const daysInView = Array.from(this.shadowRoot.querySelectorAll(".sbb-calendar__cell:not([disabled])"));
|
|
894
|
+
if (!daysInView || daysInView.length === 0) {
|
|
895
|
+
return null;
|
|
896
|
+
} else {
|
|
897
|
+
const firstElement = daysInView.map((e) => e.value).sort()[0];
|
|
898
|
+
return this.shadowRoot.querySelector(`.sbb-calendar__cell[value="${firstElement}"]`);
|
|
899
|
+
}
|
|
900
|
+
}
|
|
793
901
|
_handleKeyboardEvent(event, day) {
|
|
794
902
|
if (isArrowKeyOrPageKeysPressed(event)) {
|
|
795
903
|
event.preventDefault();
|
|
796
904
|
}
|
|
797
905
|
const cells = this._cells;
|
|
798
906
|
const index = cells.findIndex((e) => e === event.target);
|
|
799
|
-
|
|
907
|
+
let nextEl;
|
|
908
|
+
if (day) {
|
|
909
|
+
nextEl = this._navigateByKeyboardDayView(event, index, cells, day);
|
|
910
|
+
} else {
|
|
911
|
+
nextEl = this._navigateByKeyboard(event, index, cells);
|
|
912
|
+
}
|
|
800
913
|
const activeEl = this.shadowRoot.activeElement;
|
|
801
914
|
if (nextEl !== activeEl) {
|
|
802
915
|
nextEl.tabIndex = 0;
|
|
@@ -804,14 +917,113 @@ let SbbCalendarElement = (() => {
|
|
|
804
917
|
activeEl.tabIndex = -1;
|
|
805
918
|
}
|
|
806
919
|
}
|
|
920
|
+
_navigateByKeyboardDayView(evt, index, cells, day) {
|
|
921
|
+
const arrowsOffset = this.orientation === "horizontal" ? { leftRight: 1, upDown: DAYS_PER_ROW } : { leftRight: DAYS_PER_ROW, upDown: 1 };
|
|
922
|
+
const offsetForVertical = index < this._keyboardNavigationDayViewParameters.firstMonthLength ? this._keyboardNavigationDayViewParameters.firstMonthOffset : this._keyboardNavigationDayViewParameters.secondMonthOffset;
|
|
923
|
+
switch (evt.key) {
|
|
924
|
+
case "ArrowUp":
|
|
925
|
+
return this._findDayArrows(cells, index, day.dateValue, -arrowsOffset.upDown);
|
|
926
|
+
case "ArrowDown":
|
|
927
|
+
return this._findDayArrows(cells, index, day.dateValue, arrowsOffset.upDown);
|
|
928
|
+
case "ArrowLeft":
|
|
929
|
+
return this._findDayArrows(cells, index, day.dateValue, -arrowsOffset.leftRight);
|
|
930
|
+
case "ArrowRight":
|
|
931
|
+
return this._findDayArrows(cells, index, day.dateValue, arrowsOffset.leftRight);
|
|
932
|
+
case "PageUp": {
|
|
933
|
+
if (this.orientation === "horizontal") {
|
|
934
|
+
const firstOfWeek = +day.dayValue % DAYS_PER_ROW || DAYS_PER_ROW;
|
|
935
|
+
const delta = firstOfWeek - +day.dayValue;
|
|
936
|
+
return this._findDayPageUpDown(cells, index, day, delta, arrowsOffset.upDown);
|
|
937
|
+
} else {
|
|
938
|
+
const weekNumber = Math.ceil((+day.dayValue + offsetForVertical) / DAYS_PER_ROW);
|
|
939
|
+
const firstOfWeek = (weekNumber - 1) * DAYS_PER_ROW - offsetForVertical + 1;
|
|
940
|
+
const delta = firstOfWeek - +day.dayValue;
|
|
941
|
+
return this._findDayPageUpDown(cells, index, day, delta, arrowsOffset.upDown);
|
|
942
|
+
}
|
|
943
|
+
}
|
|
944
|
+
case "PageDown": {
|
|
945
|
+
if (this.orientation === "horizontal") {
|
|
946
|
+
const monthInBounds = +day.monthValue + 1 > 12 ? 1 : +day.monthValue + 1;
|
|
947
|
+
const yearInBounds = +day.monthValue + 1 > 12 ? +day.yearValue + 1 : +day.yearValue;
|
|
948
|
+
const firstNextMonth = this._dateAdapter.createDate(yearInBounds, monthInBounds, 1);
|
|
949
|
+
const lastOfMonth = this._dateAdapter.getDate(this._dateAdapter.addCalendarDays(firstNextMonth, -1));
|
|
950
|
+
const delta = Math.trunc((lastOfMonth - +day.dayValue) / DAYS_PER_ROW) * DAYS_PER_ROW;
|
|
951
|
+
return this._findDayPageUpDown(cells, index, day, delta, -arrowsOffset.upDown);
|
|
952
|
+
} else {
|
|
953
|
+
const weekNumber = Math.ceil((+day.dayValue + offsetForVertical) / DAYS_PER_ROW);
|
|
954
|
+
const lastOfWeek = weekNumber * DAYS_PER_ROW - offsetForVertical;
|
|
955
|
+
const delta = lastOfWeek - +day.dayValue;
|
|
956
|
+
return this._findDayPageUpDown(cells, index, day, delta, -arrowsOffset.upDown);
|
|
957
|
+
}
|
|
958
|
+
}
|
|
959
|
+
case "Home": {
|
|
960
|
+
return this._findDayFirst(cells, index, day, 1);
|
|
961
|
+
}
|
|
962
|
+
case "End": {
|
|
963
|
+
const monthInBounds = +day.monthValue + 1 > 12 ? 1 : +day.monthValue + 1;
|
|
964
|
+
const yearInBounds = +day.monthValue + 1 > 12 ? +day.yearValue + 1 : +day.yearValue;
|
|
965
|
+
const firstNextMonth = this._dateAdapter.createDate(yearInBounds, monthInBounds, 1);
|
|
966
|
+
return this._findDayLast(cells, index, firstNextMonth);
|
|
967
|
+
}
|
|
968
|
+
default:
|
|
969
|
+
return cells[index];
|
|
970
|
+
}
|
|
971
|
+
}
|
|
972
|
+
_isDayOutOfView(date) {
|
|
973
|
+
return date < this._keyboardNavigationDayViewParameters.firstDayInView || date > this._keyboardNavigationDayViewParameters.lastDayInView;
|
|
974
|
+
}
|
|
975
|
+
_findDayArrows(cells, index, date, delta) {
|
|
976
|
+
const newDateValue = this._dateAdapter.toIso8601(this._dateAdapter.addCalendarDays(date, delta));
|
|
977
|
+
if (this._isDayOutOfView(newDateValue)) {
|
|
978
|
+
return cells[index];
|
|
979
|
+
}
|
|
980
|
+
const nextCell = cells.find((e) => e.value === newDateValue);
|
|
981
|
+
if (!nextCell || nextCell.disabled) {
|
|
982
|
+
return this._findDayArrows(cells, index, this._dateAdapter.deserialize(newDateValue), delta);
|
|
983
|
+
}
|
|
984
|
+
return nextCell;
|
|
985
|
+
}
|
|
986
|
+
_findDayPageUpDown(cells, index, day, delta, deltaIfDisabled) {
|
|
987
|
+
const newDateValue = this._dateAdapter.toIso8601(this._dateAdapter.addCalendarDays(day.dateValue, delta));
|
|
988
|
+
if (this._isDayOutOfView(newDateValue)) {
|
|
989
|
+
return cells[index];
|
|
990
|
+
}
|
|
991
|
+
const nextCell = cells.find((e) => e.value === newDateValue);
|
|
992
|
+
if (!nextCell || nextCell.disabled) {
|
|
993
|
+
return this._findDayPageUpDown(cells, index, day, delta + deltaIfDisabled, deltaIfDisabled);
|
|
994
|
+
}
|
|
995
|
+
return nextCell;
|
|
996
|
+
}
|
|
997
|
+
_findDayFirst(cells, index, day, date) {
|
|
998
|
+
const newDateValue = this._dateAdapter.toIso8601(this._dateAdapter.createDate(+day.yearValue, +day.monthValue, date));
|
|
999
|
+
if (this._isDayOutOfView(newDateValue)) {
|
|
1000
|
+
return cells[index];
|
|
1001
|
+
}
|
|
1002
|
+
const nextCell = cells.find((e) => e.value === newDateValue);
|
|
1003
|
+
if (!nextCell || nextCell.disabled) {
|
|
1004
|
+
return this._findDayFirst(cells, index, day, date + 1);
|
|
1005
|
+
}
|
|
1006
|
+
return nextCell;
|
|
1007
|
+
}
|
|
1008
|
+
_findDayLast(cells, index, firstNextMonth) {
|
|
1009
|
+
const newDateValue = this._dateAdapter.toIso8601(this._dateAdapter.addCalendarDays(firstNextMonth, -1));
|
|
1010
|
+
if (this._isDayOutOfView(newDateValue)) {
|
|
1011
|
+
return cells[index];
|
|
1012
|
+
}
|
|
1013
|
+
const nextCell = cells.find((e) => e.value === newDateValue);
|
|
1014
|
+
if (!nextCell || nextCell.disabled) {
|
|
1015
|
+
return this._findDayLast(cells, index, this._dateAdapter.deserialize(newDateValue));
|
|
1016
|
+
}
|
|
1017
|
+
return nextCell;
|
|
1018
|
+
}
|
|
807
1019
|
/**
|
|
808
1020
|
* Gets the index of the element to move to, based on a list of elements (which can be potentially disabled),
|
|
809
1021
|
* the keyboard input and the position of the current element in the list.
|
|
810
1022
|
* In the day view, the `day?: Day` parameter is mandatory for calculation,
|
|
811
1023
|
* while in month and year view it's not due to the fixed amount of rendered cells.
|
|
812
1024
|
*/
|
|
813
|
-
_navigateByKeyboard(evt, index, cells
|
|
814
|
-
const { elementIndexForWideMode, offsetForWideMode, lastElementIndexForWideMode, verticalOffset } = this._calculateParametersForKeyboardNavigation(
|
|
1025
|
+
_navigateByKeyboard(evt, index, cells) {
|
|
1026
|
+
const { elementIndexForWideMode, offsetForWideMode, lastElementIndexForWideMode, verticalOffset } = this._calculateParametersForKeyboardNavigation(index, this._calendarView === "year");
|
|
815
1027
|
switch (evt.key) {
|
|
816
1028
|
case "ArrowUp":
|
|
817
1029
|
return this._findNext(cells, index, -verticalOffset);
|
|
@@ -834,44 +1046,20 @@ let SbbCalendarElement = (() => {
|
|
|
834
1046
|
}
|
|
835
1047
|
}
|
|
836
1048
|
/**
|
|
837
|
-
* Calculates the
|
|
838
|
-
* Since three views are now available, the function creates and returns the correct parameters for each of them
|
|
839
|
-
* by considering the number of cells per each row and the correction for the wide mode.
|
|
840
|
-
* @param cells The array of rendered table cells; they are buttons that can represent days, months or years.
|
|
1049
|
+
* Calculates the parameters needed in keyboard navigation in year and month view.
|
|
841
1050
|
* @param index The starting element's index in the cell array.
|
|
842
|
-
* @param
|
|
1051
|
+
* @param isYearView Whether the displayed `view` is the year one.
|
|
843
1052
|
*/
|
|
844
|
-
_calculateParametersForKeyboardNavigation(
|
|
845
|
-
|
|
846
|
-
|
|
847
|
-
|
|
848
|
-
|
|
849
|
-
|
|
850
|
-
|
|
851
|
-
|
|
852
|
-
|
|
853
|
-
|
|
854
|
-
}
|
|
855
|
-
// Month view is not dependent from `wide` value, so some parameters are fixed.
|
|
856
|
-
case "month": {
|
|
857
|
-
return {
|
|
858
|
-
verticalOffset: MONTHS_PER_ROW,
|
|
859
|
-
elementIndexForWideMode: index,
|
|
860
|
-
offsetForWideMode: 0,
|
|
861
|
-
lastElementIndexForWideMode: 12
|
|
862
|
-
};
|
|
863
|
-
}
|
|
864
|
-
case "year": {
|
|
865
|
-
const offset = Math.trunc(index / YEARS_PER_PAGE) * YEARS_PER_PAGE;
|
|
866
|
-
const indexInView = offset === 0 ? index : index - YEARS_PER_PAGE;
|
|
867
|
-
return {
|
|
868
|
-
verticalOffset: YEARS_PER_ROW,
|
|
869
|
-
elementIndexForWideMode: indexInView,
|
|
870
|
-
offsetForWideMode: index - indexInView,
|
|
871
|
-
lastElementIndexForWideMode: offset === 0 ? YEARS_PER_PAGE : YEARS_PER_PAGE * 2
|
|
872
|
-
};
|
|
873
|
-
}
|
|
874
|
-
}
|
|
1053
|
+
_calculateParametersForKeyboardNavigation(index, isYearView) {
|
|
1054
|
+
const elementsPerPage = isYearView ? YEARS_PER_PAGE : MONTHS_PER_PAGE;
|
|
1055
|
+
const offset = Math.trunc(index / elementsPerPage) * elementsPerPage;
|
|
1056
|
+
const indexInView = offset === 0 ? index : index - elementsPerPage;
|
|
1057
|
+
return {
|
|
1058
|
+
verticalOffset: isYearView ? YEARS_PER_ROW : MONTHS_PER_ROW,
|
|
1059
|
+
elementIndexForWideMode: indexInView,
|
|
1060
|
+
offsetForWideMode: index - indexInView,
|
|
1061
|
+
lastElementIndexForWideMode: offset === 0 ? elementsPerPage : elementsPerPage * 2
|
|
1062
|
+
};
|
|
875
1063
|
}
|
|
876
1064
|
/**
|
|
877
1065
|
* Gets the next element of the provided array starting from `index` by adding `delta`.
|
|
@@ -929,8 +1117,13 @@ let SbbCalendarElement = (() => {
|
|
|
929
1117
|
${this._getArrow("right", () => this._goToDifferentMonth(1), i18nNextMonth[this._language.current], this._nextMonthDisabled())}
|
|
930
1118
|
</div>
|
|
931
1119
|
<div class="sbb-calendar__table-container sbb-calendar__table-day-view">
|
|
932
|
-
${this.
|
|
933
|
-
|
|
1120
|
+
${this.orientation === "horizontal" ? html`
|
|
1121
|
+
${this._createDayTable(this._weeks)}
|
|
1122
|
+
${this._wide ? this._createDayTable(this._nextMonthWeeks) : nothing}
|
|
1123
|
+
` : html`
|
|
1124
|
+
${this._createDayTableVertical(this._weeks)}
|
|
1125
|
+
${this._wide ? this._createDayTableVertical(this._nextMonthWeeks, nextMonthActiveDate) : nothing}
|
|
1126
|
+
`}
|
|
934
1127
|
</div>
|
|
935
1128
|
`;
|
|
936
1129
|
}
|
|
@@ -965,6 +1158,7 @@ let SbbCalendarElement = (() => {
|
|
|
965
1158
|
}
|
|
966
1159
|
/** Creates the calendar table for the daily view. */
|
|
967
1160
|
_createDayTable(weeks) {
|
|
1161
|
+
const today = this._dateAdapter.toIso8601(this.now);
|
|
968
1162
|
return html`
|
|
969
1163
|
<table
|
|
970
1164
|
class="sbb-calendar__table"
|
|
@@ -973,44 +1167,60 @@ let SbbCalendarElement = (() => {
|
|
|
973
1167
|
>
|
|
974
1168
|
<thead class="sbb-calendar__table-header">
|
|
975
1169
|
<tr class="sbb-calendar__table-header-row">
|
|
976
|
-
${this.
|
|
1170
|
+
${this._weekdays.map((day) => html`
|
|
1171
|
+
<th class="sbb-calendar__table-header">
|
|
1172
|
+
<sbb-screen-reader-only>${day.long}</sbb-screen-reader-only>
|
|
1173
|
+
<span aria-hidden="true">${day.narrow}</span>
|
|
1174
|
+
</th>
|
|
1175
|
+
`)}
|
|
977
1176
|
</tr>
|
|
978
1177
|
</thead>
|
|
979
1178
|
<tbody class="sbb-calendar__table-body">
|
|
980
|
-
${
|
|
981
|
-
</tbody>
|
|
982
|
-
</table>
|
|
983
|
-
`;
|
|
984
|
-
}
|
|
985
|
-
/** Creates the table header with the month header cells. */
|
|
986
|
-
_createDayTableHeader() {
|
|
987
|
-
return this._weekdays.map((day) => html`
|
|
988
|
-
<th class="sbb-calendar__table-header">
|
|
989
|
-
<sbb-screen-reader-only>${day.long}</sbb-screen-reader-only>
|
|
990
|
-
<span aria-hidden="true">${day.narrow}</span>
|
|
991
|
-
</th>
|
|
992
|
-
`);
|
|
993
|
-
}
|
|
994
|
-
/** Creates the table body with the day cells. For the first row, it also considers the possible day's offset. */
|
|
995
|
-
_createDayTableBody(weeks) {
|
|
996
|
-
const today = this._dateAdapter.toIso8601(this.now);
|
|
997
|
-
return weeks.map((week, rowIndex) => {
|
|
1179
|
+
${weeks.map((week, rowIndex) => {
|
|
998
1180
|
const firstRowOffset = DAYS_PER_ROW - week.length;
|
|
999
1181
|
if (rowIndex === 0 && firstRowOffset) {
|
|
1000
1182
|
return html`
|
|
1001
|
-
|
|
1002
|
-
|
|
1003
|
-
|
|
1004
|
-
|
|
1005
|
-
|
|
1006
|
-
${this._createDayCells(week, today)}
|
|
1007
|
-
</tr>
|
|
1008
|
-
`;
|
|
1183
|
+
<tr>
|
|
1184
|
+
${[...Array(firstRowOffset).keys()].map(() => html`<td class="sbb-calendar__table-data"></td>`)}
|
|
1185
|
+
${this._createDayCells(week, today)}
|
|
1186
|
+
</tr>
|
|
1187
|
+
`;
|
|
1009
1188
|
}
|
|
1010
1189
|
return html`<tr>
|
|
1011
|
-
|
|
1012
|
-
|
|
1013
|
-
})
|
|
1190
|
+
${this._createDayCells(week, today)}
|
|
1191
|
+
</tr>`;
|
|
1192
|
+
})}
|
|
1193
|
+
</tbody>
|
|
1194
|
+
</table>
|
|
1195
|
+
`;
|
|
1196
|
+
}
|
|
1197
|
+
/* Creates the table in orientation='vertical'. */
|
|
1198
|
+
_createDayTableVertical(weeks, nextMonthActiveDate) {
|
|
1199
|
+
const today = this._dateAdapter.toIso8601(this.now);
|
|
1200
|
+
const weekOffset = this._dateAdapter.getFirstWeekOffset(nextMonthActiveDate ?? this._activeDate);
|
|
1201
|
+
return html`
|
|
1202
|
+
<table
|
|
1203
|
+
class="sbb-calendar__table"
|
|
1204
|
+
@focusout=${(event) => this._handleTableBlur(event.relatedTarget)}
|
|
1205
|
+
@animationend=${(e) => this._tableAnimationEnd(e)}
|
|
1206
|
+
>
|
|
1207
|
+
<tbody class="sbb-calendar__table-body">
|
|
1208
|
+
${weeks.map((week, rowIndex) => {
|
|
1209
|
+
const weekday = this._weekdays[rowIndex];
|
|
1210
|
+
return html`
|
|
1211
|
+
<tr>
|
|
1212
|
+
${!nextMonthActiveDate ? html` <td class="sbb-calendar__table-header">
|
|
1213
|
+
<sbb-screen-reader-only>${weekday.long}</sbb-screen-reader-only>
|
|
1214
|
+
<span aria-hidden="true">${weekday.narrow}</span>
|
|
1215
|
+
</td>` : nothing}
|
|
1216
|
+
${rowIndex < weekOffset ? html`<td class="sbb-calendar__table-data"></td>` : nothing}
|
|
1217
|
+
${this._createDayCells(week, today)}
|
|
1218
|
+
</tr>
|
|
1219
|
+
`;
|
|
1220
|
+
})}
|
|
1221
|
+
</tbody>
|
|
1222
|
+
</table>
|
|
1223
|
+
`;
|
|
1014
1224
|
}
|
|
1015
1225
|
/** Creates the cells for the daily view. */
|
|
1016
1226
|
_createDayCells(week, today) {
|
|
@@ -1018,7 +1228,6 @@ let SbbCalendarElement = (() => {
|
|
|
1018
1228
|
const isOutOfRange = !this._isDayInRange(day.value);
|
|
1019
1229
|
const isFilteredOut = !this._dateFilter(this._dateAdapter.deserialize(day.value));
|
|
1020
1230
|
const selected = !!this._selected && day.value === this._selected;
|
|
1021
|
-
const dayValue = `${day.dayValue} ${day.monthValue} ${day.yearValue}`;
|
|
1022
1231
|
const isToday = day.value === today;
|
|
1023
1232
|
return html`
|
|
1024
1233
|
<td
|
|
@@ -1037,11 +1246,12 @@ let SbbCalendarElement = (() => {
|
|
|
1037
1246
|
})}
|
|
1038
1247
|
@click=${() => this._selectDate(day.value)}
|
|
1039
1248
|
?disabled=${isOutOfRange || isFilteredOut}
|
|
1249
|
+
value=${day.value}
|
|
1250
|
+
type="button"
|
|
1040
1251
|
aria-label=${this._dateAdapter.getAccessibilityFormatDate(day.value)}
|
|
1041
1252
|
aria-pressed=${selected}
|
|
1042
1253
|
aria-disabled=${isOutOfRange || isFilteredOut}
|
|
1043
1254
|
aria-current=${isToday ? "date" : nothing}
|
|
1044
|
-
data-day=${dayValue || nothing}
|
|
1045
1255
|
tabindex="-1"
|
|
1046
1256
|
@keydown=${(evt) => this._handleKeyboardEvent(evt, day)}
|
|
1047
1257
|
sbb-popover-close
|
|
@@ -1267,7 +1477,7 @@ let SbbCalendarElement = (() => {
|
|
|
1267
1477
|
render() {
|
|
1268
1478
|
return html`<div class="sbb-calendar__wrapper">${this._getView()}</div>`;
|
|
1269
1479
|
}
|
|
1270
|
-
}, _wide_accessor_storage = new WeakMap(), _view_accessor_storage = new WeakMap(), _dateFilter_accessor_storage = new WeakMap(), __activeDate_accessor_storage = new WeakMap(), __selected_accessor_storage = new WeakMap(), __calendarView_accessor_storage = new WeakMap(), __initialized_accessor_storage = new WeakMap(), _classThis = _a, (() => {
|
|
1480
|
+
}, _wide_accessor_storage = new WeakMap(), _view_accessor_storage = new WeakMap(), _dateFilter_accessor_storage = new WeakMap(), _orientation_accessor_storage = new WeakMap(), __activeDate_accessor_storage = new WeakMap(), __selected_accessor_storage = new WeakMap(), __calendarView_accessor_storage = new WeakMap(), __initialized_accessor_storage = new WeakMap(), _classThis = _a, (() => {
|
|
1271
1481
|
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
1272
1482
|
_wide_decorators = [forceType(), property({ type: Boolean })];
|
|
1273
1483
|
_view_decorators = [property()];
|
|
@@ -1276,6 +1486,7 @@ let SbbCalendarElement = (() => {
|
|
|
1276
1486
|
_set_now_decorators = [property()];
|
|
1277
1487
|
_set_selected_decorators = [property()];
|
|
1278
1488
|
_dateFilter_decorators = [property({ attribute: "date-filter" })];
|
|
1489
|
+
_orientation_decorators = [property({ reflect: true })];
|
|
1279
1490
|
__activeDate_decorators = [state()];
|
|
1280
1491
|
__selected_decorators = [state()];
|
|
1281
1492
|
_set__wide_decorators = [state()];
|
|
@@ -1302,6 +1513,9 @@ let SbbCalendarElement = (() => {
|
|
|
1302
1513
|
__esDecorate(_a, null, _dateFilter_decorators, { kind: "accessor", name: "dateFilter", static: false, private: false, access: { has: (obj) => "dateFilter" in obj, get: (obj) => obj.dateFilter, set: (obj, value) => {
|
|
1303
1514
|
obj.dateFilter = value;
|
|
1304
1515
|
} }, metadata: _metadata }, _dateFilter_initializers, _dateFilter_extraInitializers);
|
|
1516
|
+
__esDecorate(_a, null, _orientation_decorators, { kind: "accessor", name: "orientation", static: false, private: false, access: { has: (obj) => "orientation" in obj, get: (obj) => obj.orientation, set: (obj, value) => {
|
|
1517
|
+
obj.orientation = value;
|
|
1518
|
+
} }, metadata: _metadata }, _orientation_initializers, _orientation_extraInitializers);
|
|
1305
1519
|
__esDecorate(_a, null, __activeDate_decorators, { kind: "accessor", name: "_activeDate", static: false, private: false, access: { has: (obj) => "_activeDate" in obj, get: (obj) => obj._activeDate, set: (obj, value) => {
|
|
1306
1520
|
obj._activeDate = value;
|
|
1307
1521
|
} }, metadata: _metadata }, __activeDate_initializers, __activeDate_extraInitializers);
|
|
@@ -1328,4 +1542,4 @@ let SbbCalendarElement = (() => {
|
|
|
1328
1542
|
export {
|
|
1329
1543
|
SbbCalendarElement
|
|
1330
1544
|
};
|
|
1331
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"calendar.js","sources":["../../../src/elements/calendar/calendar.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  LitElement,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\n\nimport { isArrowKeyOrPageKeysPressed, sbbInputModalityDetector } from '../core/a11y.js';\nimport { readConfig } from '../core/config.js';\nimport {\n  SbbLanguageController,\n  SbbMediaMatcherController,\n  SbbMediaQueryBreakpointMediumAndAbove,\n} from '../core/controllers.js';\nimport type { DateAdapter } from '../core/datetime.js';\nimport {\n  DAYS_PER_ROW,\n  defaultDateAdapter,\n  MONTHS_PER_ROW,\n  YEARS_PER_PAGE,\n  YEARS_PER_ROW,\n} from '../core/datetime.js';\nimport { forceType } from '../core/decorators.js';\nimport { EventEmitter } from '../core/eventing.js';\nimport {\n  i18nCalendarDateSelection,\n  i18nNextMonth,\n  i18nNextYear,\n  i18nNextYearRange,\n  i18nPreviousMonth,\n  i18nPreviousYear,\n  i18nPreviousYearRange,\n  i18nYearMonthSelection,\n} from '../core/i18n.js';\nimport type { SbbDateLike } from '../core/interfaces.js';\nimport { SbbHydrationMixin } from '../core/mixins.js';\n\nimport style from './calendar.scss?lit&inline';\n\nimport '../button/secondary-button.js';\nimport '../icon.js';\nimport '../screen-reader-only.js';\n\n/**\n * In keyboard navigation, the cell's index and the element's index in its month / year batch must be distinguished;\n * this is necessary because the navigation in the vertical direction using some keys is restricted to a single month for days,\n * and to a single range of 24 years for years. While the latter is easy to understand, the cell's index is the index\n * of the element in the array of all the rendered cells. In non-wide mode, there's no issue because the element index\n * is basically the cell's index plus 1 (element with index 0 displays the 1st of month, element with index 1 displays the 2nd and so on).\n * In wide mode, the cell's index can go from 0 to 47 for years (two batches of 24 years), and from 0 to a maximum of 61 for days\n * (two consecutive months of 31 days, as July-August or December-January), depending on the lengths of the rendered months;\n * the element index instead goes from 0 to a max value of 24 for years and 31 for days.\n * Moreover, in day view, the index of the first day of the second rendered month and the index of the last rendered day\n * can also vary depending on which months are rendered; for July-August they are equals to 31 and 61, while for February-March they are 28 and 58.\n * So, some additional parameters are needed, beside the cell's index, to correctly calculate the element to navigate to.\n */\ninterface CalendarKeyboardNavigationParameters {\n  /** The element index within its month (or year range). */\n  elementIndexForWideMode: number;\n  /** In wide mode, the index of the first element in the second panel, or, alternatively, the number of elements in the first panel. */\n  offsetForWideMode: number;\n  /** The index of the last element within the element's month (or year range). */\n  lastElementIndexForWideMode: number;\n  /** The number of cells displayed in a single row, depending on the rendered view. */\n  verticalOffset: number;\n}\n\nexport interface Day {\n  value: string;\n  dayValue: string;\n  monthValue: string;\n  yearValue: string;\n}\n\nexport interface Month {\n  value: string;\n  longValue: string;\n  monthValue: number;\n}\n\nexport interface Weekday {\n  long: string;\n  narrow: string;\n}\n\nexport type CalendarView = 'day' | 'month' | 'year';\n\n/**\n * It displays a calendar which allows to choose a date.\n *\n * @event {CustomEvent<T>} dateSelected - Event emitted on date selection.\n */\nexport\n@customElement('sbb-calendar')\nclass SbbCalendarElement<T = Date> extends SbbHydrationMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    dateSelected: 'dateSelected',\n  } as const;\n\n  /** If set to true, two months are displayed */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor wide: boolean = false;\n\n  /** The initial view of the calendar which should be displayed on opening. */\n  @property() public accessor view: CalendarView = 'day';\n\n  /** The minimum valid date. Takes T Object, ISOString, and Unix Timestamp (number of seconds since Jan 1, 1970). */\n  @property()\n  public set min(value: SbbDateLike<T> | null) {\n    this._min = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n  }\n  public get min(): T | null {\n    return this._min ?? null;\n  }\n  private _min?: T | null;\n\n  /** The maximum valid date. Takes T Object, ISOString, and Unix Timestamp (number of seconds since Jan 1, 1970). */\n  @property()\n  public set max(value: SbbDateLike<T> | null) {\n    this._max = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n  }\n  public get max(): T | null {\n    return this._max ?? null;\n  }\n  private _max?: T | null;\n\n  /** A configured date which acts as the current date instead of the real current date. Recommended for testing purposes. */\n  @property()\n  public set now(value: SbbDateLike<T> | null) {\n    this._now = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n  }\n  public get now(): T {\n    return this._now ?? this._dateAdapter.today();\n  }\n  private _now: T | null = null;\n\n  /** The selected date. Takes T Object, ISOString, and Unix Timestamp (number of seconds since Jan 1, 1970). */\n  @property()\n  public set selected(value: SbbDateLike<T> | null) {\n    this._selectedDate = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n    if (\n      !!this._selectedDate &&\n      (!this._isDayInRange(this._dateAdapter.toIso8601(this._selectedDate)) ||\n        this._dateFilter(this._selectedDate))\n    ) {\n      this._selected = this._dateAdapter.toIso8601(this._selectedDate);\n    } else {\n      this._selected = undefined;\n    }\n  }\n  public get selected(): T | null {\n    return this._selectedDate ?? null;\n  }\n  private _selectedDate?: T | null;\n\n  /** A function used to filter out dates. */\n  @property({ attribute: 'date-filter' }) public accessor dateFilter:\n    | ((date: T | null) => boolean)\n    | null = null;\n\n  private _dateAdapter: DateAdapter<T> = readConfig().datetime?.dateAdapter ?? defaultDateAdapter;\n\n  /** Event emitted on date selection. */\n  private _dateSelected: EventEmitter<T> = new EventEmitter(\n    this,\n    SbbCalendarElement.events.dateSelected,\n  );\n\n  /** The currently active date. */\n  @state() private accessor _activeDate: T = this.now;\n\n  /** The selected date as ISOString. */\n  @state() private accessor _selected: string | undefined;\n\n  /** The current wide property considering property value and breakpoints. From zero to small `wide` has always to be false. */\n  @state()\n  private set _wide(wide: boolean) {\n    this.toggleAttribute('data-wide', wide);\n  }\n  private get _wide(): boolean {\n    return this.hasAttribute('data-wide');\n  }\n\n  @state() private accessor _calendarView: CalendarView = 'day';\n\n  private _nextCalendarView: CalendarView = 'day';\n\n  /** A list of days, in two formats (long and single char). */\n  private _weekdays!: Weekday[];\n\n  /** Grid of calendar cells representing the dates of the month. */\n  private _weeks: Day[][] = [];\n\n  /** Grid of calendar cells representing months. */\n  private _months!: Month[][];\n\n  /** Grid of calendar cells representing years. */\n  private _years!: number[][];\n\n  /** Grid of calendar cells representing years for the wide view. */\n  private _nextMonthYears!: number[][];\n\n  /** Grid of calendar cells representing the dates of the next month. */\n  private _nextMonthWeeks!: Day[][];\n\n  /** An array containing all the month names in the current language. */\n  private _monthNames: string[] = this._dateAdapter.getMonthNames('long');\n\n  /** A list of buttons corresponding to days, months or years depending on the view. */\n  private get _cells(): HTMLButtonElement[] {\n    return Array.from(\n      this.shadowRoot!.querySelectorAll('.sbb-calendar__cell') ?? [],\n    ) as HTMLButtonElement[];\n  }\n\n  /** The chosen year in the year selection view. */\n  private _chosenYear?: number;\n\n  /** The chosen month in the year selection view. */\n  private _chosenMonth?: number;\n\n  /** Whether the focus should be reset on focusCell. */\n  private _resetFocus = false;\n\n  @state()\n  private accessor _initialized = false;\n\n  private _language = new SbbLanguageController(this).withHandler(() => {\n    this._monthNames = this._dateAdapter.getMonthNames('long');\n    this._createMonthRows();\n  });\n  private _mediaMatcher = new SbbMediaMatcherController(this, {\n    [SbbMediaQueryBreakpointMediumAndAbove]: () => this._init(),\n  });\n\n  public constructor() {\n    super();\n    this._createMonthRows();\n    this._setWeekdays();\n  }\n\n  private _dateFilter(date: T): boolean {\n    return this.dateFilter?.(date) ?? true;\n  }\n\n  /** Resets the active month according to the new state of the calendar. */\n  public resetPosition(): void {\n    this._resetCalendarView();\n    this._init();\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.resetPosition();\n    this.focus = () => {\n      this._resetFocus = true;\n      this._focusCell();\n    };\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (!this._initialized) {\n      return;\n    }\n\n    if (changedProperties.has('wide')) {\n      this.resetPosition();\n    }\n\n    if (changedProperties.has('view')) {\n      this._setChosenYear();\n      this._chosenMonth = undefined;\n      this._nextCalendarView = this._calendarView = this.view;\n    }\n  }\n\n  protected override updated(changedProperties: PropertyValues<this>): void {\n    super.updated(changedProperties);\n    // The calendar needs to calculate tab-indexes on first render,\n    // and every time a date is selected or the month view changes.\n    this._setTabIndex();\n    // When changing view to year/month, the tabindex is changed, but the focused element is not,\n    // so if the navigation is done via keyboard, there's the need\n    // to call the `_focusCell()` method explicitly to correctly set the focus.\n    if (sbbInputModalityDetector.mostRecentModality === 'keyboard') {\n      this._focusCell();\n    }\n  }\n\n  /** Initializes the component. */\n  private _init(activeDate?: T): void {\n    // Due to its complexity, the calendar is only initialized on client side\n    if (isServer) {\n      return;\n    } else if (this.hydrationRequired) {\n      this.hydrationComplete.then(() => this._init());\n      return;\n    }\n\n    if (activeDate) {\n      this._assignActiveDate(activeDate);\n    }\n    this._wide =\n      (this._mediaMatcher.matches(SbbMediaQueryBreakpointMediumAndAbove) ?? false) && this.wide;\n    this._weeks = this._createWeekRows(this._activeDate);\n    this._years = this._createYearRows();\n    this._nextMonthWeeks = [[]];\n    this._nextMonthYears = [[]];\n    if (this._wide) {\n      const nextMonthDate = this._dateAdapter.addCalendarMonths(this._activeDate, 1);\n      this._nextMonthWeeks = this._createWeekRows(nextMonthDate);\n      this._nextMonthYears = this._createYearRows(YEARS_PER_PAGE);\n    }\n    this._initialized = true;\n  }\n\n  /** Focuses on a day cell prioritizing the selected day, the current day, and lastly, the first selectable day. */\n  private _focusCell(): void {\n    if (this._resetFocus) {\n      this._getFirstFocusable()?.focus();\n      this._resetFocus = false;\n    }\n  }\n\n  /** Creates the array of weekdays. */\n  private _setWeekdays(): void {\n    const narrowWeekdays: string[] = this._dateAdapter.getDayOfWeekNames('narrow');\n    const longWeekdays: string[] = this._dateAdapter.getDayOfWeekNames('long');\n    const weekdays: Weekday[] = longWeekdays.map((long: string, i: number) => ({\n      long,\n      narrow: narrowWeekdays[i],\n    }));\n\n    // Rotates the labels for days of the week based on the configured first day of the week.\n    const firstDayOfWeek: number = this._dateAdapter.getFirstDayOfWeek();\n    this._weekdays = weekdays.slice(firstDayOfWeek).concat(weekdays.slice(0, firstDayOfWeek));\n  }\n\n  /** Creates the rows for each week. */\n  private _createWeekRows(value: T): Day[][] {\n    const daysInMonth: number = this._dateAdapter.getNumDaysInMonth(value);\n    const dateNames: string[] = this._dateAdapter.getDateNames();\n    const weeks: Day[][] = [[]];\n    const weekOffset = this._dateAdapter.getFirstWeekOffset(value);\n    for (let i = 0, cell = weekOffset; i < daysInMonth; i++, cell++) {\n      if (cell === DAYS_PER_ROW) {\n        weeks.push([]);\n        cell = 0;\n      }\n      const date = this._dateAdapter.createDate(\n        this._dateAdapter.getYear(value),\n        this._dateAdapter.getMonth(value),\n        i + 1,\n      )!;\n      weeks[weeks.length - 1].push({\n        value: this._dateAdapter.toIso8601(date),\n        dayValue: dateNames[i],\n        monthValue: String(this._dateAdapter.getMonth(date)),\n        yearValue: String(this._dateAdapter.getYear(date)),\n      });\n    }\n    return weeks;\n  }\n\n  /** Creates the rows for the month selection view. */\n  private _createMonthRows(): void {\n    const shortNames: string[] = this._dateAdapter.getMonthNames('short');\n    const months: Month[] = new Array(12).fill(null).map(\n      (_, i: number): Month => ({\n        value: shortNames[i],\n        longValue: this._monthNames[i],\n        monthValue: i + 1,\n      }),\n    );\n    const rows: number = 12 / MONTHS_PER_ROW;\n    const monthArray: Month[][] = [];\n    for (let i: number = 0; i < rows; i++) {\n      monthArray.push(months.slice(MONTHS_PER_ROW * i, MONTHS_PER_ROW * (i + 1)));\n    }\n    this._months = monthArray;\n  }\n\n  /** Creates the rows for the year selection view. */\n  private _createYearRows(offset: number = 0): number[][] {\n    const startValueYearView: number = this._getStartValueYearView();\n    const allYears: number[] = new Array(YEARS_PER_PAGE)\n      .fill(0)\n      .map((_, i: number) => startValueYearView + offset + i);\n    const rows: number = YEARS_PER_PAGE / YEARS_PER_ROW;\n    const yearArray: number[][] = [];\n    for (let i: number = 0; i < rows; i++) {\n      yearArray.push(allYears.slice(YEARS_PER_ROW * i, YEARS_PER_ROW * (i + 1)));\n    }\n    return yearArray;\n  }\n\n  /**\n   * Calculates the first year that will be shown in the year selection panel.\n   * If `minDate` and `maxDate` are both null, the starting year is calculated as\n   * the multiple of YEARS_PER_PAGE closest to and less than activeDate,\n   * e.g., with `YEARS_PER_PAGE` = 24 and `activeDate` = 2020, the function will return 2016 (24 * 83),\n   * while with `activeDate` = 2000, the function will return 1992 (24 * 82).\n   * If `minDate` is not null, it returns the corresponding year; if `maxDate` is not null,\n   * it returns the corresponding year minus `YEARS_PER_PAGE`, so that the `maxDate` is the last rendered year.\n   * If both are not null, `maxDate` has priority over `minDate`.\n   */\n  private _getStartValueYearView(): number {\n    let startingYear = 0;\n    if (this.max) {\n      startingYear = this._dateAdapter.getYear(this.max) - YEARS_PER_PAGE + 1;\n    } else if (this.min) {\n      startingYear = this._dateAdapter.getYear(this.min);\n    }\n    const activeYear = this._dateAdapter.getYear(this._activeDate);\n    return (\n      activeYear -\n      ((((activeYear - startingYear) % YEARS_PER_PAGE) + YEARS_PER_PAGE) % YEARS_PER_PAGE)\n    );\n  }\n\n  /** Checks if date is within the min-max range. */\n  private _isDayInRange(date: string): boolean {\n    if (!this.min && !this.max) {\n      return true;\n    }\n    const isBeforeMin: boolean =\n      this._dateAdapter.isValid(this.min) &&\n      this._dateAdapter.compareDate(this.min!, this._dateAdapter.deserialize(date)!) > 0;\n    const isAfterMax: boolean =\n      this._dateAdapter.isValid(this.max) &&\n      this._dateAdapter.compareDate(this.max!, this._dateAdapter.deserialize(date)!) < 0;\n    return !(isBeforeMin || isAfterMax);\n  }\n\n  private _isMonthInRange(month: number, year: number): boolean {\n    if (!this.min && !this.max) {\n      return true;\n    }\n\n    const isBeforeMin: boolean =\n      this._dateAdapter.isValid(this.min) &&\n      (year < this._dateAdapter.getYear(this.min!) ||\n        (year === this._dateAdapter.getYear(this.min!) &&\n          month < this._dateAdapter.getMonth(this.min!)));\n\n    const isAfterMax: boolean =\n      this._dateAdapter.isValid(this.max) &&\n      (year > this._dateAdapter.getYear(this.max!) ||\n        (year === this._dateAdapter.getYear(this.max!) &&\n          month > this._dateAdapter.getMonth(this.max!)));\n\n    return !(isBeforeMin || isAfterMax);\n  }\n\n  private _isYearInRange(year: number): boolean {\n    if (!this.min && !this.max) {\n      return true;\n    }\n    const isBeforeMin: boolean =\n      this._dateAdapter.isValid(this.min) && this._dateAdapter.getYear(this.min!) > year;\n    const isAfterMax: boolean =\n      this._dateAdapter.isValid(this.max) && this._dateAdapter.getYear(this.max!) < year;\n    return !(isBeforeMin || isAfterMax);\n  }\n\n  // Implementation adapted from https://github.com/angular/components/blob/main/src/material/datepicker/year-view.ts#L366\n  private _isMonthFilteredOut(month: number, year: number): boolean {\n    if (!this.dateFilter) {\n      return true;\n    }\n\n    const firstOfMonth = this._dateAdapter.createDate(year, month, 1)!;\n    for (\n      let date: T = firstOfMonth;\n      this._dateAdapter.getMonth(date) == month;\n      date = this._dateAdapter.addCalendarDays(date, 1)\n    ) {\n      if (this.dateFilter(date)) {\n        return true;\n      }\n    }\n\n    return false;\n  }\n\n  // Implementation adapted from https://github.com/angular/components/blob/main/src/material/datepicker/multi-year-view.ts#L351\n  private _isYearFilteredOut(year: number): boolean {\n    if (!this.dateFilter) {\n      return true;\n    }\n\n    const firstOfYear = this._dateAdapter.createDate(year, 1, 1)!;\n    for (\n      let date: T = firstOfYear;\n      this._dateAdapter.getYear(date) == year;\n      date = this._dateAdapter.addCalendarDays(date, 1)\n    ) {\n      if (this.dateFilter(date)) {\n        return true;\n      }\n    }\n\n    return false;\n  }\n\n  /** Emits the selected date and sets it internally. */\n  private _selectDate(day: string): void {\n    this._chosenMonth = undefined;\n    this._setChosenYear();\n    if (this._selected !== day) {\n      this._selected = day;\n      this._dateSelected.emit(this._dateAdapter.deserialize(day)!);\n    }\n  }\n\n  private _setChosenYear(): void {\n    if (this.view === 'month') {\n      this._chosenYear = this._dateAdapter.getYear(\n        this._dateAdapter.deserialize(this._selected) ?? this.selected ?? this.now,\n      );\n    } else {\n      this._chosenYear = undefined;\n    }\n  }\n\n  private _assignActiveDate(date: T): void {\n    if (this.min && this._dateAdapter.compareDate(this.min, date) > 0) {\n      this._activeDate = this.min;\n      return;\n    }\n    if (this.max && this._dateAdapter.compareDate(this.max, date) < 0) {\n      this._activeDate = this.max;\n      return;\n    }\n    this._activeDate = date;\n  }\n\n  /** Goes to the month identified by the shift. */\n  private _goToDifferentMonth(months: number): void {\n    this._init(this._dateAdapter.addCalendarMonths(this._activeDate, months));\n  }\n\n  private _goToDifferentYear(years: number): void {\n    this._chosenYear! += years;\n    // Can't use `_assignActiveDate(...)` here, because it will set it to min/max value if argument is out of range\n    this._activeDate = this._dateAdapter.createDate(\n      this._chosenYear!,\n      this._dateAdapter.getMonth(this._activeDate),\n      this._dateAdapter.getDate(this._activeDate),\n    );\n    this._init();\n  }\n\n  private _goToDifferentYearRange(years: number): void {\n    this._init(this._dateAdapter.addCalendarYears(this._activeDate, years));\n  }\n\n  private _prevDisabled(prevDate: T): boolean {\n    if (!this.min) {\n      return false;\n    }\n    return this._dateAdapter.compareDate(prevDate, this.min) < 0;\n  }\n\n  private _nextDisabled(nextDate: T): boolean {\n    if (!this.max) {\n      return false;\n    }\n    return this._dateAdapter.compareDate(nextDate, this.max) > 0;\n  }\n\n  /** Checks if the \"previous month\" button should be disabled. */\n  private _previousMonthDisabled(): boolean {\n    const prevMonth = this._dateAdapter.addCalendarDays(\n      this._activeDate,\n      this._dateAdapter.getDate(this._activeDate) * -1,\n    );\n    return this._prevDisabled(prevMonth);\n  }\n\n  /** Checks if the \"next month\" button should be disabled. */\n  private _nextMonthDisabled(): boolean {\n    let nextMonth = this._dateAdapter.addCalendarMonths(this._activeDate, this._wide ? 2 : 1);\n    nextMonth = this._dateAdapter.createDate(\n      this._dateAdapter.getYear(nextMonth),\n      this._dateAdapter.getMonth(nextMonth),\n      1,\n    );\n    return this._nextDisabled(nextMonth);\n  }\n\n  private _previousYearDisabled(): boolean {\n    const prevYear = this._dateAdapter.createDate(\n      this._dateAdapter.getYear(this._activeDate) - 1,\n      12,\n      31,\n    );\n    return this._prevDisabled(prevYear);\n  }\n\n  private _nextYearDisabled(): boolean {\n    const nextYear = this._dateAdapter.createDate(\n      this._dateAdapter.getYear(this._activeDate) + (this._wide ? 2 : 1),\n      1,\n      1,\n    );\n    return this._nextDisabled(nextYear);\n  }\n\n  private _previousYearRangeDisabled(): boolean {\n    const prevYear = this._dateAdapter.createDate(this._years[0][0] - 1, 12, 31);\n    return this._prevDisabled(prevYear);\n  }\n\n  private _nextYearRangeDisabled(): boolean {\n    const years = this._wide ? this._nextMonthYears : this._years;\n    const lastYearRange = years[years.length - 1];\n    const lastYear = lastYearRange[lastYearRange.length - 1];\n    const nextYear = this._dateAdapter.createDate(lastYear + 1, 1, 1);\n    return this._nextDisabled(nextYear);\n  }\n\n  private _handleTableBlur(eventTarget: HTMLElement): void {\n    if (eventTarget?.localName !== 'button') {\n      this._setTabIndex();\n    }\n  }\n\n  private _setTabIndex(): void {\n    Array.from(\n      this.shadowRoot!.querySelectorAll('.sbb-calendar__cell[tabindex=\"0\"]') ?? [],\n    ).forEach((day) => ((day as HTMLElement).tabIndex = -1));\n    const firstFocusable = this._getFirstFocusable();\n    if (firstFocusable) {\n      firstFocusable.tabIndex = 0;\n    }\n  }\n\n  private _getFirstFocusable(): HTMLButtonElement {\n    const active = this._selected ? this._dateAdapter.deserialize(this._selected)! : this.now;\n    let firstFocusable =\n      this.shadowRoot!.querySelector('.sbb-calendar__selected') ??\n      this.shadowRoot!.querySelector(\n        `[data-day=\"${this._dateAdapter.getDate(active)} ${this._dateAdapter.getMonth(\n          active,\n        )} ${this._dateAdapter.getYear(active)}\"]`,\n      ) ??\n      this.shadowRoot!.querySelector(`[data-month=\"${this._dateAdapter.getMonth(active)}\"]`) ??\n      this.shadowRoot!.querySelector(`[data-year=\"${this._dateAdapter.getYear(active)}\"]`);\n    if (!firstFocusable || (firstFocusable as HTMLButtonElement)?.disabled) {\n      firstFocusable = this.shadowRoot!.querySelector('.sbb-calendar__cell:not([disabled])');\n    }\n    return (firstFocusable as HTMLButtonElement) || null;\n  }\n\n  private _handleKeyboardEvent(event: KeyboardEvent, day?: Day): void {\n    if (isArrowKeyOrPageKeysPressed(event)) {\n      event.preventDefault();\n    }\n    // Gets the currently rendered table's cell;\n    // they could be days, months or years based on the current selection view.\n    // If `wide` is true, years are doubled in number and days are (roughly) doubled too, affecting the `index` calculation.\n    const cells: HTMLButtonElement[] = this._cells;\n    const index: number = cells.findIndex((e: HTMLButtonElement) => e === event.target);\n    const nextEl: HTMLButtonElement = this._navigateByKeyboard(event, index, cells, day);\n    const activeEl: HTMLButtonElement = this.shadowRoot!.activeElement as HTMLButtonElement;\n    if (nextEl !== activeEl) {\n      (nextEl as HTMLButtonElement).tabIndex = 0;\n      nextEl?.focus();\n      (activeEl as HTMLButtonElement).tabIndex = -1;\n    }\n  }\n\n  /**\n   * Gets the index of the element to move to, based on a list of elements (which can be potentially disabled),\n   * the keyboard input and the position of the current element in the list.\n   * In the day view, the `day?: Day` parameter is mandatory for calculation,\n   * while in month and year view it's not due to the fixed amount of rendered cells.\n   */\n  private _navigateByKeyboard(\n    evt: KeyboardEvent,\n    index: number,\n    cells: HTMLButtonElement[],\n    day?: Day,\n  ): HTMLButtonElement {\n    const {\n      elementIndexForWideMode,\n      offsetForWideMode,\n      lastElementIndexForWideMode,\n      verticalOffset,\n    }: CalendarKeyboardNavigationParameters = this._calculateParametersForKeyboardNavigation(\n      cells,\n      index,\n      day,\n    );\n\n    switch (evt.key) {\n      case 'ArrowUp':\n        return this._findNext(cells, index, -verticalOffset);\n      case 'ArrowDown':\n        return this._findNext(cells, index, verticalOffset);\n      case 'ArrowLeft':\n        return this._findNext(cells, index, -1);\n      case 'ArrowRight':\n        return this._findNext(cells, index, 1);\n      case 'Home':\n        return this._findFirst(cells, offsetForWideMode);\n      case 'PageUp':\n        return this._findFirstOnColumn(\n          cells,\n          elementIndexForWideMode,\n          offsetForWideMode,\n          verticalOffset,\n        );\n      case 'PageDown':\n        return this._findLastOnColumn(cells, index, lastElementIndexForWideMode, verticalOffset);\n      case 'End':\n        return this._findLast(cells, lastElementIndexForWideMode - 1);\n      default:\n        return cells[index];\n    }\n  }\n\n  /**\n   * Calculates the parameter needed in keyboard navigation.\n   * Since three views are now available, the function creates and returns the correct parameters for each of them\n   * by considering the number of cells per each row and the correction for the wide mode.\n   * @param cells The array of rendered table cells; they are buttons that can represent days, months or years.\n   * @param index The starting element's index in the cell array.\n   * @param day (optional) Only in the day view, the day represented by the starting cell.\n   */\n  private _calculateParametersForKeyboardNavigation(\n    cells: HTMLButtonElement[],\n    index: number,\n    day?: Day,\n  ): CalendarKeyboardNavigationParameters {\n    switch (this._calendarView) {\n      case 'day': {\n        const indexInView = +day!.dayValue - 1;\n        return {\n          verticalOffset: DAYS_PER_ROW,\n          elementIndexForWideMode: indexInView,\n          offsetForWideMode: index - indexInView,\n          lastElementIndexForWideMode:\n            index === indexInView\n              ? this._dateAdapter.getNumDaysInMonth(\n                  this._dateAdapter.addCalendarMonths(\n                    this._dateAdapter.deserialize(day!.value)!,\n                    -1,\n                  ),\n                )\n              : cells.length,\n        };\n      }\n      // Month view is not dependent from `wide` value, so some parameters are fixed.\n      case 'month': {\n        return {\n          verticalOffset: MONTHS_PER_ROW,\n          elementIndexForWideMode: index,\n          offsetForWideMode: 0,\n          lastElementIndexForWideMode: 12,\n        };\n      }\n      case 'year': {\n        const offset: number = Math.trunc(index / YEARS_PER_PAGE) * YEARS_PER_PAGE;\n        const indexInView: number = offset === 0 ? index : index - YEARS_PER_PAGE;\n        return {\n          verticalOffset: YEARS_PER_ROW,\n          elementIndexForWideMode: indexInView,\n          offsetForWideMode: index - indexInView,\n          lastElementIndexForWideMode: offset === 0 ? YEARS_PER_PAGE : YEARS_PER_PAGE * 2,\n        };\n      }\n    }\n  }\n\n  /**\n   * Gets the next element of the provided array starting from `index` by adding `delta`.\n   * If the found element is disabled, it continues adding `delta` until it finds an enabled one in the array bounds.\n   */\n  private _findNext(days: HTMLButtonElement[], index: number, delta: number): HTMLButtonElement {\n    let nextIndex = index + delta;\n    while (nextIndex < days.length && days[nextIndex]?.disabled) {\n      nextIndex += delta;\n    }\n    return days[nextIndex] ?? days[index];\n  }\n\n  /** Find the first enabled element in the provided array. */\n  private _findFirst(days: HTMLButtonElement[], firstOfCurrentMonth: number): HTMLButtonElement {\n    return !days[firstOfCurrentMonth].disabled\n      ? days[firstOfCurrentMonth]\n      : this._findNext(days, firstOfCurrentMonth, 1);\n  }\n\n  /** Find the last enabled element in the provided array. */\n  private _findLast(days: HTMLButtonElement[], lastOfCurrentMonth: number): HTMLButtonElement {\n    return !days[lastOfCurrentMonth].disabled\n      ? days[lastOfCurrentMonth]\n      : this._findNext(days, lastOfCurrentMonth, -1);\n  }\n\n  /** Find the first enabled element in the same column of the provided array. */\n  private _findFirstOnColumn(\n    days: HTMLButtonElement[],\n    index: number,\n    offset: number,\n    verticalOffset: number,\n  ): HTMLButtonElement {\n    const nextIndex = (index % verticalOffset) + offset;\n    return !days[nextIndex].disabled\n      ? days[nextIndex]\n      : this._findNext(days, nextIndex, verticalOffset);\n  }\n\n  /** Find the last enabled element in the same column of the provided array. */\n  private _findLastOnColumn(\n    days: HTMLButtonElement[],\n    index: number,\n    offset: number,\n    verticalOffset: number,\n  ): HTMLButtonElement {\n    const nextIndex = index + Math.trunc((offset - index - 1) / verticalOffset) * verticalOffset;\n    return !days[nextIndex].disabled\n      ? days[nextIndex]\n      : this._findNext(days, nextIndex, -verticalOffset);\n  }\n\n  private _resetCalendarView(initTransition = false): void {\n    this._resetFocus = true;\n    this._activeDate = this.selected ?? this.now;\n    this._setChosenYear();\n    this._chosenMonth = undefined;\n    this._nextCalendarView = this._calendarView = this.view;\n\n    if (initTransition) {\n      this._startTableTransition();\n    }\n  }\n\n  /** Render the view for the day selection. */\n  private _renderDayView(): TemplateResult {\n    const nextMonthActiveDate = this._wide\n      ? this._dateAdapter.addCalendarMonths(this._activeDate, 1)\n      : undefined;\n    return html`\n      <div class=\"sbb-calendar__controls\">\n        ${this._getArrow(\n          'left',\n          () => this._goToDifferentMonth(-1),\n          i18nPreviousMonth[this._language.current],\n          this._previousMonthDisabled(),\n        )}\n        <div class=\"sbb-calendar__controls-month\">\n          ${this._createLabelForDayView(this._activeDate)}\n          ${this._wide ? this._createLabelForDayView(nextMonthActiveDate!) : nothing}\n          <sbb-screen-reader-only role=\"status\">\n            ${this._createAriaLabelForDayView(this._activeDate, nextMonthActiveDate!)}\n          </sbb-screen-reader-only>\n        </div>\n        ${this._getArrow(\n          'right',\n          () => this._goToDifferentMonth(1),\n          i18nNextMonth[this._language.current],\n          this._nextMonthDisabled(),\n        )}\n      </div>\n      <div class=\"sbb-calendar__table-container sbb-calendar__table-day-view\">\n        ${this._createDayTable(this._weeks)}\n        ${this._wide ? this._createDayTable(this._nextMonthWeeks) : nothing}\n      </div>\n    `;\n  }\n\n  /** Creates the label with the month for the daily view. */\n  private _createLabelForDayView(d: T): TemplateResult {\n    const monthLabel = `${\n      this._monthNames[this._dateAdapter.getMonth(d) - 1]\n    } ${this._dateAdapter.getYear(d)}`;\n    return html`\n      <button\n        type=\"button\"\n        class=\"sbb-calendar__date-selection sbb-calendar__controls-change-date\"\n        aria-label=\"${i18nYearMonthSelection[this._language.current]} ${monthLabel}\"\n        @click=${() => {\n          this._resetFocus = true;\n          this._nextCalendarView = 'year';\n          this._startTableTransition();\n        }}\n      >\n        ${monthLabel}\n        <sbb-icon name=\"chevron-small-down-small\"></sbb-icon>\n      </button>\n    `;\n  }\n\n  /** Creates the aria-label for the daily view. */\n  private _createAriaLabelForDayView(...dates: T[]): string {\n    let monthLabel = '';\n    for (const d of dates) {\n      if (d) {\n        monthLabel += `${\n          this._monthNames[this._dateAdapter.getMonth(d) - 1]\n        } ${this._dateAdapter.getYear(d)} `;\n      }\n    }\n    return monthLabel;\n  }\n\n  /** Creates the calendar table for the daily view. */\n  private _createDayTable(weeks: Day[][]): TemplateResult {\n    return html`\n      <table\n        class=\"sbb-calendar__table\"\n        @focusout=${(event: FocusEvent) =>\n          this._handleTableBlur(event.relatedTarget as HTMLElement)}\n        @animationend=${(e: AnimationEvent) => this._tableAnimationEnd(e)}\n      >\n        <thead class=\"sbb-calendar__table-header\">\n          <tr class=\"sbb-calendar__table-header-row\">\n            ${this._createDayTableHeader()}\n          </tr>\n        </thead>\n        <tbody class=\"sbb-calendar__table-body\">\n          ${this._createDayTableBody(weeks)}\n        </tbody>\n      </table>\n    `;\n  }\n\n  /** Creates the table header with the month header cells. */\n  private _createDayTableHeader(): TemplateResult[] {\n    return this._weekdays.map(\n      (day: Weekday) => html`\n        <th class=\"sbb-calendar__table-header\">\n          <sbb-screen-reader-only>${day.long}</sbb-screen-reader-only>\n          <span aria-hidden=\"true\">${day.narrow}</span>\n        </th>\n      `,\n    );\n  }\n\n  /** Creates the table body with the day cells. For the first row, it also considers the possible day's offset. */\n  private _createDayTableBody(weeks: Day[][]): TemplateResult[] {\n    const today: string = this._dateAdapter.toIso8601(this.now);\n    return weeks.map((week: Day[], rowIndex: number) => {\n      const firstRowOffset: number = DAYS_PER_ROW - week.length;\n      if (rowIndex === 0 && firstRowOffset) {\n        return html`\n          <tr>\n            ${[...Array(firstRowOffset).keys()].map(\n              () =>\n                html`<td\n                  class=\"sbb-calendar__table-data\"\n                  data-day=${`0 ${week[0].monthValue} ${week[0].yearValue}`}\n                ></td>`,\n            )}\n            ${this._createDayCells(week, today)}\n          </tr>\n        `;\n      }\n      return html`<tr>\n        ${this._createDayCells(week, today)}\n      </tr>`;\n    });\n  }\n\n  /** Creates the cells for the daily view. */\n  private _createDayCells(week: Day[], today: string): TemplateResult[] {\n    return week.map((day: Day) => {\n      const isOutOfRange = !this._isDayInRange(day.value);\n      const isFilteredOut = !this._dateFilter(this._dateAdapter.deserialize(day.value)!);\n      const selected: boolean = !!this._selected && day.value === this._selected;\n      const dayValue = `${day.dayValue} ${day.monthValue} ${day.yearValue}`;\n      const isToday = day.value === today;\n      return html`\n        <td\n          class=${classMap({\n            'sbb-calendar__table-data': true,\n            'sbb-calendar__table-data-selected': selected,\n          })}\n        >\n          <button\n            class=${classMap({\n              'sbb-calendar__cell': true,\n              'sbb-calendar__day': true,\n              'sbb-calendar__cell-current': isToday,\n              'sbb-calendar__selected': selected,\n              'sbb-calendar__crossed-out': !isOutOfRange && isFilteredOut,\n            })}\n            @click=${() => this._selectDate(day.value)}\n            ?disabled=${isOutOfRange || isFilteredOut}\n            aria-label=${this._dateAdapter.getAccessibilityFormatDate(day.value)}\n            aria-pressed=${selected}\n            aria-disabled=${isOutOfRange || isFilteredOut}\n            aria-current=${isToday ? 'date' : nothing}\n            data-day=${dayValue || nothing}\n            tabindex=\"-1\"\n            @keydown=${(evt: KeyboardEvent) => this._handleKeyboardEvent(evt, day)}\n            sbb-popover-close\n          >\n            ${day.dayValue}\n          </button>\n        </td>\n      `;\n    });\n  }\n\n  /** Render the view for the month selection. */\n  private _renderMonthView(): TemplateResult {\n    return html`\n      <div class=\"sbb-calendar__controls\">\n        ${this._getArrow(\n          'left',\n          () => this._goToDifferentYear(-1),\n          i18nPreviousYear[this._language.current],\n          this._previousYearDisabled(),\n        )}\n        <div class=\"sbb-calendar__controls-month\">${this._createLabelForMonthView()}</div>\n        ${this._getArrow(\n          'right',\n          () => this._goToDifferentYear(1),\n          i18nNextYear[this._language.current],\n          this._nextYearDisabled(),\n        )}\n      </div>\n      <div class=\"sbb-calendar__table-container sbb-calendar__table-month-view\">\n        ${this._createMonthTable(this._months, this._chosenYear!)}\n        ${this._wide ? this._createMonthTable(this._months, this._chosenYear! + 1) : nothing}\n      </div>\n    `;\n  }\n\n  /** Creates the label with the year for the monthly view. */\n  private _createLabelForMonthView(): TemplateResult {\n    return html` <button\n        type=\"button\"\n        id=\"sbb-calendar__month-selection\"\n        class=\"sbb-calendar__controls-change-date\"\n        aria-label=${`${i18nCalendarDateSelection[this._language.current]} ${this._chosenYear}`}\n        @click=${() => this._resetCalendarView(true)}\n      >\n        ${this._chosenYear} ${this._wide ? ` - ${this._chosenYear! + 1}` : nothing}\n        <sbb-icon name=\"chevron-small-up-small\"></sbb-icon>\n      </button>\n      <sbb-screen-reader-only role=\"status\"> ${this._chosenYear} </sbb-screen-reader-only>`;\n  }\n\n  /** Creates the table for the month selection view. */\n  private _createMonthTable(months: Month[][], year: number): TemplateResult {\n    return html`\n      <table\n        class=\"sbb-calendar__table\"\n        @animationend=${(e: AnimationEvent) => this._tableAnimationEnd(e)}\n      >\n        ${this._wide\n          ? html`<thead class=\"sbb-calendar__table-header\" aria-hidden=\"true\">\n              <tr class=\"sbb-calendar__table-header-row\">\n                <th class=\"sbb-calendar__table-header\" colspan=${MONTHS_PER_ROW}>${year}</th>\n              </tr>\n            </thead>`\n          : nothing}\n        <tbody class=\"sbb-calendar__table-body\">\n          ${months.map(\n            (row: Month[]) => html`\n              <tr>\n                ${row.map((month: Month) => {\n                  const isOutOfRange = !this._isMonthInRange(month.monthValue, year);\n                  const isFilteredOut = !this._isMonthFilteredOut(month.monthValue, year);\n                  const selectedMonth = this._selected\n                    ? this._dateAdapter.getMonth(this._dateAdapter.deserialize(this._selected)!)\n                    : undefined;\n                  const selectedYear = this._selected\n                    ? this._dateAdapter.getYear(this._dateAdapter.deserialize(this._selected)!)\n                    : undefined;\n                  const selected: boolean =\n                    !!this._selected && year === selectedYear && month.monthValue === selectedMonth;\n\n                  const isCurrentMonth =\n                    year === this._dateAdapter.getYear(this.now) &&\n                    this._dateAdapter.getMonth(this.now) === month.monthValue;\n\n                  return html` <td\n                    class=${classMap({\n                      'sbb-calendar__table-data': true,\n                      'sbb-calendar__table-month': true,\n                    })}\n                  >\n                    <button\n                      class=${classMap({\n                        'sbb-calendar__cell': true,\n                        'sbb-calendar__pill': true,\n                        'sbb-calendar__cell-current': isCurrentMonth,\n                        'sbb-calendar__crossed-out': !isOutOfRange && isFilteredOut,\n                        'sbb-calendar__selected': selected,\n                      })}\n                      @click=${() => this._onMonthSelection(month.monthValue, year)}\n                      ?disabled=${isOutOfRange || isFilteredOut}\n                      aria-label=${`${month.longValue} ${year}`}\n                      aria-pressed=${selected}\n                      aria-disabled=${String(isOutOfRange || isFilteredOut)}\n                      tabindex=\"-1\"\n                      data-month=${month.monthValue || nothing}\n                      @keydown=${(evt: KeyboardEvent) => this._handleKeyboardEvent(evt)}\n                    >\n                      ${month.value}\n                    </button>\n                  </td>`;\n                })}\n              </tr>\n            `,\n          )}\n        </tbody>\n      </table>\n    `;\n  }\n\n  /** Select the month and change the view to day selection. */\n  private _onMonthSelection(month: number, year: number): void {\n    this._chosenMonth = month;\n    this._nextCalendarView = 'day';\n    this._init(\n      this._dateAdapter.createDate(\n        year,\n        this._chosenMonth,\n        this._dateAdapter.getDate(this._activeDate),\n      ),\n    );\n    this._startTableTransition();\n  }\n\n  /** Render the view for the year selection. */\n  private _renderYearView(): TemplateResult {\n    return html`\n      <div class=\"sbb-calendar__controls\">\n        ${this._getArrow(\n          'left',\n          () => this._goToDifferentYearRange(-YEARS_PER_PAGE),\n          i18nPreviousYearRange(YEARS_PER_PAGE)[this._language.current],\n          this._previousYearRangeDisabled(),\n        )}\n        <div class=\"sbb-calendar__controls-month\">${this._createLabelForYearView()}</div>\n        ${this._getArrow(\n          'right',\n          () => this._goToDifferentYearRange(YEARS_PER_PAGE),\n          i18nNextYearRange(YEARS_PER_PAGE)[this._language.current],\n          this._nextYearRangeDisabled(),\n        )}\n      </div>\n      <div class=\"sbb-calendar__table-container sbb-calendar__table-year-view\">\n        ${this._createYearTable(this._years)}\n        ${this._wide ? this._createYearTable(this._nextMonthYears, true) : nothing}\n      </div>\n    `;\n  }\n\n  /** Creates the button arrow for all the views. */\n  private _getArrow(\n    direction: 'left' | 'right',\n    click: () => void,\n    ariaLabel: string,\n    disabled: boolean,\n  ): TemplateResult {\n    return html`<sbb-secondary-button\n      size=\"m\"\n      icon-name=\"chevron-small-${direction}-small\"\n      aria-label=${ariaLabel}\n      @click=${click}\n      ?disabled=${disabled}\n      id=\"sbb-calendar__controls-${direction === 'left' ? 'previous' : 'next'}\"\n    ></sbb-secondary-button>`;\n  }\n\n  /** Creates the label with the year range for the yearly view. */\n  private _createLabelForYearView(): TemplateResult {\n    const firstYear: number = this._years.flat()[0];\n    const lastYearArray: number[] = (this._wide ? this._nextMonthYears : this._years).flat();\n    const lastYear: number = lastYearArray[lastYearArray.length - 1];\n    const yearLabel = `${firstYear} - ${lastYear}`;\n    return html`\n      <button\n        type=\"button\"\n        id=\"sbb-calendar__year-selection\"\n        class=\"sbb-calendar__controls-change-date\"\n        aria-label=\"${i18nCalendarDateSelection[this._language.current]} ${yearLabel}\"\n        @click=${() => this._resetCalendarView(true)}\n      >\n        ${yearLabel}\n        <sbb-icon name=\"chevron-small-up-small\"></sbb-icon>\n      </button>\n      <sbb-screen-reader-only role=\"status\"> ${yearLabel} </sbb-screen-reader-only>\n    `;\n  }\n\n  /** Creates the table for the year selection view. */\n  private _createYearTable(years: number[][], shiftRight = false): TemplateResult {\n    const now = this.now;\n    return html` <table\n      class=\"sbb-calendar__table\"\n      @animationend=${(e: AnimationEvent) => this._tableAnimationEnd(e)}\n    >\n      <tbody class=\"sbb-calendar__table-body\">\n        ${years.map(\n          (row: number[]) =>\n            html` <tr>\n              ${row.map((year: number) => {\n                const isOutOfRange = !this._isYearInRange(year);\n                const isFilteredOut = !this._isYearFilteredOut(year);\n                const selectedYear = this._selected\n                  ? this._dateAdapter.getYear(this._dateAdapter.deserialize(this._selected)!)\n                  : undefined;\n                const selected: boolean = !!this._selected && year === selectedYear;\n                const isCurrentYear = this._dateAdapter.getYear(now) === year;\n                return html` <td class=\"sbb-calendar__table-data sbb-calendar__table-year\">\n                  <button\n                    class=${classMap({\n                      'sbb-calendar__cell': true,\n                      'sbb-calendar__pill': true,\n                      'sbb-calendar__cell-current': isCurrentYear,\n                      'sbb-calendar__crossed-out': !isOutOfRange && isFilteredOut,\n                      'sbb-calendar__selected': selected,\n                    })}\n                    @click=${() => this._onYearSelection(year, shiftRight)}\n                    ?disabled=${isOutOfRange || isFilteredOut}\n                    aria-label=${year}\n                    aria-pressed=${selected}\n                    aria-disabled=${String(isOutOfRange || isFilteredOut)}\n                    tabindex=\"-1\"\n                    data-year=${year || nothing}\n                    @keydown=${(evt: KeyboardEvent) => this._handleKeyboardEvent(evt)}\n                  >\n                    ${year}\n                  </button>\n                </td>`;\n              })}\n            </tr>`,\n        )}\n      </tbody>\n    </table>`;\n  }\n\n  /** Select the year and change the view to month selection. */\n  private _onYearSelection(year: number, rightSide: boolean): void {\n    this._chosenYear = rightSide ? year - 1 : year;\n    this._nextCalendarView = 'month';\n    this._assignActiveDate(\n      this._dateAdapter.createDate(\n        this._chosenYear,\n        this._dateAdapter.getMonth(this._activeDate),\n        this._dateAdapter.getDate(this._activeDate),\n      ),\n    );\n    this._startTableTransition();\n  }\n\n  private _getView(): TemplateResult {\n    if (isServer || this.hydrationRequired) {\n      // TODO: We disable SSR for calendar for now. Figure our, if there is a way\n      // to enable it, while considering i18n and date information.\n      return html`${nothing}`;\n    }\n    switch (this._calendarView) {\n      case 'year':\n        return this._renderYearView();\n      case 'month':\n        return this._renderMonthView();\n      case 'day':\n      default:\n        return this._renderDayView();\n    }\n  }\n\n  private _tableAnimationEnd(event: AnimationEvent): void {\n    const table = event.target as HTMLElement;\n    if (event.animationName === 'hide') {\n      table.classList.remove('sbb-calendar__table-hide');\n      this._resetFocus = true;\n      this._calendarView = this._nextCalendarView;\n    } else if (event.animationName === 'show') {\n      this.removeAttribute('data-transition');\n    }\n  }\n\n  private _startTableTransition(): void {\n    this.toggleAttribute('data-transition', true);\n    this.shadowRoot\n      ?.querySelectorAll('table')\n      ?.forEach((e) => e.classList.toggle('sbb-calendar__table-hide'));\n  }\n\n  protected override render(): TemplateResult {\n    return html`<div class=\"sbb-calendar__wrapper\">${this._getView()}</div>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-calendar': SbbCalendarElement;\n  }\n}\n"],"names":["SbbCalendarElement","_a"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAmGM,sBAAkB,MAAA;;0BADvB,cAAc,cAAc,CAAC;;;;oBACa,kBAAkB,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAApCA,MAAAA,uBAAA,mBAAQ,YAA6B;AAAA,IA+ItE,cAAA;;;AAtIA;AAGY;AAoD4B;AAa/B;AAGA;AAWA;AA0CT;AArII,yBAAA,yBAAA,kBAAA,MAAA,0BAAA,GAS4B,kBAAA,MAAA,oBAAA,KAAK;AAGT,yBAAA,yBAAA,kBAAA,MAAA,uBAAA,GAAA,kBAAA,MAAA,oBAAqB,KAAK;AAU9C,WAAA,OAAgB,kBAAA,MAAA,uBAAA;AAoBhB,WAAI,OAAa;AAsB+B,yBAAA,8BAAA,kBAAA,MAAA,0BAE7C,IAAI;AAEK,WAAA,gBAAA,kBAAA,MAAA,6BAAA,KAAmBC,MAAA,aAAa,aAAb,gBAAAA,IAAuB,gBAAe;AAGrE,WAAA,gBAAiC,IAAI,aAC3C,MACAD,oBAAmB,OAAO,YAAY;AAId,yBAAiB,+BAAA,kBAAA,MAAA,2BAAA,KAAK,GAAG;AAGK,yBAAA,8BAAA,kBAAA,MAAA,8BAAA,GAAA,kBAAA,MAAA,yBAAA,MAAA;AAW9B,yBAAA,kCAAA,kBAAA,MAAA,4BAAA,GAAA,kBAAA,MAAA,6BAA8B,KAAK;AAErD,WAAiB,qBAAA,kBAAA,MAAA,gCAAA,GAAiB;AAMlC,WAAM,SAAY;AAelB,WAAW,cAAa,KAAK,aAAa,cAAc,MAAM;AAgB9D,WAAW,cAAG;AAGL,yBAAA,gCAAA,kBAAA,MAAA,4BAAe,KAAK;AAEpB,WAAA,aAAA,kBAAA,MAAA,+BAAA,GAAG,IAAI,sBAAsB,IAAI,EAAE,YAAY,MAAK;AACnE,aAAK,cAAc,KAAK,aAAa,cAAc,MAAM;AACzD,aAAK,iBAAgB;AAAA,MAAA,CACtB;AACO,WAAA,gBAAgB,IAAI,0BAA0B,MAAM;AAAA,QAC1D,CAAC,qCAAqC,GAAG,MAAM,KAAK,MAAO;AAAA,MAAA,CAC5D;AAIC,WAAK,iBAAgB;AACrB,WAAK,aAAY;AAAA,IAAA;AAAA;AAAA,IAzInB,IAAgB,OAAsB;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAtC,IAAgB,KAAsB,OAAA;AAAA,yBAAA,wBAAA;AAAA,IAAA;AAAA;AAAA,IAG1B,IAAgB,OAA2B;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA3C,IAAgB,KAA2B,OAAA;AAAA,yBAAA,wBAAA;AAAA,IAAA;AAAA;AAAA,IAIvD,IAAW,IAAI,OAA4B;AACpC,WAAA,OAAO,KAAK,aAAa,mBAAmB,KAAK,aAAa,YAAY,KAAK,CAAC;AAAA,IAAA;AAAA,IAEvF,IAAW,MAAG;AACZ,aAAO,KAAK,QAAQ;AAAA,IAAA;AAAA;AAAA,IAMtB,IAAW,IAAI,OAA4B;AACpC,WAAA,OAAO,KAAK,aAAa,mBAAmB,KAAK,aAAa,YAAY,KAAK,CAAC;AAAA,IAAA;AAAA,IAEvF,IAAW,MAAG;AACZ,aAAO,KAAK,QAAQ;AAAA,IAAA;AAAA;AAAA,IAMtB,IAAW,IAAI,OAA4B;AACpC,WAAA,OAAO,KAAK,aAAa,mBAAmB,KAAK,aAAa,YAAY,KAAK,CAAC;AAAA,IAAA;AAAA,IAEvF,IAAW,MAAG;AACZ,aAAO,KAAK,QAAQ,KAAK,aAAa,MAAK;AAAA,IAAA;AAAA;AAAA,IAM7C,IAAW,SAAS,OAA4B;AACzC,WAAA,gBAAgB,KAAK,aAAa,mBAAmB,KAAK,aAAa,YAAY,KAAK,CAAC;AAC9F,UACE,CAAC,CAAC,KAAK,kBACN,CAAC,KAAK,cAAc,KAAK,aAAa,UAAU,KAAK,aAAa,CAAC,KAClE,KAAK,YAAY,KAAK,aAAa,IACrC;AACA,aAAK,YAAY,KAAK,aAAa,UAAU,KAAK,aAAa;AAAA,MAAA,OAC1D;AACL,aAAK,YAAY;AAAA,MAAA;AAAA,IACnB;AAAA,IAEF,IAAW,WAAQ;AACjB,aAAO,KAAK,iBAAiB;AAAA,IAAA;AAAA;AAAA,IAKS,IAAgB,aAExC;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAFwB,IAAgB,WAExC,OAAA;AAAA,yBAAA,8BAAA;AAAA,IAAA;AAAA;AAAA,IAWP,IAAiB,cAA0B;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA3C,IAAiB,YAA0B,OAAA;AAAA,yBAAA,+BAAA;AAAA,IAAA;AAAA;AAAA,IAG3C,IAAiB,YAA8B;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA/C,IAAiB,UAA8B,OAAA;AAAA,yBAAA,6BAAA;AAAA,IAAA;AAAA;AAAA,IAIxD,IAAY,MAAM,MAAa;AACxB,WAAA,gBAAgB,aAAa,IAAI;AAAA,IAAA;AAAA,IAExC,IAAY,QAAK;AACR,aAAA,KAAK,aAAa,WAAW;AAAA,IAAA;AAAA,IAG7B,IAAiB,gBAAoC;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAArD,IAAiB,cAAoC,OAAA;AAAA,yBAAA,iCAAA;AAAA,IAAA;AAAA;AAAA,IA0B9D,IAAY,SAAM;AACT,aAAA,MAAM,KACX,KAAK,WAAY,iBAAiB,qBAAqB,KAAK,EAAE;AAAA,IAAA;AAAA,IAclE,IAAiB,eAAqB;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAtC,IAAiB,aAAqB,OAAA;AAAA,yBAAA,gCAAA;AAAA,IAAA;AAAA,IAgB9B,YAAY,MAAO;;AAClB,eAAAC,MAAA,KAAK,eAAL,gBAAAA,IAAA,WAAkB,UAAS;AAAA,IAAA;AAAA;AAAA,IAI7B,gBAAa;AAClB,WAAK,mBAAkB;AACvB,WAAK,MAAK;AAAA,IAAA;AAAA,IAGI,oBAAiB;AAC/B,YAAM,kBAAiB;AACvB,WAAK,cAAa;AAClB,WAAK,QAAQ,MAAK;AAChB,aAAK,cAAc;AACnB,aAAK,WAAU;AAAA,MACjB;AAAA,IAAA;AAAA,IAGiB,WAAW,mBAAuC;AACnE,YAAM,WAAW,iBAAiB;AAE9B,UAAA,CAAC,KAAK,cAAc;AACtB;AAAA,MAAA;AAGE,UAAA,kBAAkB,IAAI,MAAM,GAAG;AACjC,aAAK,cAAa;AAAA,MAAA;AAGhB,UAAA,kBAAkB,IAAI,MAAM,GAAG;AACjC,aAAK,eAAc;AACnB,aAAK,eAAe;AACf,aAAA,oBAAoB,KAAK,gBAAgB,KAAK;AAAA,MAAA;AAAA,IACrD;AAAA,IAGiB,QAAQ,mBAAuC;AAChE,YAAM,QAAQ,iBAAiB;AAG/B,WAAK,aAAY;AAIb,UAAA,yBAAyB,uBAAuB,YAAY;AAC9D,aAAK,WAAU;AAAA,MAAA;AAAA,IACjB;AAAA;AAAA,IAIM,MAAM,YAAc;AAE1B,UAAI,UAAU;AACZ;AAAA,MAAA,WACS,KAAK,mBAAmB;AACjC,aAAK,kBAAkB,KAAK,MAAM,KAAK,OAAO;AAC9C;AAAA,MAAA;AAGF,UAAI,YAAY;AACd,aAAK,kBAAkB,UAAU;AAAA,MAAA;AAEnC,WAAK,SACF,KAAK,cAAc,QAAQ,qCAAqC,KAAK,UAAU,KAAK;AACvF,WAAK,SAAS,KAAK,gBAAgB,KAAK,WAAW;AAC9C,WAAA,SAAS,KAAK;AACd,WAAA,kBAAkB,CAAC,EAAE;AACrB,WAAA,kBAAkB,CAAC,EAAE;AAC1B,UAAI,KAAK,OAAO;AACd,cAAM,gBAAgB,KAAK,aAAa,kBAAkB,KAAK,aAAa,CAAC;AACxE,aAAA,kBAAkB,KAAK,gBAAgB,aAAa;AACpD,aAAA,kBAAkB,KAAK,gBAAgB,cAAc;AAAA,MAAA;AAE5D,WAAK,eAAe;AAAA,IAAA;AAAA;AAAA,IAId,aAAU;;AAChB,UAAI,KAAK,aAAa;AACf,SAAAA,MAAA,KAAA,yBAAA,gBAAAA,IAAsB;AAC3B,aAAK,cAAc;AAAA,MAAA;AAAA,IACrB;AAAA;AAAA,IAIM,eAAY;AAClB,YAAM,iBAA2B,KAAK,aAAa,kBAAkB,QAAQ;AAC7E,YAAM,eAAyB,KAAK,aAAa,kBAAkB,MAAM;AACzE,YAAM,WAAsB,aAAa,IAAI,CAAC,MAAc,OAAe;AAAA,QACzE;AAAA,QACA,QAAQ,eAAe,CAAC;AAAA,MAAA,EACxB;AAGI,YAAA,iBAAyB,KAAK,aAAa;AAC5C,WAAA,YAAY,SAAS,MAAM,cAAc,EAAE,OAAO,SAAS,MAAM,GAAG,cAAc,CAAC;AAAA,IAAA;AAAA;AAAA,IAIlF,gBAAgB,OAAQ;AAC9B,YAAM,cAAsB,KAAK,aAAa,kBAAkB,KAAK;AAC/D,YAAA,YAAsB,KAAK,aAAa;AACxC,YAAA,QAAiB,CAAC,EAAE;AAC1B,YAAM,aAAa,KAAK,aAAa,mBAAmB,KAAK;AAC7D,eAAS,IAAI,GAAG,OAAO,YAAY,IAAI,aAAa,KAAK,QAAQ;AAC/D,YAAI,SAAS,cAAc;AACnB,gBAAA,KAAK,EAAE;AACN,iBAAA;AAAA,QAAA;AAET,cAAM,OAAO,KAAK,aAAa,WAC7B,KAAK,aAAa,QAAQ,KAAK,GAC/B,KAAK,aAAa,SAAS,KAAK,GAChC,IAAI,CAAC;AAEP,cAAM,MAAM,SAAS,CAAC,EAAE,KAAK;AAAA,UAC3B,OAAO,KAAK,aAAa,UAAU,IAAI;AAAA,UACvC,UAAU,UAAU,CAAC;AAAA,UACrB,YAAY,OAAO,KAAK,aAAa,SAAS,IAAI,CAAC;AAAA,UACnD,WAAW,OAAO,KAAK,aAAa,QAAQ,IAAI,CAAC;AAAA,QAAA,CAClD;AAAA,MAAA;AAEI,aAAA;AAAA,IAAA;AAAA;AAAA,IAID,mBAAgB;AACtB,YAAM,aAAuB,KAAK,aAAa,cAAc,OAAO;AAC9D,YAAA,SAAkB,IAAI,MAAM,EAAE,EAAE,KAAK,IAAI,EAAE,IAC/C,CAAC,GAAG,OAAsB;AAAA,QACxB,OAAO,WAAW,CAAC;AAAA,QACnB,WAAW,KAAK,YAAY,CAAC;AAAA,QAC7B,YAAY,IAAI;AAAA,MAAA,EAChB;AAEJ,YAAM,OAAe,KAAK;AAC1B,YAAM,aAAwB,CAAA;AAC9B,eAAS,IAAY,GAAG,IAAI,MAAM,KAAK;AAC1B,mBAAA,KAAK,OAAO,MAAM,iBAAiB,GAAG,kBAAkB,IAAI,EAAE,CAAC;AAAA,MAAA;AAE5E,WAAK,UAAU;AAAA,IAAA;AAAA;AAAA,IAIT,gBAAgB,SAAiB,GAAC;AAClC,YAAA,qBAA6B,KAAK;AACxC,YAAM,WAAqB,IAAI,MAAM,cAAc,EAChD,KAAK,CAAC,EACN,IAAI,CAAC,GAAG,MAAc,qBAAqB,SAAS,CAAC;AACxD,YAAM,OAAe,iBAAiB;AACtC,YAAM,YAAwB,CAAA;AAC9B,eAAS,IAAY,GAAG,IAAI,MAAM,KAAK;AAC3B,kBAAA,KAAK,SAAS,MAAM,gBAAgB,GAAG,iBAAiB,IAAI,EAAE,CAAC;AAAA,MAAA;AAEpE,aAAA;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAaD,yBAAsB;AAC5B,UAAI,eAAe;AACnB,UAAI,KAAK,KAAK;AACZ,uBAAe,KAAK,aAAa,QAAQ,KAAK,GAAG,IAAI,iBAAiB;AAAA,MAAA,WAC7D,KAAK,KAAK;AACnB,uBAAe,KAAK,aAAa,QAAQ,KAAK,GAAG;AAAA,MAAA;AAEnD,YAAM,aAAa,KAAK,aAAa,QAAQ,KAAK,WAAW;AAC7D,aACE,eACI,aAAa,gBAAgB,iBAAkB,kBAAkB;AAAA,IAAA;AAAA;AAAA,IAKjE,cAAc,MAAY;AAChC,UAAI,CAAC,KAAK,OAAO,CAAC,KAAK,KAAK;AACnB,eAAA;AAAA,MAAA;AAET,YAAM,cACJ,KAAK,aAAa,QAAQ,KAAK,GAAG,KAClC,KAAK,aAAa,YAAY,KAAK,KAAM,KAAK,aAAa,YAAY,IAAI,CAAE,IAAI;AACnF,YAAM,aACJ,KAAK,aAAa,QAAQ,KAAK,GAAG,KAClC,KAAK,aAAa,YAAY,KAAK,KAAM,KAAK,aAAa,YAAY,IAAI,CAAE,IAAI;AACnF,aAAO,EAAE,eAAe;AAAA,IAAA;AAAA,IAGlB,gBAAgB,OAAe,MAAY;AACjD,UAAI,CAAC,KAAK,OAAO,CAAC,KAAK,KAAK;AACnB,eAAA;AAAA,MAAA;AAGH,YAAA,cACJ,KAAK,aAAa,QAAQ,KAAK,GAAG,MACjC,OAAO,KAAK,aAAa,QAAQ,KAAK,GAAI,KACxC,SAAS,KAAK,aAAa,QAAQ,KAAK,GAAI,KAC3C,QAAQ,KAAK,aAAa,SAAS,KAAK,GAAI;AAE5C,YAAA,aACJ,KAAK,aAAa,QAAQ,KAAK,GAAG,MACjC,OAAO,KAAK,aAAa,QAAQ,KAAK,GAAI,KACxC,SAAS,KAAK,aAAa,QAAQ,KAAK,GAAI,KAC3C,QAAQ,KAAK,aAAa,SAAS,KAAK,GAAI;AAElD,aAAO,EAAE,eAAe;AAAA,IAAA;AAAA,IAGlB,eAAe,MAAY;AACjC,UAAI,CAAC,KAAK,OAAO,CAAC,KAAK,KAAK;AACnB,eAAA;AAAA,MAAA;AAET,YAAM,cACJ,KAAK,aAAa,QAAQ,KAAK,GAAG,KAAK,KAAK,aAAa,QAAQ,KAAK,GAAI,IAAI;AAChF,YAAM,aACJ,KAAK,aAAa,QAAQ,KAAK,GAAG,KAAK,KAAK,aAAa,QAAQ,KAAK,GAAI,IAAI;AAChF,aAAO,EAAE,eAAe;AAAA,IAAA;AAAA;AAAA,IAIlB,oBAAoB,OAAe,MAAY;AACjD,UAAA,CAAC,KAAK,YAAY;AACb,eAAA;AAAA,MAAA;AAGT,YAAM,eAAe,KAAK,aAAa,WAAW,MAAM,OAAO,CAAC;AAChE,eACM,OAAU,cACd,KAAK,aAAa,SAAS,IAAI,KAAK,OACpC,OAAO,KAAK,aAAa,gBAAgB,MAAM,CAAC,GAChD;AACI,YAAA,KAAK,WAAW,IAAI,GAAG;AAClB,iBAAA;AAAA,QAAA;AAAA,MACT;AAGK,aAAA;AAAA,IAAA;AAAA;AAAA,IAID,mBAAmB,MAAY;AACjC,UAAA,CAAC,KAAK,YAAY;AACb,eAAA;AAAA,MAAA;AAGT,YAAM,cAAc,KAAK,aAAa,WAAW,MAAM,GAAG,CAAC;AAC3D,eACM,OAAU,aACd,KAAK,aAAa,QAAQ,IAAI,KAAK,MACnC,OAAO,KAAK,aAAa,gBAAgB,MAAM,CAAC,GAChD;AACI,YAAA,KAAK,WAAW,IAAI,GAAG;AAClB,iBAAA;AAAA,QAAA;AAAA,MACT;AAGK,aAAA;AAAA,IAAA;AAAA;AAAA,IAID,YAAY,KAAW;AAC7B,WAAK,eAAe;AACpB,WAAK,eAAc;AACf,UAAA,KAAK,cAAc,KAAK;AAC1B,aAAK,YAAY;AACjB,aAAK,cAAc,KAAK,KAAK,aAAa,YAAY,GAAG,CAAE;AAAA,MAAA;AAAA,IAC7D;AAAA,IAGM,iBAAc;AAChB,UAAA,KAAK,SAAS,SAAS;AACzB,aAAK,cAAc,KAAK,aAAa,QACnC,KAAK,aAAa,YAAY,KAAK,SAAS,KAAK,KAAK,YAAY,KAAK,GAAG;AAAA,MAAA,OAEvE;AACL,aAAK,cAAc;AAAA,MAAA;AAAA,IACrB;AAAA,IAGM,kBAAkB,MAAO;AAC3B,UAAA,KAAK,OAAO,KAAK,aAAa,YAAY,KAAK,KAAK,IAAI,IAAI,GAAG;AACjE,aAAK,cAAc,KAAK;AACxB;AAAA,MAAA;AAEE,UAAA,KAAK,OAAO,KAAK,aAAa,YAAY,KAAK,KAAK,IAAI,IAAI,GAAG;AACjE,aAAK,cAAc,KAAK;AACxB;AAAA,MAAA;AAEF,WAAK,cAAc;AAAA,IAAA;AAAA;AAAA,IAIb,oBAAoB,QAAc;AACxC,WAAK,MAAM,KAAK,aAAa,kBAAkB,KAAK,aAAa,MAAM,CAAC;AAAA,IAAA;AAAA,IAGlE,mBAAmB,OAAa;AACtC,WAAK,eAAgB;AAErB,WAAK,cAAc,KAAK,aAAa,WACnC,KAAK,aACL,KAAK,aAAa,SAAS,KAAK,WAAW,GAC3C,KAAK,aAAa,QAAQ,KAAK,WAAW,CAAC;AAE7C,WAAK,MAAK;AAAA,IAAA;AAAA,IAGJ,wBAAwB,OAAa;AAC3C,WAAK,MAAM,KAAK,aAAa,iBAAiB,KAAK,aAAa,KAAK,CAAC;AAAA,IAAA;AAAA,IAGhE,cAAc,UAAW;AAC3B,UAAA,CAAC,KAAK,KAAK;AACN,eAAA;AAAA,MAAA;AAET,aAAO,KAAK,aAAa,YAAY,UAAU,KAAK,GAAG,IAAI;AAAA,IAAA;AAAA,IAGrD,cAAc,UAAW;AAC3B,UAAA,CAAC,KAAK,KAAK;AACN,eAAA;AAAA,MAAA;AAET,aAAO,KAAK,aAAa,YAAY,UAAU,KAAK,GAAG,IAAI;AAAA,IAAA;AAAA;AAAA,IAIrD,yBAAsB;AAC5B,YAAM,YAAY,KAAK,aAAa,gBAClC,KAAK,aACL,KAAK,aAAa,QAAQ,KAAK,WAAW,IAAI,EAAE;AAE3C,aAAA,KAAK,cAAc,SAAS;AAAA,IAAA;AAAA;AAAA,IAI7B,qBAAkB;AACpB,UAAA,YAAY,KAAK,aAAa,kBAAkB,KAAK,aAAa,KAAK,QAAQ,IAAI,CAAC;AACxF,kBAAY,KAAK,aAAa,WAC5B,KAAK,aAAa,QAAQ,SAAS,GACnC,KAAK,aAAa,SAAS,SAAS,GACpC,CAAC;AAEI,aAAA,KAAK,cAAc,SAAS;AAAA,IAAA;AAAA,IAG7B,wBAAqB;AAC3B,YAAM,WAAW,KAAK,aAAa,WACjC,KAAK,aAAa,QAAQ,KAAK,WAAW,IAAI,GAC9C,IACA,EAAE;AAEG,aAAA,KAAK,cAAc,QAAQ;AAAA,IAAA;AAAA,IAG5B,oBAAiB;AACvB,YAAM,WAAW,KAAK,aAAa,WACjC,KAAK,aAAa,QAAQ,KAAK,WAAW,KAAK,KAAK,QAAQ,IAAI,IAChE,GACA,CAAC;AAEI,aAAA,KAAK,cAAc,QAAQ;AAAA,IAAA;AAAA,IAG5B,6BAA0B;AAChC,YAAM,WAAW,KAAK,aAAa,WAAW,KAAK,OAAO,CAAC,EAAE,CAAC,IAAI,GAAG,IAAI,EAAE;AACpE,aAAA,KAAK,cAAc,QAAQ;AAAA,IAAA;AAAA,IAG5B,yBAAsB;AAC5B,YAAM,QAAQ,KAAK,QAAQ,KAAK,kBAAkB,KAAK;AACvD,YAAM,gBAAgB,MAAM,MAAM,SAAS,CAAC;AAC5C,YAAM,WAAW,cAAc,cAAc,SAAS,CAAC;AACvD,YAAM,WAAW,KAAK,aAAa,WAAW,WAAW,GAAG,GAAG,CAAC;AACzD,aAAA,KAAK,cAAc,QAAQ;AAAA,IAAA;AAAA,IAG5B,iBAAiB,aAAwB;AAC3C,WAAA,2CAAa,eAAc,UAAU;AACvC,aAAK,aAAY;AAAA,MAAA;AAAA,IACnB;AAAA,IAGM,eAAY;AAClB,YAAM,KACJ,KAAK,WAAY,iBAAiB,mCAAmC,KAAK,EAAE,EAC5E,QAAQ,CAAC,QAAU,IAAoB,WAAW,EAAG;AACjD,YAAA,iBAAiB,KAAK;AAC5B,UAAI,gBAAgB;AAClB,uBAAe,WAAW;AAAA,MAAA;AAAA,IAC5B;AAAA,IAGM,qBAAkB;AAClB,YAAA,SAAS,KAAK,YAAY,KAAK,aAAa,YAAY,KAAK,SAAS,IAAK,KAAK;AAClF,UAAA,iBACF,KAAK,WAAY,cAAc,yBAAyB,KACxD,KAAK,WAAY,cACf,cAAc,KAAK,aAAa,QAAQ,MAAM,CAAC,IAAI,KAAK,aAAa,SACnE,MAAM,CACP,IAAI,KAAK,aAAa,QAAQ,MAAM,CAAC,IAAI,KAE5C,KAAK,WAAY,cAAc,gBAAgB,KAAK,aAAa,SAAS,MAAM,CAAC,IAAI,KACrF,KAAK,WAAY,cAAc,eAAe,KAAK,aAAa,QAAQ,MAAM,CAAC,IAAI;AACjF,UAAA,CAAC,mBAAmB,iDAAsC,WAAU;AACrD,yBAAA,KAAK,WAAY,cAAc,qCAAqC;AAAA,MAAA;AAEvF,aAAQ,kBAAwC;AAAA,IAAA;AAAA,IAG1C,qBAAqB,OAAsB,KAAS;AACtD,UAAA,4BAA4B,KAAK,GAAG;AACtC,cAAM,eAAc;AAAA,MAAA;AAKtB,YAAM,QAA6B,KAAK;AACxC,YAAM,QAAgB,MAAM,UAAU,CAAC,MAAyB,MAAM,MAAM,MAAM;AAClF,YAAM,SAA4B,KAAK,oBAAoB,OAAO,OAAO,OAAO,GAAG;AAC7E,YAAA,WAA8B,KAAK,WAAY;AACrD,UAAI,WAAW,UAAU;AACtB,eAA6B,WAAW;AACzC,yCAAQ;AACP,iBAA+B,WAAW;AAAA,MAAA;AAAA,IAC7C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IASM,oBACN,KACA,OACA,OACA,KAAS;AAEH,YAAA,EACJ,yBACA,mBACA,6BACA,eAAA,IACwC,KAAK,0CAC7C,OACA,OACA,GAAG;AAGL,cAAQ,IAAI,KAAK;AAAA,QACf,KAAK;AACH,iBAAO,KAAK,UAAU,OAAO,OAAO,CAAC,cAAc;AAAA,QACrD,KAAK;AACH,iBAAO,KAAK,UAAU,OAAO,OAAO,cAAc;AAAA,QACpD,KAAK;AACH,iBAAO,KAAK,UAAU,OAAO,OAAO,EAAE;AAAA,QACxC,KAAK;AACH,iBAAO,KAAK,UAAU,OAAO,OAAO,CAAC;AAAA,QACvC,KAAK;AACI,iBAAA,KAAK,WAAW,OAAO,iBAAiB;AAAA,QACjD,KAAK;AACH,iBAAO,KAAK,mBACV,OACA,yBACA,mBACA,cAAc;AAAA,QAElB,KAAK;AACH,iBAAO,KAAK,kBAAkB,OAAO,OAAO,6BAA6B,cAAc;AAAA,QACzF,KAAK;AACH,iBAAO,KAAK,UAAU,OAAO,8BAA8B,CAAC;AAAA,QAC9D;AACE,iBAAO,MAAM,KAAK;AAAA,MAAA;AAAA,IACtB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAWM,0CACN,OACA,OACA,KAAS;AAET,cAAQ,KAAK,eAAe;AAAA,QAC1B,KAAK,OAAO;AACJ,gBAAA,cAAc,CAAC,IAAK,WAAW;AAC9B,iBAAA;AAAA,YACL,gBAAgB;AAAA,YAChB,yBAAyB;AAAA,YACzB,mBAAmB,QAAQ;AAAA,YAC3B,6BACE,UAAU,cACN,KAAK,aAAa,kBAChB,KAAK,aAAa,kBAChB,KAAK,aAAa,YAAY,IAAK,KAAK,GACxC,EAAE,CACH,IAEH,MAAM;AAAA;;;QAIhB,KAAK,SAAS;AACL,iBAAA;AAAA,YACL,gBAAgB;AAAA,YAChB,yBAAyB;AAAA,YACzB,mBAAmB;AAAA,YACnB,6BAA6B;AAAA;;QAGjC,KAAK,QAAQ;AACX,gBAAM,SAAiB,KAAK,MAAM,QAAQ,cAAc,IAAI;AAC5D,gBAAM,cAAsB,WAAW,IAAI,QAAQ,QAAQ;AACpD,iBAAA;AAAA,YACL,gBAAgB;AAAA,YAChB,yBAAyB;AAAA,YACzB,mBAAmB,QAAQ;AAAA,YAC3B,6BAA6B,WAAW,IAAI,iBAAiB,iBAAiB;AAAA;;MAElF;AAAA,IACF;AAAA;AAAA;AAAA;AAAA;AAAA,IAOM,UAAU,MAA2B,OAAe,OAAa;;AACvE,UAAI,YAAY,QAAQ;AACxB,aAAO,YAAY,KAAK,YAAUA,MAAA,KAAK,SAAS,MAAd,gBAAAA,IAAiB,WAAU;AAC9C,qBAAA;AAAA,MAAA;AAEf,aAAO,KAAK,SAAS,KAAK,KAAK,KAAK;AAAA,IAAA;AAAA;AAAA,IAI9B,WAAW,MAA2B,qBAA2B;AACvE,aAAO,CAAC,KAAK,mBAAmB,EAAE,WAC9B,KAAK,mBAAmB,IACxB,KAAK,UAAU,MAAM,qBAAqB,CAAC;AAAA,IAAA;AAAA;AAAA,IAIzC,UAAU,MAA2B,oBAA0B;AACrE,aAAO,CAAC,KAAK,kBAAkB,EAAE,WAC7B,KAAK,kBAAkB,IACvB,KAAK,UAAU,MAAM,oBAAoB,EAAE;AAAA,IAAA;AAAA;AAAA,IAIzC,mBACN,MACA,OACA,QACA,gBAAsB;AAEhB,YAAA,YAAa,QAAQ,iBAAkB;AAC7C,aAAO,CAAC,KAAK,SAAS,EAAE,WACpB,KAAK,SAAS,IACd,KAAK,UAAU,MAAM,WAAW,cAAc;AAAA,IAAA;AAAA;AAAA,IAI5C,kBACN,MACA,OACA,QACA,gBAAsB;AAEhB,YAAA,YAAY,QAAQ,KAAK,OAAO,SAAS,QAAQ,KAAK,cAAc,IAAI;AAC9E,aAAO,CAAC,KAAK,SAAS,EAAE,WACpB,KAAK,SAAS,IACd,KAAK,UAAU,MAAM,WAAW,CAAC,cAAc;AAAA,IAAA;AAAA,IAG7C,mBAAmB,iBAAiB,OAAK;AAC/C,WAAK,cAAc;AACd,WAAA,cAAc,KAAK,YAAY,KAAK;AACzC,WAAK,eAAc;AACnB,WAAK,eAAe;AACf,WAAA,oBAAoB,KAAK,gBAAgB,KAAK;AAEnD,UAAI,gBAAgB;AAClB,aAAK,sBAAqB;AAAA,MAAA;AAAA,IAC5B;AAAA;AAAA,IAIM,iBAAc;AACd,YAAA,sBAAsB,KAAK,QAC7B,KAAK,aAAa,kBAAkB,KAAK,aAAa,CAAC,IACvD;AACG,aAAA;AAAA;AAAA,UAED,KAAK,UACL,QACA,MAAM,KAAK,oBAAoB,EAAE,GACjC,kBAAkB,KAAK,UAAU,OAAO,GACxC,KAAK,uBAAA,CAAwB,CAC9B;AAAA;AAAA,YAEG,KAAK,uBAAuB,KAAK,WAAW,CAAC;AAAA,YAC7C,KAAK,QAAQ,KAAK,uBAAuB,mBAAoB,IAAI,OAAO;AAAA;AAAA,cAEtE,KAAK,2BAA2B,KAAK,aAAa,mBAAoB,CAAC;AAAA;AAAA;AAAA,UAG3E,KAAK,UACL,SACA,MAAM,KAAK,oBAAoB,CAAC,GAChC,cAAc,KAAK,UAAU,OAAO,GACpC,KAAK,mBAAA,CAAoB,CAC1B;AAAA;AAAA;AAAA,UAGC,KAAK,gBAAgB,KAAK,MAAM,CAAC;AAAA,UACjC,KAAK,QAAQ,KAAK,gBAAgB,KAAK,eAAe,IAAI,OAAO;AAAA;AAAA;AAAA,IAAA;AAAA;AAAA,IAMjE,uBAAuB,GAAI;AACjC,YAAM,aAAa,GACjB,KAAK,YAAY,KAAK,aAAa,SAAS,CAAC,IAAI,CAAC,CACpD,IAAI,KAAK,aAAa,QAAQ,CAAC,CAAC;AACzB,aAAA;AAAA;AAAA;AAAA;AAAA,sBAIW,uBAAuB,KAAK,UAAU,OAAO,CAAC,IAAI,UAAU;AAAA,iBACjE,MAAK;AACZ,aAAK,cAAc;AACnB,aAAK,oBAAoB;AACzB,aAAK,sBAAqB;AAAA,MAC3B,CAAA;AAAA;AAAA,UAEC,UAAU;AAAA;AAAA;AAAA;AAAA,IAAA;AAAA;AAAA,IAOV,8BAA8B,OAAU;AAC9C,UAAI,aAAa;AACjB,iBAAW,KAAK,OAAO;AACrB,YAAI,GAAG;AACL,wBAAc,GACZ,KAAK,YAAY,KAAK,aAAa,SAAS,CAAC,IAAI,CAAC,CACpD,IAAI,KAAK,aAAa,QAAQ,CAAC,CAAC;AAAA,QAAA;AAAA,MAClC;AAEK,aAAA;AAAA,IAAA;AAAA;AAAA,IAID,gBAAgB,OAAc;AAC7B,aAAA;AAAA;AAAA;AAAA,oBAGS,CAAC,UACX,KAAK,iBAAiB,MAAM,aAA4B,CAAC;AAAA,wBAC3C,CAAC,MAAsB,KAAK,mBAAmB,CAAC,CAAC;AAAA;AAAA;AAAA;AAAA,cAI3D,KAAK,sBAAuB,CAAA;AAAA;AAAA;AAAA;AAAA,YAI9B,KAAK,oBAAoB,KAAK,CAAC;AAAA;AAAA;AAAA;AAAA,IAAA;AAAA;AAAA,IAOjC,wBAAqB;AAC3B,aAAO,KAAK,UAAU,IACpB,CAAC,QAAiB;AAAA;AAAA,oCAEY,IAAI,IAAI;AAAA,qCACP,IAAI,MAAM;AAAA;AAAA,OAExC;AAAA,IAAA;AAAA;AAAA,IAKG,oBAAoB,OAAc;AACxC,YAAM,QAAgB,KAAK,aAAa,UAAU,KAAK,GAAG;AAC1D,aAAO,MAAM,IAAI,CAAC,MAAa,aAAoB;AAC3C,cAAA,iBAAyB,eAAe,KAAK;AAC/C,YAAA,aAAa,KAAK,gBAAgB;AAC7B,iBAAA;AAAA;AAAA,cAED,CAAC,GAAG,MAAM,cAAc,EAAE,KAAI,CAAE,EAAE,IAClC,MACE;AAAA;AAAA,6BAEa,KAAK,KAAK,CAAC,EAAE,UAAU,IAAI,KAAK,CAAC,EAAE,SAAS,EAAE;AAAA,uBACpD,CACV;AAAA,cACC,KAAK,gBAAgB,MAAM,KAAK,CAAC;AAAA;AAAA;AAAA,QAAA;AAIlC,eAAA;AAAA,UACH,KAAK,gBAAgB,MAAM,KAAK,CAAC;AAAA;AAAA,MAAA,CAEtC;AAAA,IAAA;AAAA;AAAA,IAIK,gBAAgB,MAAa,OAAa;AACzC,aAAA,KAAK,IAAI,CAAC,QAAY;AAC3B,cAAM,eAAe,CAAC,KAAK,cAAc,IAAI,KAAK;AAC5C,cAAA,gBAAgB,CAAC,KAAK,YAAY,KAAK,aAAa,YAAY,IAAI,KAAK,CAAE;AACjF,cAAM,WAAoB,CAAC,CAAC,KAAK,aAAa,IAAI,UAAU,KAAK;AAC3D,cAAA,WAAW,GAAG,IAAI,QAAQ,IAAI,IAAI,UAAU,IAAI,IAAI,SAAS;AAC7D,cAAA,UAAU,IAAI,UAAU;AACvB,eAAA;AAAA;AAAA,kBAEK,SAAS;AAAA,UACf,4BAA4B;AAAA,UAC5B,qCAAqC;AAAA,QAAA,CACtC,CAAC;AAAA;AAAA;AAAA,oBAGQ,SAAS;AAAA,UACf,sBAAsB;AAAA,UACtB,qBAAqB;AAAA,UACrB,8BAA8B;AAAA,UAC9B,0BAA0B;AAAA,UAC1B,6BAA6B,CAAC,gBAAgB;AAAA,QAAA,CAC/C,CAAC;AAAA,qBACO,MAAM,KAAK,YAAY,IAAI,KAAK,CAAC;AAAA,wBAC9B,gBAAgB,aAAa;AAAA,yBAC5B,KAAK,aAAa,2BAA2B,IAAI,KAAK,CAAC;AAAA,2BACrD,QAAQ;AAAA,4BACP,gBAAgB,aAAa;AAAA,2BAC9B,UAAU,SAAS,OAAO;AAAA,uBAC9B,YAAY,OAAO;AAAA;AAAA,uBAEnB,CAAC,QAAuB,KAAK,qBAAqB,KAAK,GAAG,CAAC;AAAA;AAAA;AAAA,cAGpE,IAAI,QAAQ;AAAA;AAAA;AAAA;AAAA,MAAA,CAIrB;AAAA,IAAA;AAAA;AAAA,IAIK,mBAAgB;AACf,aAAA;AAAA;AAAA,UAED,KAAK,UACL,QACA,MAAM,KAAK,mBAAmB,EAAE,GAChC,iBAAiB,KAAK,UAAU,OAAO,GACvC,KAAK,sBAAA,CAAuB,CAC7B;AAAA,oDAC2C,KAAK,0BAA0B;AAAA,UACzE,KAAK,UACL,SACA,MAAM,KAAK,mBAAmB,CAAC,GAC/B,aAAa,KAAK,UAAU,OAAO,GACnC,KAAK,kBAAA,CAAmB,CACzB;AAAA;AAAA;AAAA,UAGC,KAAK,kBAAkB,KAAK,SAAS,KAAK,WAAY,CAAC;AAAA,UACvD,KAAK,QAAQ,KAAK,kBAAkB,KAAK,SAAS,KAAK,cAAe,CAAC,IAAI,OAAO;AAAA;AAAA;AAAA,IAAA;AAAA;AAAA,IAMlF,2BAAwB;AACvB,aAAA;AAAA;AAAA;AAAA;AAAA,qBAIU,GAAG,0BAA0B,KAAK,UAAU,OAAO,CAAC,IAAI,KAAK,WAAW,EAAE;AAAA,iBAC9E,MAAM,KAAK,mBAAmB,IAAI,CAAC;AAAA;AAAA,UAE1C,KAAK,WAAW,IAAI,KAAK,QAAQ,MAAM,KAAK,cAAe,CAAC,KAAK,OAAO;AAAA;AAAA;AAAA,+CAGnC,KAAK,WAAW;AAAA,IAAA;AAAA;AAAA,IAIrD,kBAAkB,QAAmB,MAAY;AAChD,aAAA;AAAA;AAAA;AAAA,wBAGa,CAAC,MAAsB,KAAK,mBAAmB,CAAC,CAAC;AAAA;AAAA,UAE/D,KAAK,QACH;AAAA;AAAA,iEAEqD,cAAc,IAAI,IAAI;AAAA;AAAA,wBAG3E,OAAO;AAAA;AAAA,YAEP,OAAO,IACP,CAAC,QAAiB;AAAA;AAAA,kBAEZ,IAAI,IAAI,CAAC,UAAgB;AACzB,cAAM,eAAe,CAAC,KAAK,gBAAgB,MAAM,YAAY,IAAI;AACjE,cAAM,gBAAgB,CAAC,KAAK,oBAAoB,MAAM,YAAY,IAAI;AACtE,cAAM,gBAAgB,KAAK,YACvB,KAAK,aAAa,SAAS,KAAK,aAAa,YAAY,KAAK,SAAS,CAAE,IACzE;AACJ,cAAM,eAAe,KAAK,YACtB,KAAK,aAAa,QAAQ,KAAK,aAAa,YAAY,KAAK,SAAS,CAAE,IACxE;AACE,cAAA,WACJ,CAAC,CAAC,KAAK,aAAa,SAAS,gBAAgB,MAAM,eAAe;AAEpE,cAAM,iBACJ,SAAS,KAAK,aAAa,QAAQ,KAAK,GAAG,KAC3C,KAAK,aAAa,SAAS,KAAK,GAAG,MAAM,MAAM;AAE1C,eAAA;AAAA,4BACG,SAAS;AAAA,UACf,4BAA4B;AAAA,UAC5B,6BAA6B;AAAA,QAAA,CAC9B,CAAC;AAAA;AAAA;AAAA,8BAGQ,SAAS;AAAA,UACf,sBAAsB;AAAA,UACtB,sBAAsB;AAAA,UACtB,8BAA8B;AAAA,UAC9B,6BAA6B,CAAC,gBAAgB;AAAA,UAC9C,0BAA0B;AAAA,QAAA,CAC3B,CAAC;AAAA,+BACO,MAAM,KAAK,kBAAkB,MAAM,YAAY,IAAI,CAAC;AAAA,kCACjD,gBAAgB,aAAa;AAAA,mCAC5B,GAAG,MAAM,SAAS,IAAI,IAAI,EAAE;AAAA,qCAC1B,QAAQ;AAAA,sCACP,OAAO,gBAAgB,aAAa,CAAC;AAAA;AAAA,mCAExC,MAAM,cAAc,OAAO;AAAA,iCAC7B,CAAC,QAAuB,KAAK,qBAAqB,GAAG,CAAC;AAAA;AAAA,wBAE/D,MAAM,KAAK;AAAA;AAAA;AAAA,MAAA,CAGlB,CAAC;AAAA;AAAA,aAEL,CACF;AAAA;AAAA;AAAA;AAAA,IAAA;AAAA;AAAA,IAOD,kBAAkB,OAAe,MAAY;AACnD,WAAK,eAAe;AACpB,WAAK,oBAAoB;AACzB,WAAK,MACH,KAAK,aAAa,WAChB,MACA,KAAK,cACL,KAAK,aAAa,QAAQ,KAAK,WAAW,CAAC,CAC5C;AAEH,WAAK,sBAAqB;AAAA,IAAA;AAAA;AAAA,IAIpB,kBAAe;AACd,aAAA;AAAA;AAAA,UAED,KAAK,UACL,QACA,MAAM,KAAK,wBAAwB,CAAC,cAAc,GAClD,sBAAsB,cAAc,EAAE,KAAK,UAAU,OAAO,GAC5D,KAAK,4BAA4B,CAClC;AAAA,oDAC2C,KAAK,yBAAyB;AAAA,UACxE,KAAK,UACL,SACA,MAAM,KAAK,wBAAwB,cAAc,GACjD,kBAAkB,cAAc,EAAE,KAAK,UAAU,OAAO,GACxD,KAAK,wBAAwB,CAC9B;AAAA;AAAA;AAAA,UAGC,KAAK,iBAAiB,KAAK,MAAM,CAAC;AAAA,UAClC,KAAK,QAAQ,KAAK,iBAAiB,KAAK,iBAAiB,IAAI,IAAI,OAAO;AAAA;AAAA;AAAA,IAAA;AAAA;AAAA,IAMxE,UACN,WACA,OACA,WACA,UAAiB;AAEV,aAAA;AAAA;AAAA,iCAEsB,SAAS;AAAA,mBACvB,SAAS;AAAA,eACb,KAAK;AAAA,kBACF,QAAQ;AAAA,mCACS,cAAc,SAAS,aAAa,MAAM;AAAA;AAAA,IAAA;AAAA;AAAA,IAKnE,0BAAuB;AAC7B,YAAM,YAAoB,KAAK,OAAO,KAAA,EAAO,CAAC;AAC9C,YAAM,iBAA2B,KAAK,QAAQ,KAAK,kBAAkB,KAAK,QAAQ,KAAI;AACtF,YAAM,WAAmB,cAAc,cAAc,SAAS,CAAC;AAC/D,YAAM,YAAY,GAAG,SAAS,MAAM,QAAQ;AACrC,aAAA;AAAA;AAAA;AAAA;AAAA;AAAA,sBAKW,0BAA0B,KAAK,UAAU,OAAO,CAAC,IAAI,SAAS;AAAA,iBACnE,MAAM,KAAK,mBAAmB,IAAI,CAAC;AAAA;AAAA,UAE1C,SAAS;AAAA;AAAA;AAAA,+CAG4B,SAAS;AAAA;AAAA,IAAA;AAAA;AAAA,IAK9C,iBAAiB,OAAmB,aAAa,OAAK;AAC5D,YAAM,MAAM,KAAK;AACV,aAAA;AAAA;AAAA,sBAEW,CAAC,MAAsB,KAAK,mBAAmB,CAAC,CAAC;AAAA;AAAA;AAAA,UAG7D,MAAM,IACN,CAAC,QACC;AAAA,gBACI,IAAI,IAAI,CAAC,SAAgB;AACzB,cAAM,eAAe,CAAC,KAAK,eAAe,IAAI;AAC9C,cAAM,gBAAgB,CAAC,KAAK,mBAAmB,IAAI;AACnD,cAAM,eAAe,KAAK,YACtB,KAAK,aAAa,QAAQ,KAAK,aAAa,YAAY,KAAK,SAAS,CAAE,IACxE;AACJ,cAAM,WAAoB,CAAC,CAAC,KAAK,aAAa,SAAS;AACvD,cAAM,gBAAgB,KAAK,aAAa,QAAQ,GAAG,MAAM;AAClD,eAAA;AAAA;AAAA,4BAEK,SAAS;AAAA,UACf,sBAAsB;AAAA,UACtB,sBAAsB;AAAA,UACtB,8BAA8B;AAAA,UAC9B,6BAA6B,CAAC,gBAAgB;AAAA,UAC9C,0BAA0B;AAAA,QAAA,CAC3B,CAAC;AAAA,6BACO,MAAM,KAAK,iBAAiB,MAAM,UAAU,CAAC;AAAA,gCAC1C,gBAAgB,aAAa;AAAA,iCAC5B,IAAI;AAAA,mCACF,QAAQ;AAAA,oCACP,OAAO,gBAAgB,aAAa,CAAC;AAAA;AAAA,gCAEzC,QAAQ,OAAO;AAAA,+BAChB,CAAC,QAAuB,KAAK,qBAAqB,GAAG,CAAC;AAAA;AAAA,sBAE/D,IAAI;AAAA;AAAA;AAAA,MAAA,CAGX,CAAC;AAAA,kBACE,CACT;AAAA;AAAA;AAAA,IAAA;AAAA;AAAA,IAMC,iBAAiB,MAAc,WAAkB;AAClD,WAAA,cAAc,YAAY,OAAO,IAAI;AAC1C,WAAK,oBAAoB;AACzB,WAAK,kBACH,KAAK,aAAa,WAChB,KAAK,aACL,KAAK,aAAa,SAAS,KAAK,WAAW,GAC3C,KAAK,aAAa,QAAQ,KAAK,WAAW,CAAC,CAC5C;AAEH,WAAK,sBAAqB;AAAA,IAAA;AAAA,IAGpB,WAAQ;AACV,UAAA,YAAY,KAAK,mBAAmB;AAGtC,eAAO,OAAO,OAAO;AAAA,MAAA;AAEvB,cAAQ,KAAK,eAAe;AAAA,QAC1B,KAAK;AACH,iBAAO,KAAK,gBAAe;AAAA,QAC7B,KAAK;AACH,iBAAO,KAAK,iBAAgB;AAAA,QAC9B,KAAK;AAAA,QACL;AACE,iBAAO,KAAK,eAAc;AAAA,MAAA;AAAA,IAC9B;AAAA,IAGM,mBAAmB,OAAqB;AAC9C,YAAM,QAAQ,MAAM;AAChB,UAAA,MAAM,kBAAkB,QAAQ;AAC5B,cAAA,UAAU,OAAO,0BAA0B;AACjD,aAAK,cAAc;AACnB,aAAK,gBAAgB,KAAK;AAAA,MAAA,WACjB,MAAM,kBAAkB,QAAQ;AACzC,aAAK,gBAAgB,iBAAiB;AAAA,MAAA;AAAA,IACxC;AAAA,IAGM,wBAAqB;;AACtB,WAAA,gBAAgB,mBAAmB,IAAI;AACvC,aAAAA,MAAA,KAAA,eAAA,gBAAAA,IACD,iBAAiB,aADhB,mBAED,QAAQ,CAAC,MAAM,EAAE,UAAU,OAAO,0BAA0B;AAAA,IAAC;AAAA,IAGhD,SAAM;AAChB,aAAA,0CAA0C,KAAK,SAAA,CAAU;AAAA,IAAA;AAAA,KAxqClE,wCAGY,wCAoD4B,8CAa/B,+CAGA,6CAWA,iDA0CT;;wBA9HC,aACA,SAAS,EAAE,MAAM,QAAA,CAAS,CAAC;AAI3B,uBAAA,CAAA,UAAU;AAGV,0BAAA,CAAA,UAAU;AAUV,0BAAA,CAAA,UAAU;AAUV,0BAAA,CAAA,UAAU;AAUV,+BAAA,CAAA,UAAU;AAmBV,6BAAA,CAAA,SAAS,EAAE,WAAW,cAAe,CAAA,CAAC;AAatC,8BAAA,CAAA,OAAO;AAGP,4BAAA,CAAA,OAAO;AAGP,4BAAA,CAAA,OAAO;AAQP,gCAAA,CAAA,OAAO;AAyCP,+BAAA,CAAA,OAAO;AA3HQ,iBAAA,IAAA,MAAA,kBAAA,EAAA,MAAA,YAAA,MAAA,QAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,UAAA,KAAA,KAAA,CAAA,QAAA,IAAA,MAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,OAAsB;AAAA,SAAA,UAAA,aAAA,oBAAA,uBAAA;AAGV,iBAAA,IAAA,MAAA,kBAAA,EAAA,MAAA,YAAA,MAAA,QAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,UAAA,KAAA,KAAA,CAAA,QAAA,IAAA,MAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,OAA2B;AAAA,SAAA,UAAA,aAAA,oBAAA,uBAAA;AAIvD,iBAAA,IAAA,MAAA,qBAAA,EAAA,MAAA,UAAA,MAAA,OAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,SAAA,KAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAW,MAEV;AAAA,SAAA,UAAA,aAAA,MAAA,0BAAA;AAQD,iBAAA,IAAA,MAAA,qBAAA,EAAA,MAAA,UAAA,MAAA,OAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,SAAA,KAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAW,MAEV;AAAA,SAAA,UAAA,aAAA,MAAA,0BAAA;AAQD,iBAAA,IAAA,MAAA,qBAAA,EAAA,MAAA,UAAA,MAAA,OAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,SAAA,KAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAW,MAEV;AAAA,SAAA,UAAA,aAAA,MAAA,0BAAA;AAQD,iBAAA,IAAA,MAAA,0BAAA,EAAA,MAAA,UAAA,MAAA,YAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,cAAA,KAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAW,WAWV;AAAA,SAAA,UAAA,aAAA,MAAA,0BAAA;AAOuD,iBAAA,IAAA,MAAA,wBAAA,EAAA,MAAA,YAAA,MAAA,cAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,gBAAA,KAAA,KAAA,CAAA,QAAA,IAAA,YAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,aAExC;AAAA,SAAA,UAAA,aAAA,0BAAA,6BAAA;AAWU,iBAAA,IAAA,MAAA,yBAAA,EAAA,MAAA,YAAA,MAAA,eAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,iBAAA,KAAA,KAAA,CAAA,QAAA,IAAA,aAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,cAA0B;AAAA,SAAA,UAAA,aAAA,2BAAA,8BAAA;AAG1B,iBAAA,IAAA,MAAA,uBAAA,EAAA,MAAA,YAAA,MAAA,aAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,eAAA,KAAA,KAAA,CAAA,QAAA,IAAA,WAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,YAA8B;AAAA,SAAA,UAAA,aAAA,yBAAA,4BAAA;AAIxD,iBAAA,IAAA,MAAA,uBAAA,EAAA,MAAA,UAAA,MAAA,SAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,WAAA,KAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAY,QAEX;AAAA,SAAA,UAAA,aAAA,MAAA,0BAAA;AAKyB,iBAAA,IAAA,MAAA,2BAAA,EAAA,MAAA,YAAA,MAAA,iBAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,mBAAA,KAAA,KAAA,CAAA,QAAA,IAAA,eAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,gBAAoC;AAAA,SAAA,UAAA,aAAA,6BAAA,gCAAA;AA0C7C,iBAAA,IAAA,MAAA,0BAAA,EAAA,MAAA,YAAA,MAAA,gBAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,kBAAA,KAAA,KAAA,CAAA,QAAA,IAAA,cAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,eAAqB;AAAA,SAAA,UAAA,aAAA,4BAAA,+BAAA;AArIxC,iBAmrCC,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QAlrCwB,GAAM,SAAmB,OACzB,GAAA,SAAS;AAAA,IAC9B,cAAc;AAAA,EACN,GAJN,kBAAkB,YAAA,uBAAA,GAAW;;;"}
|
|
1545
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"calendar.js","sources":["../../../src/elements/calendar/calendar.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  LitElement,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\n\nimport { isArrowKeyOrPageKeysPressed, sbbInputModalityDetector } from '../core/a11y.js';\nimport { readConfig } from '../core/config.js';\nimport {\n  SbbLanguageController,\n  SbbMediaMatcherController,\n  SbbMediaQueryBreakpointMediumAndAbove,\n} from '../core/controllers.js';\nimport type { DateAdapter } from '../core/datetime.js';\nimport {\n  DAYS_PER_ROW,\n  defaultDateAdapter,\n  MONTHS_PER_PAGE,\n  MONTHS_PER_ROW,\n  YEARS_PER_PAGE,\n  YEARS_PER_ROW,\n} from '../core/datetime.js';\nimport { forceType } from '../core/decorators.js';\nimport { EventEmitter } from '../core/eventing.js';\nimport {\n  i18nCalendarDateSelection,\n  i18nNextMonth,\n  i18nNextYear,\n  i18nNextYearRange,\n  i18nPreviousMonth,\n  i18nPreviousYear,\n  i18nPreviousYearRange,\n  i18nYearMonthSelection,\n} from '../core/i18n.js';\nimport type { SbbDateLike } from '../core/interfaces.js';\nimport { SbbHydrationMixin } from '../core/mixins.js';\n\nimport style from './calendar.scss?lit&inline';\n\nimport '../button/secondary-button.js';\nimport '../icon.js';\nimport '../screen-reader-only.js';\n\n/**\n * Parameters needed in year and month views to correctly calculate the next element in keyboard navigation.\n *\n * The cell's index and the element's index in its month / year batch must be distinguished:\n * the first is the index of the element in the array of all the rendered cells, while the second is the index of the element relative to its table.\n * In non-wide mode, the wto are the same, while in wide mode the cell's index can go from 0 to 47 for years and from 0 to 23 for months,\n * while the element index goes from 0 to, respectively, 23 and 11.\n */\ninterface CalendarKeyboardNavigationMonthYearViewsParameters {\n  /** The element index within its year or month range. */\n  elementIndexForWideMode: number;\n  /** In wide mode, the index of the first element in the second panel, or, alternatively, the number of elements in the first panel. */\n  offsetForWideMode: number;\n  /** The index of the last element within the element's month (or year range). */\n  lastElementIndexForWideMode: number;\n  /** The number of cells displayed in a single row, depending on the rendered view. */\n  verticalOffset: number;\n}\n\n/**\n * Parameters needed in day view to correctly calculate the next element in keyboard navigation.\n *\n * In orientation='vertical', it's not possible to rely on any array/index to calculate the element to navigate to,\n * so calculations on dates must be done, which should consider view boundaries, offsets and month's length.\n */\ninterface CalendarKeyboardNavigationDayViewParameters {\n  /** The first day rendered. */\n  firstDayInView: string | null;\n  /** The last day rendered. It depends on the 'wide' value. */\n  lastDayInView: string | null;\n  /** The offset from the first day of the week (Monday) of the first rendered month. */\n  firstMonthOffset: number;\n  /** The number of days in the first rendered month. */\n  firstMonthLength: number;\n  /** The offset from the first day of the week (Monday) of the second rendered month. If wide is false, it's equal to zero. */\n  secondMonthOffset: number;\n}\n\nexport interface Day<T = Date> {\n  value: string;\n  dayValue: string;\n  monthValue: string;\n  yearValue: string;\n  dateValue?: T;\n}\n\nexport interface Month {\n  value: string;\n  longValue: string;\n  monthValue: number;\n}\n\nexport interface Weekday {\n  long: string;\n  narrow: string;\n}\n\nexport type CalendarView = 'day' | 'month' | 'year';\n\n/**\n * It displays a calendar which allows to choose a date.\n *\n * @event {CustomEvent<T>} dateSelected - Event emitted on date selection.\n */\nexport\n@customElement('sbb-calendar')\nclass SbbCalendarElement<T = Date> extends SbbHydrationMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    dateSelected: 'dateSelected',\n  } as const;\n\n  /** If set to true, two months are displayed */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor wide: boolean = false;\n\n  /** The initial view of the calendar which should be displayed on opening. */\n  @property() public accessor view: CalendarView = 'day';\n\n  /** The minimum valid date. Takes T Object, ISOString, and Unix Timestamp (number of seconds since Jan 1, 1970). */\n  @property()\n  public set min(value: SbbDateLike<T> | null) {\n    this._min = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n  }\n  public get min(): T | null {\n    return this._min ?? null;\n  }\n  private _min?: T | null;\n\n  /** The maximum valid date. Takes T Object, ISOString, and Unix Timestamp (number of seconds since Jan 1, 1970). */\n  @property()\n  public set max(value: SbbDateLike<T> | null) {\n    this._max = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n  }\n  public get max(): T | null {\n    return this._max ?? null;\n  }\n  private _max?: T | null;\n\n  /** A configured date which acts as the current date instead of the real current date. Recommended for testing purposes. */\n  @property()\n  public set now(value: SbbDateLike<T> | null) {\n    this._now = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n  }\n  public get now(): T {\n    return this._now ?? this._dateAdapter.today();\n  }\n  private _now: T | null = null;\n\n  /** The selected date. Takes T Object, ISOString, and Unix Timestamp (number of seconds since Jan 1, 1970). */\n  @property()\n  public set selected(value: SbbDateLike<T> | null) {\n    this._selectedDate = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n    if (\n      !!this._selectedDate &&\n      (!this._isDayInRange(this._dateAdapter.toIso8601(this._selectedDate)) ||\n        this._dateFilter(this._selectedDate))\n    ) {\n      this._selected = this._dateAdapter.toIso8601(this._selectedDate);\n    } else {\n      this._selected = undefined;\n    }\n  }\n  public get selected(): T | null {\n    return this._selectedDate ?? null;\n  }\n  private _selectedDate?: T | null;\n\n  /** A function used to filter out dates. */\n  @property({ attribute: 'date-filter' })\n  public accessor dateFilter: ((date: T | null) => boolean) | null = null;\n\n  /** The orientation of days in the calendar. */\n  @property({ reflect: true }) public accessor orientation: 'horizontal' | 'vertical' =\n    'horizontal';\n\n  private _dateAdapter: DateAdapter<T> = readConfig().datetime?.dateAdapter ?? defaultDateAdapter;\n\n  /** Event emitted on date selection. */\n  private _dateSelected: EventEmitter<T> = new EventEmitter(\n    this,\n    SbbCalendarElement.events.dateSelected,\n  );\n\n  /** The currently active date. */\n  @state() private accessor _activeDate: T = this.now;\n\n  /** The selected date as ISOString. */\n  @state() private accessor _selected: string | undefined;\n\n  /** The current wide property considering property value and breakpoints. From zero to small `wide` has always to be false. */\n  @state()\n  private set _wide(wide: boolean) {\n    this.toggleAttribute('data-wide', wide);\n  }\n  private get _wide(): boolean {\n    return this.hasAttribute('data-wide');\n  }\n\n  @state() private accessor _calendarView: CalendarView = 'day';\n\n  private _nextCalendarView: CalendarView = 'day';\n\n  /** Information about the rendered day view; used in keyboard navigation. */\n  private _keyboardNavigationDayViewParameters: CalendarKeyboardNavigationDayViewParameters = {\n    firstDayInView: null,\n    lastDayInView: null,\n    firstMonthOffset: 0,\n    firstMonthLength: 0,\n    secondMonthOffset: 0,\n  };\n\n  /** A list of days, in two formats (long and single char). */\n  private _weekdays!: Weekday[];\n\n  /** Grid of calendar cells representing the dates of the month. */\n  private _weeks: Day<T>[][] = [];\n\n  /** Grid of calendar cells representing months. */\n  private _months!: Month[][];\n\n  /** Grid of calendar cells representing years. */\n  private _years!: number[][];\n\n  /** Grid of calendar cells representing years for the wide view. */\n  private _nextMonthYears!: number[][];\n\n  /** Grid of calendar cells representing the dates of the next month. */\n  private _nextMonthWeeks!: Day<T>[][];\n\n  /** An array containing all the month names in the current language. */\n  private _monthNames: string[] = this._dateAdapter.getMonthNames('long');\n\n  /** A list of buttons corresponding to days, months or years depending on the view. */\n  private get _cells(): HTMLButtonElement[] {\n    return Array.from(\n      this.shadowRoot!.querySelectorAll('.sbb-calendar__cell') ?? [],\n    ) as HTMLButtonElement[];\n  }\n\n  /** The chosen year in the year selection view. */\n  private _chosenYear?: number;\n\n  /** The chosen month in the year selection view. */\n  private _chosenMonth?: number;\n\n  /** Whether the focus should be reset on focusCell. */\n  private _resetFocus = false;\n\n  @state()\n  private accessor _initialized = false;\n\n  private _language = new SbbLanguageController(this).withHandler(() => {\n    this._monthNames = this._dateAdapter.getMonthNames('long');\n    this._createMonthRows();\n  });\n  private _mediaMatcher = new SbbMediaMatcherController(this, {\n    [SbbMediaQueryBreakpointMediumAndAbove]: () => this._init(),\n  });\n\n  public constructor() {\n    super();\n    this._createMonthRows();\n    this._setWeekdays();\n  }\n\n  private _dateFilter(date: T): boolean {\n    return this.dateFilter?.(date) ?? true;\n  }\n\n  /** Resets the active month according to the new state of the calendar. */\n  public resetPosition(): void {\n    this._resetCalendarView();\n    this._init();\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.resetPosition();\n    this.focus = () => {\n      this._resetFocus = true;\n      this._focusCell();\n    };\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (!this._initialized) {\n      return;\n    }\n\n    if (changedProperties.has('wide') || changedProperties.has('orientation')) {\n      this.resetPosition();\n    }\n\n    if (changedProperties.has('view')) {\n      this._setChosenYear();\n      this._chosenMonth = undefined;\n      this._nextCalendarView = this._calendarView = this.view;\n    }\n  }\n\n  protected override updated(changedProperties: PropertyValues<this>): void {\n    super.updated(changedProperties);\n    // The calendar needs to calculate tab-indexes on first render,\n    // and every time a date is selected or the month view changes.\n    this._setTabIndex();\n    // When changing view to year/month, the tabindex is changed, but the focused element is not,\n    // so if the navigation is done via keyboard, there's the need\n    // to call the `_focusCell()` method explicitly to correctly set the focus.\n    if (sbbInputModalityDetector.mostRecentModality === 'keyboard') {\n      this._focusCell();\n    }\n  }\n\n  /** Initializes the component. */\n  private _init(activeDate?: T): void {\n    // Due to its complexity, the calendar is only initialized on client side\n    if (isServer) {\n      return;\n    } else if (this.hydrationRequired) {\n      this.hydrationComplete.then(() => this._init());\n      return;\n    }\n\n    if (activeDate) {\n      this._assignActiveDate(activeDate);\n    }\n    this._wide =\n      (this._mediaMatcher.matches(SbbMediaQueryBreakpointMediumAndAbove) ?? false) && this.wide;\n    this._weeks = this._createWeekRows(this._activeDate);\n    this._years = this._createYearRows();\n    this._nextMonthWeeks = [[]];\n    this._nextMonthYears = [[]];\n    if (this._wide) {\n      const nextMonthDate = this._dateAdapter.addCalendarMonths(this._activeDate, 1);\n      this._nextMonthWeeks = this._createWeekRows(nextMonthDate, true);\n      this._nextMonthYears = this._createYearRows(YEARS_PER_PAGE);\n    }\n    this._initialized = true;\n  }\n\n  /** Focuses on a day cell prioritizing the selected day, the current day, and lastly, the first selectable day. */\n  private _focusCell(): void {\n    if (this._resetFocus) {\n      this._getFirstFocusable()?.focus();\n      this._resetFocus = false;\n    }\n  }\n\n  /** Creates the array of weekdays. */\n  private _setWeekdays(): void {\n    const narrowWeekdays: string[] = this._dateAdapter.getDayOfWeekNames('narrow');\n    const longWeekdays: string[] = this._dateAdapter.getDayOfWeekNames('long');\n    const weekdays: Weekday[] = longWeekdays.map((long: string, i: number) => ({\n      long,\n      narrow: narrowWeekdays[i],\n    }));\n\n    // Rotates the labels for days of the week based on the configured first day of the week.\n    const firstDayOfWeek: number = this._dateAdapter.getFirstDayOfWeek();\n    this._weekdays = weekdays.slice(firstDayOfWeek).concat(weekdays.slice(0, firstDayOfWeek));\n  }\n\n  /** Creates the rows for each week and sets the parameters used in keyboard navigation. */\n  private _createWeekRows(value: T, isSecondMonthInView = false): Day<T>[][] {\n    const dateNames: string[] = this._dateAdapter.getDateNames();\n    const daysInMonth: number = this._dateAdapter.getNumDaysInMonth(value);\n    const weekOffset: number = this._dateAdapter.getFirstWeekOffset(value);\n    if (!isSecondMonthInView) {\n      this._keyboardNavigationDayViewParameters.firstMonthLength = daysInMonth;\n      this._keyboardNavigationDayViewParameters.firstMonthOffset = weekOffset;\n      this._keyboardNavigationDayViewParameters.firstDayInView = this._dateAdapter.toIso8601(\n        this._dateAdapter.createDate(\n          this._dateAdapter.getYear(value),\n          this._dateAdapter.getMonth(value),\n          1,\n        ),\n      );\n      this._keyboardNavigationDayViewParameters.lastDayInView = this._dateAdapter.toIso8601(\n        this._dateAdapter.createDate(\n          this._dateAdapter.getYear(value),\n          this._dateAdapter.getMonth(value),\n          daysInMonth,\n        ),\n      );\n    } else {\n      this._keyboardNavigationDayViewParameters.secondMonthOffset = weekOffset;\n      this._keyboardNavigationDayViewParameters.lastDayInView = this._dateAdapter.toIso8601(\n        this._dateAdapter.createDate(\n          this._dateAdapter.getYear(value),\n          this._dateAdapter.getMonth(value),\n          daysInMonth,\n        ),\n      );\n    }\n    return this.orientation === 'horizontal'\n      ? this._createWeekRowsHorizontal(value, dateNames, daysInMonth, weekOffset)\n      : this._createWeekRowsVertical(value, dateNames, daysInMonth, weekOffset);\n  }\n\n  /**\n   * Creates the rows for each week in orientation='horizontal'.\n   *\n   * Iterates through the days of the months, creates a Day object for each and pushes it into and array.\n   * Each seven days (considering the offset at the beginning of the month) restarts from an empty array.\n   *\n   * The result is a matrix in which every row is a week (or part of it, considering offset).\n   */\n  private _createWeekRowsHorizontal(\n    value: T,\n    dateNames: string[],\n    daysInMonth: number,\n    weekOffset: number,\n  ): Day<T>[][] {\n    const weeks: Day<T>[][] = [[]];\n    for (let i = 0, cell = weekOffset; i < daysInMonth; i++, cell++) {\n      if (cell === DAYS_PER_ROW) {\n        weeks.push([]);\n        cell = 0;\n      }\n      const date = this._dateAdapter.createDate(\n        this._dateAdapter.getYear(value),\n        this._dateAdapter.getMonth(value),\n        i + 1,\n      )!;\n      weeks[weeks.length - 1].push({\n        value: this._dateAdapter.toIso8601(date),\n        dateValue: date,\n        dayValue: dateNames[i],\n        monthValue: String(this._dateAdapter.getMonth(date)),\n        yearValue: String(this._dateAdapter.getYear(date)),\n      });\n    }\n    return weeks;\n  }\n\n  /**\n   * Creates the rows for each week in orientation='vertical'.\n   *\n   * Creates a matrix with seven empty rows.\n   * Iterates through the days of the months, creates a Day object for each\n   * and pushes it into the correct array considering the offset at the beginning of the month.\n   * Each seven days (including offset) restarts from the first.\n   *\n   * The result is a matrix in which every row is a set of weekdays, so:\n   * - row 0: all the Mondays;\n   * - row 1: all the Tuesdays;\n   * - ...\n   * - row 7: all the Sundays.\n   */\n  private _createWeekRowsVertical(\n    value: T,\n    dateNames: string[],\n    daysInMonth: number,\n    weekOffset: number,\n  ): Day<T>[][] {\n    const weeks: Day<T>[][] = Array.from({ length: DAYS_PER_ROW }, () => []);\n    for (let i = 0, cell = weekOffset; i < daysInMonth; i++, cell++) {\n      if (cell === DAYS_PER_ROW) {\n        cell = 0;\n      }\n      const date = this._dateAdapter.createDate(\n        this._dateAdapter.getYear(value),\n        this._dateAdapter.getMonth(value),\n        i + 1,\n      )!;\n      weeks[cell].push({\n        value: this._dateAdapter.toIso8601(date),\n        dateValue: date,\n        dayValue: dateNames[i],\n        monthValue: String(this._dateAdapter.getMonth(date)),\n        yearValue: String(this._dateAdapter.getYear(date)),\n      });\n    }\n    return weeks;\n  }\n\n  /** Creates the rows for the month selection view. */\n  private _createMonthRows(): void {\n    const shortNames: string[] = this._dateAdapter.getMonthNames('short');\n    const months: Month[] = new Array(12).fill(null).map(\n      (_, i: number): Month => ({\n        value: shortNames[i],\n        longValue: this._monthNames[i],\n        monthValue: i + 1,\n      }),\n    );\n    const rows: number = 12 / MONTHS_PER_ROW;\n    const monthArray: Month[][] = [];\n    for (let i: number = 0; i < rows; i++) {\n      monthArray.push(months.slice(MONTHS_PER_ROW * i, MONTHS_PER_ROW * (i + 1)));\n    }\n    this._months = monthArray;\n  }\n\n  /** Creates the rows for the year selection view. */\n  private _createYearRows(offset: number = 0): number[][] {\n    const startValueYearView: number = this._getStartValueYearView();\n    const allYears: number[] = new Array(YEARS_PER_PAGE)\n      .fill(0)\n      .map((_, i: number) => startValueYearView + offset + i);\n    const rows: number = YEARS_PER_PAGE / YEARS_PER_ROW;\n    const yearArray: number[][] = [];\n    for (let i: number = 0; i < rows; i++) {\n      yearArray.push(allYears.slice(YEARS_PER_ROW * i, YEARS_PER_ROW * (i + 1)));\n    }\n    return yearArray;\n  }\n\n  /**\n   * Calculates the first year that will be shown in the year selection panel.\n   * If `minDate` and `maxDate` are both null, the starting year is calculated as\n   * the multiple of YEARS_PER_PAGE closest to and less than activeDate,\n   * e.g., with `YEARS_PER_PAGE` = 24 and `activeDate` = 2020, the function will return 2016 (24 * 83),\n   * while with `activeDate` = 2000, the function will return 1992 (24 * 82).\n   * If `minDate` is not null, it returns the corresponding year; if `maxDate` is not null,\n   * it returns the corresponding year minus `YEARS_PER_PAGE`, so that the `maxDate` is the last rendered year.\n   * If both are not null, `maxDate` has priority over `minDate`.\n   */\n  private _getStartValueYearView(): number {\n    let startingYear = 0;\n    if (this.max) {\n      startingYear = this._dateAdapter.getYear(this.max) - YEARS_PER_PAGE + 1;\n    } else if (this.min) {\n      startingYear = this._dateAdapter.getYear(this.min);\n    }\n    const activeYear = this._dateAdapter.getYear(this._activeDate);\n    return (\n      activeYear -\n      ((((activeYear - startingYear) % YEARS_PER_PAGE) + YEARS_PER_PAGE) % YEARS_PER_PAGE)\n    );\n  }\n\n  /** Checks if date is within the min-max range. */\n  private _isDayInRange(date: string): boolean {\n    if (!this.min && !this.max) {\n      return true;\n    }\n    const isBeforeMin: boolean =\n      this._dateAdapter.isValid(this.min) &&\n      this._dateAdapter.compareDate(this.min!, this._dateAdapter.deserialize(date)!) > 0;\n    const isAfterMax: boolean =\n      this._dateAdapter.isValid(this.max) &&\n      this._dateAdapter.compareDate(this.max!, this._dateAdapter.deserialize(date)!) < 0;\n    return !(isBeforeMin || isAfterMax);\n  }\n\n  /** Checks if date is within the min-max range in month view. */\n  private _isMonthInRange(month: number, year: number): boolean {\n    if (!this.min && !this.max) {\n      return true;\n    }\n\n    const isBeforeMin: boolean =\n      this._dateAdapter.isValid(this.min) &&\n      (year < this._dateAdapter.getYear(this.min!) ||\n        (year === this._dateAdapter.getYear(this.min!) &&\n          month < this._dateAdapter.getMonth(this.min!)));\n\n    const isAfterMax: boolean =\n      this._dateAdapter.isValid(this.max) &&\n      (year > this._dateAdapter.getYear(this.max!) ||\n        (year === this._dateAdapter.getYear(this.max!) &&\n          month > this._dateAdapter.getMonth(this.max!)));\n\n    return !(isBeforeMin || isAfterMax);\n  }\n\n  /** Checks if date is within the min-max range in year view. */\n  private _isYearInRange(year: number): boolean {\n    if (!this.min && !this.max) {\n      return true;\n    }\n    const isBeforeMin: boolean =\n      this._dateAdapter.isValid(this.min) && this._dateAdapter.getYear(this.min!) > year;\n    const isAfterMax: boolean =\n      this._dateAdapter.isValid(this.max) && this._dateAdapter.getYear(this.max!) < year;\n    return !(isBeforeMin || isAfterMax);\n  }\n\n  // Implementation adapted from https://github.com/angular/components/blob/main/src/material/datepicker/year-view.ts#L366\n  private _isMonthFilteredOut(month: number, year: number): boolean {\n    if (!this.dateFilter) {\n      return true;\n    }\n\n    const firstOfMonth = this._dateAdapter.createDate(year, month, 1)!;\n    for (\n      let date: T = firstOfMonth;\n      this._dateAdapter.getMonth(date) == month;\n      date = this._dateAdapter.addCalendarDays(date, 1)\n    ) {\n      if (this.dateFilter(date)) {\n        return true;\n      }\n    }\n\n    return false;\n  }\n\n  // Implementation adapted from https://github.com/angular/components/blob/main/src/material/datepicker/multi-year-view.ts#L351\n  private _isYearFilteredOut(year: number): boolean {\n    if (!this.dateFilter) {\n      return true;\n    }\n\n    const firstOfYear = this._dateAdapter.createDate(year, 1, 1)!;\n    for (\n      let date: T = firstOfYear;\n      this._dateAdapter.getYear(date) == year;\n      date = this._dateAdapter.addCalendarDays(date, 1)\n    ) {\n      if (this.dateFilter(date)) {\n        return true;\n      }\n    }\n\n    return false;\n  }\n\n  /** Emits the selected date and sets it internally. */\n  private _selectDate(day: string): void {\n    this._chosenMonth = undefined;\n    this._setChosenYear();\n    if (this._selected !== day) {\n      this._selected = day;\n      this._dateSelected.emit(this._dateAdapter.deserialize(day)!);\n    }\n  }\n\n  private _setChosenYear(): void {\n    if (this.view === 'month') {\n      this._chosenYear = this._dateAdapter.getYear(\n        this._dateAdapter.deserialize(this._selected) ?? this.selected ?? this.now,\n      );\n    } else {\n      this._chosenYear = undefined;\n    }\n  }\n\n  private _assignActiveDate(date: T): void {\n    if (this.min && this._dateAdapter.compareDate(this.min, date) > 0) {\n      this._activeDate = this.min;\n      return;\n    }\n    if (this.max && this._dateAdapter.compareDate(this.max, date) < 0) {\n      this._activeDate = this.max;\n      return;\n    }\n    this._activeDate = date;\n  }\n\n  /** Goes to the month identified by the shift. */\n  private _goToDifferentMonth(months: number): void {\n    this._init(this._dateAdapter.addCalendarMonths(this._activeDate, months));\n  }\n\n  private _goToDifferentYear(years: number): void {\n    this._chosenYear! += years;\n    // Can't use `_assignActiveDate(...)` here, because it will set it to min/max value if argument is out of range\n    this._activeDate = this._dateAdapter.createDate(\n      this._chosenYear!,\n      this._dateAdapter.getMonth(this._activeDate),\n      this._dateAdapter.getDate(this._activeDate),\n    );\n    this._init();\n  }\n\n  private _goToDifferentYearRange(years: number): void {\n    this._init(this._dateAdapter.addCalendarYears(this._activeDate, years));\n  }\n\n  private _prevDisabled(prevDate: T): boolean {\n    if (!this.min) {\n      return false;\n    }\n    return this._dateAdapter.compareDate(prevDate, this.min) < 0;\n  }\n\n  private _nextDisabled(nextDate: T): boolean {\n    if (!this.max) {\n      return false;\n    }\n    return this._dateAdapter.compareDate(nextDate, this.max) > 0;\n  }\n\n  /** Checks if the \"previous month\" button should be disabled. */\n  private _previousMonthDisabled(): boolean {\n    const prevMonth = this._dateAdapter.addCalendarDays(\n      this._activeDate,\n      this._dateAdapter.getDate(this._activeDate) * -1,\n    );\n    return this._prevDisabled(prevMonth);\n  }\n\n  /** Checks if the \"next month\" button should be disabled. */\n  private _nextMonthDisabled(): boolean {\n    let nextMonth = this._dateAdapter.addCalendarMonths(this._activeDate, this._wide ? 2 : 1);\n    nextMonth = this._dateAdapter.createDate(\n      this._dateAdapter.getYear(nextMonth),\n      this._dateAdapter.getMonth(nextMonth),\n      1,\n    );\n    return this._nextDisabled(nextMonth);\n  }\n\n  /** Checks if the \"previous year\" button should be disabled. */\n  private _previousYearDisabled(): boolean {\n    const prevYear = this._dateAdapter.createDate(\n      this._dateAdapter.getYear(this._activeDate) - 1,\n      12,\n      31,\n    );\n    return this._prevDisabled(prevYear);\n  }\n\n  /** Checks if the \"next year\" button should be disabled. */\n  private _nextYearDisabled(): boolean {\n    const nextYear = this._dateAdapter.createDate(\n      this._dateAdapter.getYear(this._activeDate) + (this._wide ? 2 : 1),\n      1,\n      1,\n    );\n    return this._nextDisabled(nextYear);\n  }\n\n  /** Checks if the \"previous year\" button should be disabled in year view. */\n  private _previousYearRangeDisabled(): boolean {\n    const prevYear = this._dateAdapter.createDate(this._years[0][0] - 1, 12, 31);\n    return this._prevDisabled(prevYear);\n  }\n\n  /** Checks if the \"next year\" button should be disabled in year view. */\n  private _nextYearRangeDisabled(): boolean {\n    const years = this._wide ? this._nextMonthYears : this._years;\n    const lastYearRange = years[years.length - 1];\n    const lastYear = lastYearRange[lastYearRange.length - 1];\n    const nextYear = this._dateAdapter.createDate(lastYear + 1, 1, 1);\n    return this._nextDisabled(nextYear);\n  }\n\n  private _handleTableBlur(eventTarget: HTMLElement): void {\n    if (eventTarget?.localName !== 'button') {\n      this._setTabIndex();\n    }\n  }\n\n  private _setTabIndex(): void {\n    Array.from(\n      this.shadowRoot!.querySelectorAll('.sbb-calendar__cell[tabindex=\"0\"]') ?? [],\n    ).forEach((day) => ((day as HTMLElement).tabIndex = -1));\n    const firstFocusable = this._getFirstFocusable();\n    if (firstFocusable) {\n      firstFocusable.tabIndex = 0;\n    }\n  }\n\n  /** Get the element in the calendar to assign focus. */\n  private _getFirstFocusable(): HTMLButtonElement {\n    const active = this._selected ? this._dateAdapter.deserialize(this._selected)! : this.now;\n    let firstFocusable =\n      this.shadowRoot!.querySelector('.sbb-calendar__selected') ??\n      this.shadowRoot!.querySelector(`[value=\"${this._dateAdapter.toIso8601(active)}\"]`) ??\n      this.shadowRoot!.querySelector(`[data-month=\"${this._dateAdapter.getMonth(active)}\"]`) ??\n      this.shadowRoot!.querySelector(`[data-year=\"${this._dateAdapter.getYear(active)}\"]`);\n    if (!firstFocusable || (firstFocusable as HTMLButtonElement)?.disabled) {\n      firstFocusable =\n        this._calendarView === 'day'\n          ? this._getFirstFocusableDay()\n          : this.shadowRoot!.querySelector('.sbb-calendar__cell:not([disabled])');\n    }\n    return (firstFocusable as HTMLButtonElement) || null;\n  }\n\n  /**\n   * In `day` view in `vertical` orientation,\n   * if the first of the month is not a Monday, it is not the first rendered element in the table,\n   * so `this.shadowRoot!.querySelector('.sbb-calendar__cell:not([disabled])')` will return a wrong value.\n   *\n   * To solve this, the element with the lowest `value` is taken (ISO String are ordered).\n   */\n  private _getFirstFocusableDay(): HTMLButtonElement | null {\n    const daysInView: HTMLButtonElement[] = Array.from(\n      this.shadowRoot!.querySelectorAll('.sbb-calendar__cell:not([disabled])'),\n    );\n    if (!daysInView || daysInView.length === 0) {\n      return null;\n    } else {\n      const firstElement = daysInView.map((e: HTMLButtonElement): string => e.value).sort()[0];\n      return this.shadowRoot!.querySelector(`.sbb-calendar__cell[value=\"${firstElement}\"]`);\n    }\n  }\n\n  private _handleKeyboardEvent(event: KeyboardEvent, day?: Day<T>): void {\n    if (isArrowKeyOrPageKeysPressed(event)) {\n      event.preventDefault();\n    }\n    // Gets the currently rendered table's cell;\n    // they could be days, months or years based on the current selection view.\n    // If `wide` is true, years are doubled in number and days are (roughly) doubled too, affecting the `index` calculation.\n    const cells: HTMLButtonElement[] = this._cells;\n    const index: number = cells.findIndex((e: HTMLButtonElement) => e === event.target);\n    let nextEl: HTMLButtonElement;\n    if (day) {\n      nextEl = this._navigateByKeyboardDayView(event, index, cells, day);\n    } else {\n      nextEl = this._navigateByKeyboard(event, index, cells);\n    }\n    const activeEl: HTMLButtonElement = this.shadowRoot!.activeElement as HTMLButtonElement;\n    if (nextEl !== activeEl) {\n      (nextEl as HTMLButtonElement).tabIndex = 0;\n      nextEl?.focus();\n      (activeEl as HTMLButtonElement).tabIndex = -1;\n    }\n  }\n\n  private _navigateByKeyboardDayView(\n    evt: KeyboardEvent,\n    index: number,\n    cells: HTMLButtonElement[],\n    day: Day<T>,\n  ): HTMLButtonElement {\n    const arrowsOffset =\n      this.orientation === 'horizontal'\n        ? { leftRight: 1, upDown: DAYS_PER_ROW }\n        : { leftRight: DAYS_PER_ROW, upDown: 1 };\n    const offsetForVertical: number =\n      index < this._keyboardNavigationDayViewParameters.firstMonthLength\n        ? this._keyboardNavigationDayViewParameters.firstMonthOffset\n        : this._keyboardNavigationDayViewParameters.secondMonthOffset;\n\n    switch (evt.key) {\n      case 'ArrowUp':\n        return this._findDayArrows(cells, index, day.dateValue!, -arrowsOffset.upDown);\n      case 'ArrowDown':\n        return this._findDayArrows(cells, index, day.dateValue!, arrowsOffset.upDown);\n      case 'ArrowLeft':\n        return this._findDayArrows(cells, index, day.dateValue!, -arrowsOffset.leftRight);\n      case 'ArrowRight':\n        return this._findDayArrows(cells, index, day.dateValue!, arrowsOffset.leftRight);\n      case 'PageUp': {\n        if (this.orientation === 'horizontal') {\n          const firstOfWeek: number = +day.dayValue % DAYS_PER_ROW || DAYS_PER_ROW;\n          const delta: number = firstOfWeek - +day.dayValue;\n          return this._findDayPageUpDown(cells, index, day, delta, arrowsOffset.upDown);\n        } else {\n          const weekNumber: number = Math.ceil((+day.dayValue + offsetForVertical) / DAYS_PER_ROW);\n          const firstOfWeek: number = (weekNumber - 1) * DAYS_PER_ROW - offsetForVertical + 1;\n          const delta: number = firstOfWeek - +day.dayValue;\n          return this._findDayPageUpDown(cells, index, day, delta, arrowsOffset.upDown);\n        }\n      }\n      case 'PageDown': {\n        if (this.orientation === 'horizontal') {\n          const monthInBounds = +day.monthValue + 1 > 12 ? 1 : +day.monthValue + 1;\n          const yearInBounds = +day.monthValue + 1 > 12 ? +day.yearValue + 1 : +day.yearValue;\n          const firstNextMonth: T = this._dateAdapter.createDate(yearInBounds, monthInBounds, 1);\n          const lastOfMonth: number = this._dateAdapter.getDate(\n            this._dateAdapter.addCalendarDays(firstNextMonth, -1),\n          );\n          const delta: number =\n            Math.trunc((lastOfMonth - +day.dayValue!) / DAYS_PER_ROW) * DAYS_PER_ROW;\n          return this._findDayPageUpDown(cells, index, day, delta, -arrowsOffset.upDown);\n        } else {\n          const weekNumber: number = Math.ceil((+day.dayValue + offsetForVertical) / DAYS_PER_ROW);\n          const lastOfWeek: number = weekNumber * DAYS_PER_ROW - offsetForVertical;\n          const delta: number = lastOfWeek - +day.dayValue;\n          return this._findDayPageUpDown(cells, index, day, delta, -arrowsOffset.upDown);\n        }\n      }\n      case 'Home': {\n        return this._findDayFirst(cells, index, day, 1);\n      }\n      case 'End': {\n        const monthInBounds = +day.monthValue + 1 > 12 ? 1 : +day.monthValue + 1;\n        const yearInBounds = +day.monthValue + 1 > 12 ? +day.yearValue + 1 : +day.yearValue;\n        const firstNextMonth: T = this._dateAdapter.createDate(yearInBounds, monthInBounds, 1);\n        return this._findDayLast(cells, index, firstNextMonth);\n      }\n      default:\n        return cells[index];\n    }\n  }\n\n  private _isDayOutOfView(date: string): boolean {\n    return (\n      date < this._keyboardNavigationDayViewParameters.firstDayInView! ||\n      date > this._keyboardNavigationDayViewParameters.lastDayInView!\n    );\n  }\n\n  private _findDayArrows(\n    cells: HTMLButtonElement[],\n    index: number,\n    date: T,\n    delta: number,\n  ): HTMLButtonElement {\n    const newDateValue = this._dateAdapter.toIso8601(\n      this._dateAdapter.addCalendarDays(date, delta),\n    );\n    if (this._isDayOutOfView(newDateValue)) {\n      return cells[index];\n    }\n    const nextCell = cells.find((e) => e.value === newDateValue);\n    if (!nextCell || nextCell.disabled) {\n      return this._findDayArrows(cells, index, this._dateAdapter.deserialize(newDateValue)!, delta);\n    }\n    return nextCell;\n  }\n\n  private _findDayPageUpDown(\n    cells: HTMLButtonElement[],\n    index: number,\n    day: Day<T>,\n    delta: number,\n    deltaIfDisabled: number,\n  ): HTMLButtonElement {\n    const newDateValue = this._dateAdapter.toIso8601(\n      this._dateAdapter.addCalendarDays(day.dateValue!, delta),\n    );\n    if (this._isDayOutOfView(newDateValue)) {\n      return cells[index];\n    }\n    const nextCell = cells.find((e) => e.value === newDateValue);\n    if (!nextCell || nextCell.disabled) {\n      return this._findDayPageUpDown(cells, index, day, delta + deltaIfDisabled, deltaIfDisabled);\n    }\n    return nextCell;\n  }\n\n  private _findDayFirst(\n    cells: HTMLButtonElement[],\n    index: number,\n    day: Day<T>,\n    date: number,\n  ): HTMLButtonElement {\n    const newDateValue = this._dateAdapter.toIso8601(\n      this._dateAdapter.createDate(+day.yearValue, +day.monthValue, date),\n    );\n    if (this._isDayOutOfView(newDateValue)) {\n      return cells[index];\n    }\n    const nextCell = cells.find((e) => e.value === newDateValue);\n    if (!nextCell || nextCell.disabled) {\n      return this._findDayFirst(cells, index, day, date + 1);\n    }\n    return nextCell;\n  }\n\n  private _findDayLast(\n    cells: HTMLButtonElement[],\n    index: number,\n    firstNextMonth: T,\n  ): HTMLButtonElement {\n    const newDateValue = this._dateAdapter.toIso8601(\n      this._dateAdapter.addCalendarDays(firstNextMonth, -1),\n    );\n    if (this._isDayOutOfView(newDateValue)) {\n      return cells[index];\n    }\n    const nextCell = cells.find((e) => e.value === newDateValue);\n    if (!nextCell || nextCell.disabled) {\n      return this._findDayLast(cells, index, this._dateAdapter.deserialize(newDateValue)!);\n    }\n    return nextCell;\n  }\n\n  /**\n   * Gets the index of the element to move to, based on a list of elements (which can be potentially disabled),\n   * the keyboard input and the position of the current element in the list.\n   * In the day view, the `day?: Day` parameter is mandatory for calculation,\n   * while in month and year view it's not due to the fixed amount of rendered cells.\n   */\n  private _navigateByKeyboard(\n    evt: KeyboardEvent,\n    index: number,\n    cells: HTMLButtonElement[],\n  ): HTMLButtonElement {\n    const {\n      elementIndexForWideMode,\n      offsetForWideMode,\n      lastElementIndexForWideMode,\n      verticalOffset,\n    }: CalendarKeyboardNavigationMonthYearViewsParameters =\n      this._calculateParametersForKeyboardNavigation(index, this._calendarView === 'year');\n\n    switch (evt.key) {\n      case 'ArrowUp':\n        return this._findNext(cells, index, -verticalOffset);\n      case 'ArrowDown':\n        return this._findNext(cells, index, verticalOffset);\n      case 'ArrowLeft':\n        return this._findNext(cells, index, -1);\n      case 'ArrowRight':\n        return this._findNext(cells, index, 1);\n      case 'Home':\n        return this._findFirst(cells, offsetForWideMode);\n      case 'PageUp':\n        return this._findFirstOnColumn(\n          cells,\n          elementIndexForWideMode,\n          offsetForWideMode,\n          verticalOffset,\n        );\n      case 'PageDown':\n        return this._findLastOnColumn(cells, index, lastElementIndexForWideMode, verticalOffset);\n      case 'End':\n        return this._findLast(cells, lastElementIndexForWideMode - 1);\n      default:\n        return cells[index];\n    }\n  }\n\n  /**\n   * Calculates the parameters needed in keyboard navigation in year and month view.\n   * @param index The starting element's index in the cell array.\n   * @param isYearView Whether the displayed `view` is the year one.\n   */\n  private _calculateParametersForKeyboardNavigation(\n    index: number,\n    isYearView: boolean,\n  ): CalendarKeyboardNavigationMonthYearViewsParameters {\n    const elementsPerPage = isYearView ? YEARS_PER_PAGE : MONTHS_PER_PAGE;\n    const offset: number = Math.trunc(index / elementsPerPage) * elementsPerPage;\n    const indexInView: number = offset === 0 ? index : index - elementsPerPage;\n    return {\n      verticalOffset: isYearView ? YEARS_PER_ROW : MONTHS_PER_ROW,\n      elementIndexForWideMode: indexInView,\n      offsetForWideMode: index - indexInView,\n      lastElementIndexForWideMode: offset === 0 ? elementsPerPage : elementsPerPage * 2,\n    };\n  }\n\n  /**\n   * Gets the next element of the provided array starting from `index` by adding `delta`.\n   * If the found element is disabled, it continues adding `delta` until it finds an enabled one in the array bounds.\n   */\n  private _findNext(days: HTMLButtonElement[], index: number, delta: number): HTMLButtonElement {\n    let nextIndex = index + delta;\n    while (nextIndex < days.length && days[nextIndex]?.disabled) {\n      nextIndex += delta;\n    }\n    return days[nextIndex] ?? days[index];\n  }\n\n  /** Find the first enabled element in the provided array. */\n  private _findFirst(days: HTMLButtonElement[], firstOfCurrentMonth: number): HTMLButtonElement {\n    return !days[firstOfCurrentMonth].disabled\n      ? days[firstOfCurrentMonth]\n      : this._findNext(days, firstOfCurrentMonth, 1);\n  }\n\n  /** Find the last enabled element in the provided array. */\n  private _findLast(days: HTMLButtonElement[], lastOfCurrentMonth: number): HTMLButtonElement {\n    return !days[lastOfCurrentMonth].disabled\n      ? days[lastOfCurrentMonth]\n      : this._findNext(days, lastOfCurrentMonth, -1);\n  }\n\n  /** Find the first enabled element in the same column of the provided array. */\n  private _findFirstOnColumn(\n    days: HTMLButtonElement[],\n    index: number,\n    offset: number,\n    verticalOffset: number,\n  ): HTMLButtonElement {\n    const nextIndex = (index % verticalOffset) + offset;\n    return !days[nextIndex].disabled\n      ? days[nextIndex]\n      : this._findNext(days, nextIndex, verticalOffset);\n  }\n\n  /** Find the last enabled element in the same column of the provided array. */\n  private _findLastOnColumn(\n    days: HTMLButtonElement[],\n    index: number,\n    offset: number,\n    verticalOffset: number,\n  ): HTMLButtonElement {\n    const nextIndex = index + Math.trunc((offset - index - 1) / verticalOffset) * verticalOffset;\n    return !days[nextIndex].disabled\n      ? days[nextIndex]\n      : this._findNext(days, nextIndex, -verticalOffset);\n  }\n\n  private _resetCalendarView(initTransition = false): void {\n    this._resetFocus = true;\n    this._activeDate = this.selected ?? this.now;\n    this._setChosenYear();\n    this._chosenMonth = undefined;\n    this._nextCalendarView = this._calendarView = this.view;\n\n    if (initTransition) {\n      this._startTableTransition();\n    }\n  }\n\n  /** Render the view for the day selection. */\n  private _renderDayView(): TemplateResult {\n    const nextMonthActiveDate = this._wide\n      ? this._dateAdapter.addCalendarMonths(this._activeDate, 1)\n      : undefined;\n    return html`\n      <div class=\"sbb-calendar__controls\">\n        ${this._getArrow(\n          'left',\n          () => this._goToDifferentMonth(-1),\n          i18nPreviousMonth[this._language.current],\n          this._previousMonthDisabled(),\n        )}\n        <div class=\"sbb-calendar__controls-month\">\n          ${this._createLabelForDayView(this._activeDate)}\n          ${this._wide ? this._createLabelForDayView(nextMonthActiveDate!) : nothing}\n          <sbb-screen-reader-only role=\"status\">\n            ${this._createAriaLabelForDayView(this._activeDate, nextMonthActiveDate!)}\n          </sbb-screen-reader-only>\n        </div>\n        ${this._getArrow(\n          'right',\n          () => this._goToDifferentMonth(1),\n          i18nNextMonth[this._language.current],\n          this._nextMonthDisabled(),\n        )}\n      </div>\n      <div class=\"sbb-calendar__table-container sbb-calendar__table-day-view\">\n        ${this.orientation === 'horizontal'\n          ? html`\n              ${this._createDayTable(this._weeks)}\n              ${this._wide ? this._createDayTable(this._nextMonthWeeks) : nothing}\n            `\n          : html`\n              ${this._createDayTableVertical(this._weeks)}\n              ${this._wide\n                ? this._createDayTableVertical(this._nextMonthWeeks, nextMonthActiveDate)\n                : nothing}\n            `}\n      </div>\n    `;\n  }\n\n  /** Creates the label with the month for the daily view. */\n  private _createLabelForDayView(d: T): TemplateResult {\n    const monthLabel = `${\n      this._monthNames[this._dateAdapter.getMonth(d) - 1]\n    } ${this._dateAdapter.getYear(d)}`;\n    return html`\n      <button\n        type=\"button\"\n        class=\"sbb-calendar__date-selection sbb-calendar__controls-change-date\"\n        aria-label=\"${i18nYearMonthSelection[this._language.current]} ${monthLabel}\"\n        @click=${() => {\n          this._resetFocus = true;\n          this._nextCalendarView = 'year';\n          this._startTableTransition();\n        }}\n      >\n        ${monthLabel}\n        <sbb-icon name=\"chevron-small-down-small\"></sbb-icon>\n      </button>\n    `;\n  }\n\n  /** Creates the aria-label for the daily view. */\n  private _createAriaLabelForDayView(...dates: T[]): string {\n    let monthLabel = '';\n    for (const d of dates) {\n      if (d) {\n        monthLabel += `${\n          this._monthNames[this._dateAdapter.getMonth(d) - 1]\n        } ${this._dateAdapter.getYear(d)} `;\n      }\n    }\n    return monthLabel;\n  }\n\n  /** Creates the calendar table for the daily view. */\n  private _createDayTable(weeks: Day<T>[][]): TemplateResult {\n    const today: string = this._dateAdapter.toIso8601(this.now);\n    return html`\n      <table\n        class=\"sbb-calendar__table\"\n        @focusout=${(event: FocusEvent) =>\n          this._handleTableBlur(event.relatedTarget as HTMLElement)}\n        @animationend=${(e: AnimationEvent) => this._tableAnimationEnd(e)}\n      >\n        <thead class=\"sbb-calendar__table-header\">\n          <tr class=\"sbb-calendar__table-header-row\">\n            ${this._weekdays.map(\n              (day: Weekday) => html`\n                <th class=\"sbb-calendar__table-header\">\n                  <sbb-screen-reader-only>${day.long}</sbb-screen-reader-only>\n                  <span aria-hidden=\"true\">${day.narrow}</span>\n                </th>\n              `,\n            )}\n          </tr>\n        </thead>\n        <tbody class=\"sbb-calendar__table-body\">\n          ${weeks.map((week: Day<T>[], rowIndex: number) => {\n            const firstRowOffset: number = DAYS_PER_ROW - week.length;\n            if (rowIndex === 0 && firstRowOffset) {\n              return html`\n                <tr>\n                  ${[...Array(firstRowOffset).keys()].map(\n                    () => html`<td class=\"sbb-calendar__table-data\"></td>`,\n                  )}\n                  ${this._createDayCells(week, today)}\n                </tr>\n              `;\n            }\n            return html`<tr>\n              ${this._createDayCells(week, today)}\n            </tr>`;\n          })}\n        </tbody>\n      </table>\n    `;\n  }\n\n  /* Creates the table in orientation='vertical'. */\n  private _createDayTableVertical(weeks: Day<T>[][], nextMonthActiveDate?: T): TemplateResult {\n    const today: string = this._dateAdapter.toIso8601(this.now);\n    const weekOffset = this._dateAdapter.getFirstWeekOffset(\n      nextMonthActiveDate ?? this._activeDate,\n    );\n    return html`\n      <table\n        class=\"sbb-calendar__table\"\n        @focusout=${(event: FocusEvent) =>\n          this._handleTableBlur(event.relatedTarget as HTMLElement)}\n        @animationend=${(e: AnimationEvent) => this._tableAnimationEnd(e)}\n      >\n        <tbody class=\"sbb-calendar__table-body\">\n          ${weeks.map((week: Day<T>[], rowIndex: number) => {\n            const weekday = this._weekdays[rowIndex];\n            return html`\n              <tr>\n                ${!nextMonthActiveDate\n                  ? html` <td class=\"sbb-calendar__table-header\">\n                      <sbb-screen-reader-only>${weekday.long}</sbb-screen-reader-only>\n                      <span aria-hidden=\"true\">${weekday.narrow}</span>\n                    </td>`\n                  : nothing}\n                ${rowIndex < weekOffset\n                  ? html`<td class=\"sbb-calendar__table-data\"></td>`\n                  : nothing}\n                ${this._createDayCells(week, today)}\n              </tr>\n            `;\n          })}\n        </tbody>\n      </table>\n    `;\n  }\n\n  /** Creates the cells for the daily view. */\n  private _createDayCells(week: Day<T>[], today: string): TemplateResult[] {\n    return week.map((day: Day<T>) => {\n      const isOutOfRange = !this._isDayInRange(day.value);\n      const isFilteredOut = !this._dateFilter(this._dateAdapter.deserialize(day.value)!);\n      const selected: boolean = !!this._selected && day.value === this._selected;\n      const isToday = day.value === today;\n      return html`\n        <td\n          class=${classMap({\n            'sbb-calendar__table-data': true,\n            'sbb-calendar__table-data-selected': selected,\n          })}\n        >\n          <button\n            class=${classMap({\n              'sbb-calendar__cell': true,\n              'sbb-calendar__day': true,\n              'sbb-calendar__cell-current': isToday,\n              'sbb-calendar__selected': selected,\n              'sbb-calendar__crossed-out': !isOutOfRange && isFilteredOut,\n            })}\n            @click=${() => this._selectDate(day.value)}\n            ?disabled=${isOutOfRange || isFilteredOut}\n            value=${day.value}\n            type=\"button\"\n            aria-label=${this._dateAdapter.getAccessibilityFormatDate(day.value)}\n            aria-pressed=${selected}\n            aria-disabled=${isOutOfRange || isFilteredOut}\n            aria-current=${isToday ? 'date' : nothing}\n            tabindex=\"-1\"\n            @keydown=${(evt: KeyboardEvent) => this._handleKeyboardEvent(evt, day)}\n            sbb-popover-close\n          >\n            ${day.dayValue}\n          </button>\n        </td>\n      `;\n    });\n  }\n\n  /** Render the view for the month selection. */\n  private _renderMonthView(): TemplateResult {\n    return html`\n      <div class=\"sbb-calendar__controls\">\n        ${this._getArrow(\n          'left',\n          () => this._goToDifferentYear(-1),\n          i18nPreviousYear[this._language.current],\n          this._previousYearDisabled(),\n        )}\n        <div class=\"sbb-calendar__controls-month\">${this._createLabelForMonthView()}</div>\n        ${this._getArrow(\n          'right',\n          () => this._goToDifferentYear(1),\n          i18nNextYear[this._language.current],\n          this._nextYearDisabled(),\n        )}\n      </div>\n      <div class=\"sbb-calendar__table-container sbb-calendar__table-month-view\">\n        ${this._createMonthTable(this._months, this._chosenYear!)}\n        ${this._wide ? this._createMonthTable(this._months, this._chosenYear! + 1) : nothing}\n      </div>\n    `;\n  }\n\n  /** Creates the label with the year for the monthly view. */\n  private _createLabelForMonthView(): TemplateResult {\n    return html` <button\n        type=\"button\"\n        id=\"sbb-calendar__month-selection\"\n        class=\"sbb-calendar__controls-change-date\"\n        aria-label=${`${i18nCalendarDateSelection[this._language.current]} ${this._chosenYear}`}\n        @click=${() => this._resetCalendarView(true)}\n      >\n        ${this._chosenYear} ${this._wide ? ` - ${this._chosenYear! + 1}` : nothing}\n        <sbb-icon name=\"chevron-small-up-small\"></sbb-icon>\n      </button>\n      <sbb-screen-reader-only role=\"status\"> ${this._chosenYear} </sbb-screen-reader-only>`;\n  }\n\n  /** Creates the table for the month selection view. */\n  private _createMonthTable(months: Month[][], year: number): TemplateResult {\n    return html`\n      <table\n        class=\"sbb-calendar__table\"\n        @animationend=${(e: AnimationEvent) => this._tableAnimationEnd(e)}\n      >\n        ${this._wide\n          ? html`<thead class=\"sbb-calendar__table-header\" aria-hidden=\"true\">\n              <tr class=\"sbb-calendar__table-header-row\">\n                <th class=\"sbb-calendar__table-header\" colspan=${MONTHS_PER_ROW}>${year}</th>\n              </tr>\n            </thead>`\n          : nothing}\n        <tbody class=\"sbb-calendar__table-body\">\n          ${months.map(\n            (row: Month[]) => html`\n              <tr>\n                ${row.map((month: Month) => {\n                  const isOutOfRange = !this._isMonthInRange(month.monthValue, year);\n                  const isFilteredOut = !this._isMonthFilteredOut(month.monthValue, year);\n                  const selectedMonth = this._selected\n                    ? this._dateAdapter.getMonth(this._dateAdapter.deserialize(this._selected)!)\n                    : undefined;\n                  const selectedYear = this._selected\n                    ? this._dateAdapter.getYear(this._dateAdapter.deserialize(this._selected)!)\n                    : undefined;\n                  const selected: boolean =\n                    !!this._selected && year === selectedYear && month.monthValue === selectedMonth;\n\n                  const isCurrentMonth =\n                    year === this._dateAdapter.getYear(this.now) &&\n                    this._dateAdapter.getMonth(this.now) === month.monthValue;\n\n                  return html` <td\n                    class=${classMap({\n                      'sbb-calendar__table-data': true,\n                      'sbb-calendar__table-month': true,\n                    })}\n                  >\n                    <button\n                      class=${classMap({\n                        'sbb-calendar__cell': true,\n                        'sbb-calendar__pill': true,\n                        'sbb-calendar__cell-current': isCurrentMonth,\n                        'sbb-calendar__crossed-out': !isOutOfRange && isFilteredOut,\n                        'sbb-calendar__selected': selected,\n                      })}\n                      @click=${() => this._onMonthSelection(month.monthValue, year)}\n                      ?disabled=${isOutOfRange || isFilteredOut}\n                      aria-label=${`${month.longValue} ${year}`}\n                      aria-pressed=${selected}\n                      aria-disabled=${String(isOutOfRange || isFilteredOut)}\n                      tabindex=\"-1\"\n                      data-month=${month.monthValue || nothing}\n                      @keydown=${(evt: KeyboardEvent) => this._handleKeyboardEvent(evt)}\n                    >\n                      ${month.value}\n                    </button>\n                  </td>`;\n                })}\n              </tr>\n            `,\n          )}\n        </tbody>\n      </table>\n    `;\n  }\n\n  /** Select the month and change the view to day selection. */\n  private _onMonthSelection(month: number, year: number): void {\n    this._chosenMonth = month;\n    this._nextCalendarView = 'day';\n    this._init(\n      this._dateAdapter.createDate(\n        year,\n        this._chosenMonth,\n        this._dateAdapter.getDate(this._activeDate),\n      ),\n    );\n    this._startTableTransition();\n  }\n\n  /** Render the view for the year selection. */\n  private _renderYearView(): TemplateResult {\n    return html`\n      <div class=\"sbb-calendar__controls\">\n        ${this._getArrow(\n          'left',\n          () => this._goToDifferentYearRange(-YEARS_PER_PAGE),\n          i18nPreviousYearRange(YEARS_PER_PAGE)[this._language.current],\n          this._previousYearRangeDisabled(),\n        )}\n        <div class=\"sbb-calendar__controls-month\">${this._createLabelForYearView()}</div>\n        ${this._getArrow(\n          'right',\n          () => this._goToDifferentYearRange(YEARS_PER_PAGE),\n          i18nNextYearRange(YEARS_PER_PAGE)[this._language.current],\n          this._nextYearRangeDisabled(),\n        )}\n      </div>\n      <div class=\"sbb-calendar__table-container sbb-calendar__table-year-view\">\n        ${this._createYearTable(this._years)}\n        ${this._wide ? this._createYearTable(this._nextMonthYears, true) : nothing}\n      </div>\n    `;\n  }\n\n  /** Creates the button arrow for all the views. */\n  private _getArrow(\n    direction: 'left' | 'right',\n    click: () => void,\n    ariaLabel: string,\n    disabled: boolean,\n  ): TemplateResult {\n    return html`<sbb-secondary-button\n      size=\"m\"\n      icon-name=\"chevron-small-${direction}-small\"\n      aria-label=${ariaLabel}\n      @click=${click}\n      ?disabled=${disabled}\n      id=\"sbb-calendar__controls-${direction === 'left' ? 'previous' : 'next'}\"\n    ></sbb-secondary-button>`;\n  }\n\n  /** Creates the label with the year range for the yearly view. */\n  private _createLabelForYearView(): TemplateResult {\n    const firstYear: number = this._years.flat()[0];\n    const lastYearArray: number[] = (this._wide ? this._nextMonthYears : this._years).flat();\n    const lastYear: number = lastYearArray[lastYearArray.length - 1];\n    const yearLabel = `${firstYear} - ${lastYear}`;\n    return html`\n      <button\n        type=\"button\"\n        id=\"sbb-calendar__year-selection\"\n        class=\"sbb-calendar__controls-change-date\"\n        aria-label=\"${i18nCalendarDateSelection[this._language.current]} ${yearLabel}\"\n        @click=${() => this._resetCalendarView(true)}\n      >\n        ${yearLabel}\n        <sbb-icon name=\"chevron-small-up-small\"></sbb-icon>\n      </button>\n      <sbb-screen-reader-only role=\"status\"> ${yearLabel} </sbb-screen-reader-only>\n    `;\n  }\n\n  /** Creates the table for the year selection view. */\n  private _createYearTable(years: number[][], shiftRight = false): TemplateResult {\n    const now = this.now;\n    return html` <table\n      class=\"sbb-calendar__table\"\n      @animationend=${(e: AnimationEvent) => this._tableAnimationEnd(e)}\n    >\n      <tbody class=\"sbb-calendar__table-body\">\n        ${years.map(\n          (row: number[]) =>\n            html` <tr>\n              ${row.map((year: number) => {\n                const isOutOfRange = !this._isYearInRange(year);\n                const isFilteredOut = !this._isYearFilteredOut(year);\n                const selectedYear = this._selected\n                  ? this._dateAdapter.getYear(this._dateAdapter.deserialize(this._selected)!)\n                  : undefined;\n                const selected: boolean = !!this._selected && year === selectedYear;\n                const isCurrentYear = this._dateAdapter.getYear(now) === year;\n                return html` <td class=\"sbb-calendar__table-data sbb-calendar__table-year\">\n                  <button\n                    class=${classMap({\n                      'sbb-calendar__cell': true,\n                      'sbb-calendar__pill': true,\n                      'sbb-calendar__cell-current': isCurrentYear,\n                      'sbb-calendar__crossed-out': !isOutOfRange && isFilteredOut,\n                      'sbb-calendar__selected': selected,\n                    })}\n                    @click=${() => this._onYearSelection(year, shiftRight)}\n                    ?disabled=${isOutOfRange || isFilteredOut}\n                    aria-label=${year}\n                    aria-pressed=${selected}\n                    aria-disabled=${String(isOutOfRange || isFilteredOut)}\n                    tabindex=\"-1\"\n                    data-year=${year || nothing}\n                    @keydown=${(evt: KeyboardEvent) => this._handleKeyboardEvent(evt)}\n                  >\n                    ${year}\n                  </button>\n                </td>`;\n              })}\n            </tr>`,\n        )}\n      </tbody>\n    </table>`;\n  }\n\n  /** Select the year and change the view to month selection. */\n  private _onYearSelection(year: number, rightSide: boolean): void {\n    this._chosenYear = rightSide ? year - 1 : year;\n    this._nextCalendarView = 'month';\n    this._assignActiveDate(\n      this._dateAdapter.createDate(\n        this._chosenYear,\n        this._dateAdapter.getMonth(this._activeDate),\n        this._dateAdapter.getDate(this._activeDate),\n      ),\n    );\n    this._startTableTransition();\n  }\n\n  private _getView(): TemplateResult {\n    if (isServer || this.hydrationRequired) {\n      // TODO: We disable SSR for calendar for now. Figure our, if there is a way\n      // to enable it, while considering i18n and date information.\n      return html`${nothing}`;\n    }\n    switch (this._calendarView) {\n      case 'year':\n        return this._renderYearView();\n      case 'month':\n        return this._renderMonthView();\n      case 'day':\n      default:\n        return this._renderDayView();\n    }\n  }\n\n  private _tableAnimationEnd(event: AnimationEvent): void {\n    const table = event.target as HTMLElement;\n    if (event.animationName === 'hide') {\n      table.classList.remove('sbb-calendar__table-hide');\n      this._resetFocus = true;\n      this._calendarView = this._nextCalendarView;\n    } else if (event.animationName === 'show') {\n      this.removeAttribute('data-transition');\n    }\n  }\n\n  private _startTableTransition(): void {\n    this.toggleAttribute('data-transition', true);\n    this.shadowRoot\n      ?.querySelectorAll('table')\n      ?.forEach((e) => e.classList.toggle('sbb-calendar__table-hide'));\n  }\n\n  protected override render(): TemplateResult {\n    return html`<div class=\"sbb-calendar__wrapper\">${this._getView()}</div>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-calendar': SbbCalendarElement;\n  }\n}\n"],"names":["SbbCalendarElement","_a"],"mappings":"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"}
|