@sbb-esta/lyne-elements 2.3.0 → 2.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (428) hide show
  1. package/autocomplete/autocomplete-base-element.d.ts +1 -0
  2. package/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  3. package/autocomplete/autocomplete.d.ts.map +1 -1
  4. package/autocomplete-grid/autocomplete-grid/autocomplete-grid.d.ts.map +1 -1
  5. package/autocomplete-grid/autocomplete-grid.js +0 -1
  6. package/autocomplete.js +28 -28
  7. package/button/common/button-common.d.ts +1 -2
  8. package/button/common/button-common.d.ts.map +1 -1
  9. package/button/common.js +4 -4
  10. package/calendar/calendar.d.ts +55 -11
  11. package/calendar/calendar.d.ts.map +1 -1
  12. package/calendar.js +374 -224
  13. package/card/common/card-action-common.d.ts.map +1 -1
  14. package/checkbox/checkbox-group/checkbox-group.d.ts.map +1 -1
  15. package/checkbox/checkbox-group.js +1 -1
  16. package/checkbox/common/checkbox-common.d.ts.map +1 -1
  17. package/clock/clock.d.ts +8 -0
  18. package/clock/clock.d.ts.map +1 -1
  19. package/clock.js +40 -31
  20. package/core/a11y/focus.d.ts.map +1 -1
  21. package/core/base-elements.js +36 -36
  22. package/core/controllers/escapable-overlay-controller.d.ts +11 -0
  23. package/core/controllers/escapable-overlay-controller.d.ts.map +1 -0
  24. package/core/controllers/inert-controller.d.ts +3 -3
  25. package/core/controllers/inert-controller.d.ts.map +1 -1
  26. package/core/controllers.d.ts +1 -0
  27. package/core/controllers.d.ts.map +1 -1
  28. package/core/controllers.js +79 -52
  29. package/core/datetime/date-adapter.d.ts +4 -2
  30. package/core/datetime/date-adapter.d.ts.map +1 -1
  31. package/core/datetime/native-date-adapter.d.ts +1 -1
  32. package/core/datetime/native-date-adapter.d.ts.map +1 -1
  33. package/core/datetime.js +51 -43
  34. package/core/decorators/date-converter.d.ts +8 -0
  35. package/core/decorators/date-converter.d.ts.map +1 -0
  36. package/core/decorators/date-only-type.d.ts +8 -0
  37. package/core/decorators/date-only-type.d.ts.map +1 -0
  38. package/core/decorators/force-type.d.ts +1 -1
  39. package/core/decorators/force-type.d.ts.map +1 -1
  40. package/core/decorators/get-override.d.ts.map +1 -1
  41. package/core/decorators/handle-distinct-change.d.ts.map +1 -1
  42. package/core/decorators/host-attributes.d.ts.map +1 -1
  43. package/core/decorators/slot-state.d.ts.map +1 -1
  44. package/core/decorators.d.ts +2 -0
  45. package/core/decorators.d.ts.map +1 -1
  46. package/core/decorators.js +61 -41
  47. package/core/dom/input-element.d.ts +1 -1
  48. package/core/dom/input-element.d.ts.map +1 -1
  49. package/core/dom.js +5 -5
  50. package/core/eventing/throttle.d.ts.map +1 -1
  51. package/core/i18n/i18n.d.ts +5 -0
  52. package/core/i18n/i18n.d.ts.map +1 -1
  53. package/core/i18n.js +138 -108
  54. package/core/mixins/animation-complete-mixin.d.ts +13 -0
  55. package/core/mixins/animation-complete-mixin.d.ts.map +1 -0
  56. package/core/mixins/disabled-mixin.d.ts.map +1 -1
  57. package/core/mixins/form-associated-checkbox-mixin.d.ts.map +1 -1
  58. package/core/mixins/form-associated-input-mixin.d.ts +25 -0
  59. package/core/mixins/form-associated-input-mixin.d.ts.map +1 -0
  60. package/core/mixins/form-associated-mixin.d.ts +13 -0
  61. package/core/mixins/form-associated-mixin.d.ts.map +1 -1
  62. package/core/mixins/form-associated-radio-button-mixin.d.ts.map +1 -1
  63. package/core/mixins/hydration-mixin.d.ts.map +1 -1
  64. package/core/mixins/named-slot-list-mixin.d.ts.map +1 -1
  65. package/core/mixins/negative-mixin.d.ts.map +1 -1
  66. package/core/mixins/panel-mixin.d.ts.map +1 -1
  67. package/core/mixins/required-mixin.d.ts.map +1 -1
  68. package/core/mixins/update-scheduler-mixin.d.ts.map +1 -1
  69. package/core/mixins.d.ts +2 -0
  70. package/core/mixins.d.ts.map +1 -1
  71. package/core/mixins.js +566 -341
  72. package/core/styles/core.scss +84 -1
  73. package/core/styles/mixins/link.scss +14 -0
  74. package/core/styles/node_modules_@sbb-esta_lyne-design-tokens_dist_scss_sbb-variables.scss +3 -0
  75. package/core/styles/node_modules_@sbb-esta_lyne-design-tokens_dist_scss_sbb-variables_css--mixin.scss +4 -1
  76. package/core/testing/mocha-extensions.d.ts.map +1 -1
  77. package/core/testing/wait-for-render.d.ts.map +1 -1
  78. package/core.css +53 -3
  79. package/custom-elements.json +37278 -30220
  80. package/date-input/date-input.d.ts +75 -0
  81. package/date-input/date-input.d.ts.map +1 -0
  82. package/date-input.d.ts +2 -0
  83. package/date-input.d.ts.map +1 -0
  84. package/date-input.js +155 -0
  85. package/datepicker/common/datepicker-button.d.ts.map +1 -1
  86. package/datepicker/common.js +49 -45
  87. package/datepicker/datepicker/datepicker.d.ts +16 -6
  88. package/datepicker/datepicker/datepicker.d.ts.map +1 -1
  89. package/datepicker/datepicker-toggle/datepicker-toggle.d.ts.map +1 -1
  90. package/datepicker/datepicker-toggle.js +41 -38
  91. package/datepicker/datepicker.js +95 -77
  92. package/development/autocomplete/autocomplete-base-element.d.ts +1 -0
  93. package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  94. package/development/autocomplete/autocomplete.d.ts.map +1 -1
  95. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.d.ts.map +1 -1
  96. package/development/autocomplete-grid/autocomplete-grid.js +1 -2
  97. package/development/autocomplete.js +9 -4
  98. package/development/button/common/button-common.d.ts +1 -2
  99. package/development/button/common/button-common.d.ts.map +1 -1
  100. package/development/button/common.js +26 -24
  101. package/development/calendar/calendar.d.ts +55 -11
  102. package/development/calendar/calendar.d.ts.map +1 -1
  103. package/development/calendar.js +301 -87
  104. package/development/card/common/card-action-common.d.ts.map +1 -1
  105. package/development/checkbox/checkbox-group/checkbox-group.d.ts.map +1 -1
  106. package/development/checkbox/checkbox-group.js +2 -2
  107. package/development/checkbox/common/checkbox-common.d.ts.map +1 -1
  108. package/development/clock/clock.d.ts +8 -0
  109. package/development/clock/clock.d.ts.map +1 -1
  110. package/development/clock.js +20 -2
  111. package/development/core/a11y/focus.d.ts.map +1 -1
  112. package/development/core/a11y.js +1 -1
  113. package/development/core/base-elements.js +6 -6
  114. package/development/core/controllers/escapable-overlay-controller.d.ts +11 -0
  115. package/development/core/controllers/escapable-overlay-controller.d.ts.map +1 -0
  116. package/development/core/controllers/inert-controller.d.ts +3 -3
  117. package/development/core/controllers/inert-controller.d.ts.map +1 -1
  118. package/development/core/controllers.d.ts +1 -0
  119. package/development/core/controllers.d.ts.map +1 -1
  120. package/development/core/controllers.js +41 -7
  121. package/development/core/datetime/date-adapter.d.ts +4 -2
  122. package/development/core/datetime/date-adapter.d.ts.map +1 -1
  123. package/development/core/datetime/native-date-adapter.d.ts +1 -1
  124. package/development/core/datetime/native-date-adapter.d.ts.map +1 -1
  125. package/development/core/datetime.js +14 -2
  126. package/development/core/decorators/date-converter.d.ts +8 -0
  127. package/development/core/decorators/date-converter.d.ts.map +1 -0
  128. package/development/core/decorators/date-only-type.d.ts +8 -0
  129. package/development/core/decorators/date-only-type.d.ts.map +1 -0
  130. package/development/core/decorators/force-type.d.ts +1 -1
  131. package/development/core/decorators/force-type.d.ts.map +1 -1
  132. package/development/core/decorators/get-override.d.ts.map +1 -1
  133. package/development/core/decorators/handle-distinct-change.d.ts.map +1 -1
  134. package/development/core/decorators/host-attributes.d.ts.map +1 -1
  135. package/development/core/decorators/slot-state.d.ts.map +1 -1
  136. package/development/core/decorators.d.ts +2 -0
  137. package/development/core/decorators.d.ts.map +1 -1
  138. package/development/core/decorators.js +27 -6
  139. package/development/core/dom/input-element.d.ts +1 -1
  140. package/development/core/dom/input-element.d.ts.map +1 -1
  141. package/development/core/dom.js +3 -3
  142. package/development/core/eventing/throttle.d.ts.map +1 -1
  143. package/development/core/i18n/i18n.d.ts +5 -0
  144. package/development/core/i18n/i18n.d.ts.map +1 -1
  145. package/development/core/i18n.js +36 -1
  146. package/development/core/mixins/animation-complete-mixin.d.ts +13 -0
  147. package/development/core/mixins/animation-complete-mixin.d.ts.map +1 -0
  148. package/development/core/mixins/disabled-mixin.d.ts.map +1 -1
  149. package/development/core/mixins/form-associated-checkbox-mixin.d.ts.map +1 -1
  150. package/development/core/mixins/form-associated-input-mixin.d.ts +25 -0
  151. package/development/core/mixins/form-associated-input-mixin.d.ts.map +1 -0
  152. package/development/core/mixins/form-associated-mixin.d.ts +13 -0
  153. package/development/core/mixins/form-associated-mixin.d.ts.map +1 -1
  154. package/development/core/mixins/form-associated-radio-button-mixin.d.ts.map +1 -1
  155. package/development/core/mixins/hydration-mixin.d.ts.map +1 -1
  156. package/development/core/mixins/named-slot-list-mixin.d.ts.map +1 -1
  157. package/development/core/mixins/negative-mixin.d.ts.map +1 -1
  158. package/development/core/mixins/panel-mixin.d.ts.map +1 -1
  159. package/development/core/mixins/required-mixin.d.ts.map +1 -1
  160. package/development/core/mixins/update-scheduler-mixin.d.ts.map +1 -1
  161. package/development/core/mixins.d.ts +2 -0
  162. package/development/core/mixins.d.ts.map +1 -1
  163. package/development/core/mixins.js +428 -88
  164. package/development/core/testing/mocha-extensions.d.ts.map +1 -1
  165. package/development/core/testing/wait-for-render.d.ts.map +1 -1
  166. package/development/date-input/date-input.d.ts +75 -0
  167. package/development/date-input/date-input.d.ts.map +1 -0
  168. package/development/date-input.d.ts +2 -0
  169. package/development/date-input.d.ts.map +1 -0
  170. package/development/date-input.js +267 -0
  171. package/development/datepicker/common/datepicker-button.d.ts.map +1 -1
  172. package/development/datepicker/common.js +11 -2
  173. package/development/datepicker/datepicker/datepicker.d.ts +16 -6
  174. package/development/datepicker/datepicker/datepicker.d.ts.map +1 -1
  175. package/development/datepicker/datepicker-toggle/datepicker-toggle.d.ts.map +1 -1
  176. package/development/datepicker/datepicker-toggle.js +12 -3
  177. package/development/datepicker/datepicker.js +66 -39
  178. package/development/dialog/dialog/dialog.d.ts.map +1 -1
  179. package/development/dialog/dialog-title/dialog-title.d.ts +3 -1
  180. package/development/dialog/dialog-title/dialog-title.d.ts.map +1 -1
  181. package/development/dialog/dialog-title.js +7 -2
  182. package/development/dialog/dialog.js +3 -1
  183. package/development/expansion-panel/expansion-panel/expansion-panel.d.ts.map +1 -1
  184. package/development/expansion-panel/expansion-panel.js +2 -2
  185. package/development/file-selector/common/file-selector-common.d.ts.map +1 -1
  186. package/development/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -1
  187. package/development/flip-card/flip-card-details.js +5 -3
  188. package/development/form-field/form-field/form-field.d.ts +1 -1
  189. package/development/form-field/form-field/form-field.d.ts.map +1 -1
  190. package/development/form-field/form-field.js +19 -13
  191. package/development/header/common/header-action-common.d.ts.map +1 -1
  192. package/development/header/common.js +2 -2
  193. package/development/icon/icon-name-mixin.d.ts.map +1 -1
  194. package/development/icon/icon-request.d.ts.map +1 -1
  195. package/development/icon/icon-validate.d.ts.map +1 -1
  196. package/development/link/common/block-link-common.d.ts.map +1 -1
  197. package/development/link/common/inline-link-common.d.ts.map +1 -1
  198. package/development/link/common/link-common.d.ts.map +1 -1
  199. package/development/link/common.js +13 -1
  200. package/development/menu/common/menu-action-common.d.ts.map +1 -1
  201. package/development/menu/menu/menu.d.ts +1 -1
  202. package/development/menu/menu/menu.d.ts.map +1 -1
  203. package/development/menu/menu.js +8 -15
  204. package/development/navigation/common/navigation-action-common.d.ts.map +1 -1
  205. package/development/navigation/navigation/navigation.d.ts +1 -3
  206. package/development/navigation/navigation/navigation.d.ts.map +1 -1
  207. package/development/navigation/navigation.js +11 -21
  208. package/development/overlay/overlay-base-element.d.ts +2 -2
  209. package/development/overlay/overlay-base-element.d.ts.map +1 -1
  210. package/development/overlay/overlay.d.ts.map +1 -1
  211. package/development/overlay.js +9 -13
  212. package/development/paginator/common/paginator-common.d.ts.map +1 -1
  213. package/development/popover/popover/popover.d.ts +1 -1
  214. package/development/popover/popover/popover.d.ts.map +1 -1
  215. package/development/popover/popover.js +5 -15
  216. package/development/radio-button/common/radio-button-common.d.ts.map +1 -1
  217. package/development/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  218. package/development/radio-button/radio-button-group.js +2 -2
  219. package/development/sbb-tokens-CSAKTXUi.js +1 -1
  220. package/development/select/select.d.ts +3 -1
  221. package/development/select/select.d.ts.map +1 -1
  222. package/development/select.js +12 -8
  223. package/development/selection-expansion-panel/selection-expansion-panel.d.ts.map +1 -1
  224. package/development/selection-expansion-panel.js +2 -2
  225. package/development/sidebar/common.d.ts +1 -0
  226. package/development/sidebar/common.d.ts.map +1 -0
  227. package/development/sidebar/common.js +114 -0
  228. package/development/sidebar/icon-sidebar/icon-sidebar.d.ts +23 -0
  229. package/development/sidebar/icon-sidebar/icon-sidebar.d.ts.map +1 -0
  230. package/development/sidebar/icon-sidebar-button/icon-sidebar-button.d.ts +19 -0
  231. package/development/sidebar/icon-sidebar-button/icon-sidebar-button.d.ts.map +1 -0
  232. package/development/sidebar/icon-sidebar-button.d.ts +2 -0
  233. package/development/sidebar/icon-sidebar-button.d.ts.map +1 -0
  234. package/development/sidebar/icon-sidebar-button.js +28 -0
  235. package/development/sidebar/icon-sidebar-container/icon-sidebar-container.d.ts +23 -0
  236. package/development/sidebar/icon-sidebar-container/icon-sidebar-container.d.ts.map +1 -0
  237. package/development/sidebar/icon-sidebar-container.d.ts +2 -0
  238. package/development/sidebar/icon-sidebar-container.d.ts.map +1 -0
  239. package/development/sidebar/icon-sidebar-container.js +45 -0
  240. package/development/sidebar/icon-sidebar-content/icon-sidebar-content.d.ts +17 -0
  241. package/development/sidebar/icon-sidebar-content/icon-sidebar-content.d.ts.map +1 -0
  242. package/development/sidebar/icon-sidebar-content.d.ts +2 -0
  243. package/development/sidebar/icon-sidebar-content.d.ts.map +1 -0
  244. package/development/sidebar/icon-sidebar-content.js +34 -0
  245. package/development/sidebar/icon-sidebar-link/icon-sidebar-link.d.ts +19 -0
  246. package/development/sidebar/icon-sidebar-link/icon-sidebar-link.d.ts.map +1 -0
  247. package/development/sidebar/icon-sidebar-link.d.ts +2 -0
  248. package/development/sidebar/icon-sidebar-link.d.ts.map +1 -0
  249. package/development/sidebar/icon-sidebar-link.js +28 -0
  250. package/development/sidebar/icon-sidebar.d.ts +2 -0
  251. package/development/sidebar/icon-sidebar.d.ts.map +1 -0
  252. package/development/sidebar/icon-sidebar.js +85 -0
  253. package/development/sidebar/sidebar/sidebar.d.ts +76 -0
  254. package/development/sidebar/sidebar/sidebar.d.ts.map +1 -0
  255. package/development/sidebar/sidebar-close-button/sidebar-close-button.d.ts +22 -0
  256. package/development/sidebar/sidebar-close-button/sidebar-close-button.d.ts.map +1 -0
  257. package/development/sidebar/sidebar-close-button.d.ts +2 -0
  258. package/development/sidebar/sidebar-close-button.d.ts.map +1 -0
  259. package/development/sidebar/sidebar-close-button.js +55 -0
  260. package/development/sidebar/sidebar-container/sidebar-container.d.ts +34 -0
  261. package/development/sidebar/sidebar-container/sidebar-container.d.ts.map +1 -0
  262. package/development/sidebar/sidebar-container.d.ts +2 -0
  263. package/development/sidebar/sidebar-container.d.ts.map +1 -0
  264. package/development/sidebar/sidebar-container.js +153 -0
  265. package/development/sidebar/sidebar-content/sidebar-content.d.ts +18 -0
  266. package/development/sidebar/sidebar-content/sidebar-content.d.ts.map +1 -0
  267. package/development/sidebar/sidebar-content.d.ts +2 -0
  268. package/development/sidebar/sidebar-content.d.ts.map +1 -0
  269. package/development/sidebar/sidebar-content.js +37 -0
  270. package/development/sidebar/sidebar-title/sidebar-title.d.ts +17 -0
  271. package/development/sidebar/sidebar-title/sidebar-title.d.ts.map +1 -0
  272. package/development/sidebar/sidebar-title.d.ts +2 -0
  273. package/development/sidebar/sidebar-title.d.ts.map +1 -0
  274. package/development/sidebar/sidebar-title.js +63 -0
  275. package/development/sidebar/sidebar.d.ts +2 -0
  276. package/development/sidebar/sidebar.d.ts.map +1 -0
  277. package/development/sidebar/sidebar.js +523 -0
  278. package/development/sidebar.d.ts +12 -0
  279. package/development/sidebar.d.ts.map +1 -0
  280. package/development/sidebar.js +12 -0
  281. package/development/stepper/step/step.d.ts +0 -2
  282. package/development/stepper/step/step.d.ts.map +1 -1
  283. package/development/stepper/step.js +19 -23
  284. package/development/stepper/stepper/stepper.d.ts +11 -0
  285. package/development/stepper/stepper/stepper.d.ts.map +1 -1
  286. package/development/stepper/stepper.js +30 -3
  287. package/development/tag/tag/tag.d.ts +11 -0
  288. package/development/tag/tag/tag.d.ts.map +1 -1
  289. package/development/tag/tag-group/tag-group.d.ts +1 -1
  290. package/development/tag/tag-group/tag-group.d.ts.map +1 -1
  291. package/development/tag/tag-group.js +9 -3
  292. package/development/tag/tag.js +37 -10
  293. package/development/teaser-product/common/teaser-product-common.d.ts.map +1 -1
  294. package/development/time-input/time-input.d.ts +3 -2
  295. package/development/time-input/time-input.d.ts.map +1 -1
  296. package/development/time-input.js +19 -10
  297. package/development/title/title-base.d.ts +2 -4
  298. package/development/title/title-base.d.ts.map +1 -1
  299. package/development/title/title.d.ts +3 -1
  300. package/development/title/title.d.ts.map +1 -1
  301. package/development/title.js +8 -8
  302. package/dialog/dialog/dialog.d.ts.map +1 -1
  303. package/dialog/dialog-title/dialog-title.d.ts +3 -1
  304. package/dialog/dialog-title/dialog-title.d.ts.map +1 -1
  305. package/dialog/dialog-title.js +16 -15
  306. package/dialog/dialog.js +2 -2
  307. package/expansion-panel/expansion-panel/expansion-panel.d.ts.map +1 -1
  308. package/expansion-panel/expansion-panel.js +1 -1
  309. package/file-selector/common/file-selector-common.d.ts.map +1 -1
  310. package/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -1
  311. package/flip-card/flip-card-details.js +14 -13
  312. package/form-field/form-field/form-field.d.ts +1 -1
  313. package/form-field/form-field/form-field.d.ts.map +1 -1
  314. package/form-field/form-field.js +30 -24
  315. package/header/common/header-action-common.d.ts.map +1 -1
  316. package/header/common.js +6 -6
  317. package/icon/icon-name-mixin.d.ts.map +1 -1
  318. package/icon/icon-request.d.ts.map +1 -1
  319. package/icon/icon-validate.d.ts.map +1 -1
  320. package/index.d.ts +22 -0
  321. package/index.js +22 -0
  322. package/link/common/block-link-common.d.ts.map +1 -1
  323. package/link/common/inline-link-common.d.ts.map +1 -1
  324. package/link/common/link-common.d.ts.map +1 -1
  325. package/link/common.js +12 -12
  326. package/menu/common/menu-action-common.d.ts.map +1 -1
  327. package/menu/menu/menu.d.ts +1 -1
  328. package/menu/menu/menu.d.ts.map +1 -1
  329. package/menu/menu.js +26 -35
  330. package/navigation/common/navigation-action-common.d.ts.map +1 -1
  331. package/navigation/navigation/navigation.d.ts +1 -3
  332. package/navigation/navigation/navigation.d.ts.map +1 -1
  333. package/navigation/navigation.js +47 -56
  334. package/overlay/overlay-base-element.d.ts +2 -2
  335. package/overlay/overlay-base-element.d.ts.map +1 -1
  336. package/overlay/overlay.d.ts.map +1 -1
  337. package/overlay.js +58 -64
  338. package/package.json +66 -1
  339. package/paginator/common/paginator-common.d.ts.map +1 -1
  340. package/popover/popover/popover.d.ts +1 -1
  341. package/popover/popover/popover.d.ts.map +1 -1
  342. package/popover/popover.js +101 -110
  343. package/radio-button/common/radio-button-common.d.ts.map +1 -1
  344. package/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  345. package/radio-button/radio-button-group.js +1 -1
  346. package/select/select.d.ts +3 -1
  347. package/select/select.d.ts.map +1 -1
  348. package/select.js +39 -37
  349. package/selection-expansion-panel/selection-expansion-panel.d.ts.map +1 -1
  350. package/selection-expansion-panel.js +1 -1
  351. package/sidebar/common.d.ts +1 -0
  352. package/sidebar/common.d.ts.map +1 -0
  353. package/sidebar/common.js +7 -0
  354. package/sidebar/icon-sidebar/icon-sidebar.d.ts +23 -0
  355. package/sidebar/icon-sidebar/icon-sidebar.d.ts.map +1 -0
  356. package/sidebar/icon-sidebar-button/icon-sidebar-button.d.ts +19 -0
  357. package/sidebar/icon-sidebar-button/icon-sidebar-button.d.ts.map +1 -0
  358. package/sidebar/icon-sidebar-button.d.ts +2 -0
  359. package/sidebar/icon-sidebar-button.d.ts.map +1 -0
  360. package/sidebar/icon-sidebar-button.js +20 -0
  361. package/sidebar/icon-sidebar-container/icon-sidebar-container.d.ts +23 -0
  362. package/sidebar/icon-sidebar-container/icon-sidebar-container.d.ts.map +1 -0
  363. package/sidebar/icon-sidebar-container.d.ts +2 -0
  364. package/sidebar/icon-sidebar-container.d.ts.map +1 -0
  365. package/sidebar/icon-sidebar-container.js +35 -0
  366. package/sidebar/icon-sidebar-content/icon-sidebar-content.d.ts +17 -0
  367. package/sidebar/icon-sidebar-content/icon-sidebar-content.d.ts.map +1 -0
  368. package/sidebar/icon-sidebar-content.d.ts +2 -0
  369. package/sidebar/icon-sidebar-content.d.ts.map +1 -0
  370. package/sidebar/icon-sidebar-content.js +23 -0
  371. package/sidebar/icon-sidebar-link/icon-sidebar-link.d.ts +19 -0
  372. package/sidebar/icon-sidebar-link/icon-sidebar-link.d.ts.map +1 -0
  373. package/sidebar/icon-sidebar-link.d.ts +2 -0
  374. package/sidebar/icon-sidebar-link.d.ts.map +1 -0
  375. package/sidebar/icon-sidebar-link.js +20 -0
  376. package/sidebar/icon-sidebar.d.ts +2 -0
  377. package/sidebar/icon-sidebar.d.ts.map +1 -0
  378. package/sidebar/icon-sidebar.js +47 -0
  379. package/sidebar/sidebar/sidebar.d.ts +76 -0
  380. package/sidebar/sidebar/sidebar.d.ts.map +1 -0
  381. package/sidebar/sidebar-close-button/sidebar-close-button.d.ts +22 -0
  382. package/sidebar/sidebar-close-button/sidebar-close-button.d.ts.map +1 -0
  383. package/sidebar/sidebar-close-button.d.ts +2 -0
  384. package/sidebar/sidebar-close-button.d.ts.map +1 -0
  385. package/sidebar/sidebar-close-button.js +29 -0
  386. package/sidebar/sidebar-container/sidebar-container.d.ts +34 -0
  387. package/sidebar/sidebar-container/sidebar-container.d.ts.map +1 -0
  388. package/sidebar/sidebar-container.d.ts +2 -0
  389. package/sidebar/sidebar-container.d.ts.map +1 -0
  390. package/sidebar/sidebar-container.js +78 -0
  391. package/sidebar/sidebar-content/sidebar-content.d.ts +18 -0
  392. package/sidebar/sidebar-content/sidebar-content.d.ts.map +1 -0
  393. package/sidebar/sidebar-content.d.ts +2 -0
  394. package/sidebar/sidebar-content.d.ts.map +1 -0
  395. package/sidebar/sidebar-content.js +23 -0
  396. package/sidebar/sidebar-title/sidebar-title.d.ts +17 -0
  397. package/sidebar/sidebar-title/sidebar-title.d.ts.map +1 -0
  398. package/sidebar/sidebar-title.d.ts +2 -0
  399. package/sidebar/sidebar-title.d.ts.map +1 -0
  400. package/sidebar/sidebar-title.js +37 -0
  401. package/sidebar/sidebar.d.ts +2 -0
  402. package/sidebar/sidebar.d.ts.map +1 -0
  403. package/sidebar/sidebar.js +214 -0
  404. package/sidebar.d.ts +12 -0
  405. package/sidebar.d.ts.map +1 -0
  406. package/sidebar.js +11 -0
  407. package/standard-theme.css +53 -3
  408. package/stepper/step/step.d.ts +0 -2
  409. package/stepper/step/step.d.ts.map +1 -1
  410. package/stepper/step.js +23 -35
  411. package/stepper/stepper/stepper.d.ts +11 -0
  412. package/stepper/stepper/stepper.d.ts.map +1 -1
  413. package/stepper/stepper.js +59 -41
  414. package/tag/tag/tag.d.ts +11 -0
  415. package/tag/tag/tag.d.ts.map +1 -1
  416. package/tag/tag-group/tag-group.d.ts +1 -1
  417. package/tag/tag-group/tag-group.d.ts.map +1 -1
  418. package/tag/tag-group.js +32 -29
  419. package/tag/tag.js +60 -41
  420. package/teaser-product/common/teaser-product-common.d.ts.map +1 -1
  421. package/time-input/time-input.d.ts +3 -2
  422. package/time-input/time-input.d.ts.map +1 -1
  423. package/time-input.js +44 -36
  424. package/title/title-base.d.ts +2 -4
  425. package/title/title-base.d.ts.map +1 -1
  426. package/title/title.d.ts +3 -1
  427. package/title/title.d.ts.map +1 -1
  428. package/title.js +11 -11
@@ -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._dateAdapter = (__runInitializers(this, _dateFilter_extraInitializers), ((_a2 = readConfig().datetime) == null ? void 0 : _a2.dateAdapter) ?? defaultDateAdapter);
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 weeks = [[]];
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(`[data-day="${this._dateAdapter.getDate(active)} ${this._dateAdapter.getMonth(active)} ${this._dateAdapter.getYear(active)}"]`) ?? this.shadowRoot.querySelector(`[data-month="${this._dateAdapter.getMonth(active)}"]`) ?? this.shadowRoot.querySelector(`[data-year="${this._dateAdapter.getYear(active)}"]`);
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
- const nextEl = this._navigateByKeyboard(event, index, cells, day);
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, day) {
814
- const { elementIndexForWideMode, offsetForWideMode, lastElementIndexForWideMode, verticalOffset } = this._calculateParametersForKeyboardNavigation(cells, index, day);
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 parameter needed in keyboard navigation.
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 day (optional) Only in the day view, the day represented by the starting cell.
1051
+ * @param isYearView Whether the displayed `view` is the year one.
843
1052
  */
844
- _calculateParametersForKeyboardNavigation(cells, index, day) {
845
- switch (this._calendarView) {
846
- case "day": {
847
- const indexInView = +day.dayValue - 1;
848
- return {
849
- verticalOffset: DAYS_PER_ROW,
850
- elementIndexForWideMode: indexInView,
851
- offsetForWideMode: index - indexInView,
852
- lastElementIndexForWideMode: index === indexInView ? this._dateAdapter.getNumDaysInMonth(this._dateAdapter.addCalendarMonths(this._dateAdapter.deserialize(day.value), -1)) : cells.length
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._createDayTable(this._weeks)}
933
- ${this._wide ? this._createDayTable(this._nextMonthWeeks) : nothing}
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._createDayTableHeader()}
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
- ${this._createDayTableBody(weeks)}
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
- <tr>
1002
- ${[...Array(firstRowOffset).keys()].map(() => html`<td
1003
- class="sbb-calendar__table-data"
1004
- data-day=${`0 ${week[0].monthValue} ${week[0].yearValue}`}
1005
- ></td>`)}
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
- ${this._createDayCells(week, today)}
1012
- </tr>`;
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":"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"}
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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"}