@sbb-esta/lyne-elements-dev 4.7.0-dev.1773388991 → 4.7.0-dev.1773396165

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 (1412) hide show
  1. package/accordion/accordion.component.js +98 -2
  2. package/accordion.js +4 -5
  3. package/accordion.pure.js +4 -2
  4. package/action-group/action-group.component.js +107 -2
  5. package/action-group.js +4 -5
  6. package/action-group.pure.js +4 -2
  7. package/alert/alert/alert.component.js +143 -2
  8. package/alert/alert-group/alert-group.component.js +103 -2
  9. package/alert/alert-group.js +7 -4
  10. package/alert/alert.js +7 -4
  11. package/alert.js +8 -6
  12. package/alert.pure.js +6 -3
  13. package/autocomplete/autocomplete-base-element.js +373 -2
  14. package/autocomplete/autocomplete.component.js +50 -51
  15. package/autocomplete.js +7 -7
  16. package/autocomplete.pure.js +6 -3
  17. package/breadcrumb/breadcrumb/breadcrumb.component.js +20 -2
  18. package/breadcrumb/breadcrumb-group/breadcrumb-group.component.js +135 -2
  19. package/breadcrumb/breadcrumb-group.js +7 -4
  20. package/breadcrumb/breadcrumb.js +7 -4
  21. package/breadcrumb.js +8 -6
  22. package/breadcrumb.pure.js +6 -3
  23. package/button/accent-button/accent-button.component.js +14 -18
  24. package/button/accent-button-link/accent-button-link.component.js +14 -18
  25. package/button/accent-button-link.js +4 -4
  26. package/button/accent-button-static/accent-button-static.component.js +13 -17
  27. package/button/accent-button-static.js +4 -4
  28. package/button/accent-button.js +4 -4
  29. package/button/button/button.component.js +14 -18
  30. package/button/button-link/button-link.component.js +14 -18
  31. package/button/button-link.js +4 -4
  32. package/button/button-static/button-static.component.js +14 -18
  33. package/button/button-static.js +4 -4
  34. package/button/button.js +4 -4
  35. package/button/common/button-common.js +67 -81
  36. package/button/common.js +12 -3
  37. package/button/mini-button/mini-button.component.js +18 -22
  38. package/button/mini-button-group/mini-button-group.component.js +68 -2
  39. package/button/mini-button-group.js +6 -6
  40. package/button/mini-button-link/mini-button-link.component.js +27 -2
  41. package/button/mini-button-link.js +6 -6
  42. package/button/mini-button.js +4 -4
  43. package/button/secondary-button/secondary-button.component.js +14 -18
  44. package/button/secondary-button-link/secondary-button-link.component.js +14 -18
  45. package/button/secondary-button-link.js +6 -6
  46. package/button/secondary-button-static/secondary-button-static.component.js +14 -18
  47. package/button/secondary-button-static.js +4 -4
  48. package/button/secondary-button.js +6 -6
  49. package/button/transparent-button/transparent-button.component.js +14 -18
  50. package/button/transparent-button-link/transparent-button-link.component.js +14 -18
  51. package/button/transparent-button-link.js +6 -6
  52. package/button/transparent-button-static/transparent-button-static.component.js +14 -18
  53. package/button/transparent-button-static.js +4 -4
  54. package/button/transparent-button.js +4 -4
  55. package/button.js +56 -20
  56. package/button.pure.js +42 -18
  57. package/calendar/calendar/calendar.component.js +1227 -2
  58. package/calendar/calendar-day/calendar-day.component.js +98 -2
  59. package/calendar/calendar-day.js +7 -4
  60. package/calendar/calendar.js +9 -4
  61. package/calendar.js +10 -6
  62. package/calendar.pure.js +7 -3
  63. package/card/card/card.component.js +48 -2
  64. package/card/card-badge/card-badge.component.js +48 -2
  65. package/card/card-badge.js +7 -4
  66. package/card/card-button/card-button.component.js +10 -11
  67. package/card/card-button.js +6 -3
  68. package/card/card-link/card-link.component.js +10 -11
  69. package/card/card-link.js +6 -3
  70. package/card/card.js +7 -4
  71. package/card/common/card-action-common.js +63 -2
  72. package/card/common.js +6 -5
  73. package/card.js +16 -9
  74. package/card.pure.js +11 -5
  75. package/carousel/carousel/carousel.component.js +88 -2
  76. package/carousel/carousel-item/carousel-item.component.js +18 -2
  77. package/carousel/carousel-item.js +7 -4
  78. package/carousel/carousel-list/carousel-list.component.js +90 -2
  79. package/carousel/carousel-list.js +7 -4
  80. package/carousel/carousel.js +7 -4
  81. package/carousel.js +11 -7
  82. package/carousel.pure.js +8 -4
  83. package/checkbox/checkbox-group.js +3 -2
  84. package/checkbox/checkbox-panel.js +3 -2
  85. package/checkbox/checkbox.component.js +91 -3
  86. package/checkbox/checkbox.js +7 -5
  87. package/checkbox/common/checkbox-common.js +57 -2
  88. package/checkbox/common.js +7 -5
  89. package/checkbox-group/checkbox-group.component.js +101 -2
  90. package/checkbox-group.js +4 -5
  91. package/checkbox-group.pure.js +4 -2
  92. package/checkbox-panel/checkbox-panel.component.js +48 -63
  93. package/checkbox-panel.js +3 -4
  94. package/checkbox-panel.pure.js +4 -2
  95. package/checkbox.js +14 -10
  96. package/checkbox.pure.js +7 -3
  97. package/chip/chip/chip.component.js +73 -2
  98. package/chip/chip-group/chip-group.component.js +253 -2
  99. package/chip/chip-group.js +7 -4
  100. package/chip/chip.js +7 -4
  101. package/chip-label/chip-label.component.js +56 -2
  102. package/chip-label.js +4 -5
  103. package/chip-label.pure.js +4 -2
  104. package/chip.js +8 -6
  105. package/chip.pure.js +6 -3
  106. package/clock/clock.component.js +153 -2
  107. package/clock.js +4 -5
  108. package/clock.pure.js +4 -2
  109. package/container/container/container.component.js +76 -2
  110. package/container/container.js +7 -4
  111. package/container/sticky-bar/sticky-bar.component.js +122 -2
  112. package/container/sticky-bar.js +7 -4
  113. package/container.js +8 -6
  114. package/container.pure.js +6 -3
  115. package/core/a11y/arrow-navigation.js +33 -45
  116. package/core/a11y/fake-event-detection.js +9 -8
  117. package/core/a11y/focus-trap-controller.js +91 -69
  118. package/core/a11y/focus-visible-within-controller.js +18 -18
  119. package/core/a11y/focus.js +13 -13
  120. package/core/a11y/input-modality-detector.js +47 -42
  121. package/core/a11y/interactivity-checker.js +96 -61
  122. package/core/a11y/live-announcer.js +40 -29
  123. package/core/a11y.js +26 -9
  124. package/core/base-elements/action-base-element.js +37 -29
  125. package/core/base-elements/button-base-element.js +145 -165
  126. package/core/base-elements/element.js +63 -28
  127. package/core/base-elements/link-base-element.js +119 -186
  128. package/core/base-elements/open-close-base-element.js +42 -40
  129. package/core/base-elements.js +13 -6
  130. package/core/config/config.js +9 -8
  131. package/core/config.js +5 -2
  132. package/core/controllers/escapable-overlay-controller.js +25 -23
  133. package/core/controllers/id-reference-controller.js +59 -50
  134. package/core/controllers/inert-controller.js +57 -55
  135. package/core/controllers/language-controller.js +38 -53
  136. package/core/controllers/media-matchers-controller.js +96 -82
  137. package/core/controllers/overlay-position-controller.js +222 -215
  138. package/core/controllers/property-watcher-controller.js +59 -55
  139. package/core/controllers/slot-state-controller.js +36 -34
  140. package/core/controllers.js +28 -7
  141. package/core/datetime/date-adapter.js +135 -61
  142. package/core/datetime/native-date-adapter.js +140 -91
  143. package/core/datetime/temporal-date-adapter.js +144 -108
  144. package/core/datetime.js +16 -4
  145. package/core/decorators/base.js +1 -0
  146. package/core/decorators/force-type.js +16 -12
  147. package/core/decorators/get-override.js +13 -10
  148. package/core/decorators/handle-distinct-change.js +15 -12
  149. package/core/decorators/host-attributes.js +16 -15
  150. package/core/decorators/id-reference.js +75 -65
  151. package/core/decorators/omit-empty-converter.js +9 -7
  152. package/core/decorators/plain-date.js +25 -21
  153. package/core/decorators.js +17 -8
  154. package/core/dom/animation.js +9 -8
  155. package/core/dom/contains-pierce-shadow-dom.js +11 -10
  156. package/core/dom/lean-context.js +4 -4
  157. package/core/dom/platform.js +18 -8
  158. package/core/dom/queue-dom-content-loaded.js +6 -6
  159. package/core/dom/scroll.js +16 -14
  160. package/core/dom/set-or-remove-attribute.js +5 -5
  161. package/core/dom.js +25 -6
  162. package/core/eventing/composed-path-has-attribute.js +7 -6
  163. package/core/eventing/event-target.js +5 -5
  164. package/core/eventing/form-element-handlers.js +5 -5
  165. package/core/eventing/forward-event.js +6 -6
  166. package/core/eventing/is-event-prevented.js +5 -5
  167. package/core/eventing/throttle.js +10 -10
  168. package/core/eventing.js +14 -7
  169. package/core/i18n/i18n.js +738 -634
  170. package/core/i18n.js +104 -2
  171. package/core/images.js +14 -14
  172. package/core/interfaces.js +1 -0
  173. package/core/mixins/animation-complete-mixin.js +42 -34
  174. package/core/mixins/constructor.js +1 -0
  175. package/core/mixins/disabled-mixin.js +74 -91
  176. package/core/mixins/element-internals-mixin.js +155 -149
  177. package/core/mixins/form-associated-checkbox-mixin.js +93 -106
  178. package/core/mixins/form-associated-input-mixin.js +193 -202
  179. package/core/mixins/form-associated-mixin.js +226 -168
  180. package/core/mixins/form-associated-radio-button-mixin.js +168 -152
  181. package/core/mixins/hydration-mixin.js +37 -27
  182. package/core/mixins/named-slot-list-mixin.js +95 -77
  183. package/core/mixins/negative-mixin.js +33 -45
  184. package/core/mixins/panel-mixin.js +70 -109
  185. package/core/mixins/readonly-mixin.js +34 -40
  186. package/core/mixins/required-mixin.js +35 -48
  187. package/core/mixins/selection-panel-mixin.js +39 -36
  188. package/core/mixins/update-scheduler-mixin.js +21 -20
  189. package/core/mixins.js +41 -21
  190. package/core/overlay/overlay-option-panel.js +16 -15
  191. package/core/overlay/overlay-outside-pointer-event-listener.js +37 -34
  192. package/core/overlay/overlay-trigger-attributes.js +14 -11
  193. package/core/overlay/overlay.js +6 -6
  194. package/core/overlay/position.js +49 -53
  195. package/core/overlay.js +19 -6
  196. package/core/styles/core.scss +10 -0
  197. package/core/styles.js +5 -5
  198. package/core/testing/event-spy.js +50 -46
  199. package/core/testing/mocha-extensions.js +10 -7
  200. package/core/testing/wait-for-condition.js +12 -10
  201. package/core/testing/wait-for-image-ready.js +16 -15
  202. package/core/testing/wait-for-render.js +13 -12
  203. package/core/testing.js +14 -6
  204. package/core.css +14 -0
  205. package/date-input/date-input.component.js +166 -2
  206. package/date-input.js +4 -5
  207. package/date-input.pure.js +4 -2
  208. package/datepicker/common/datepicker-button.js +102 -2
  209. package/datepicker/common.js +8 -5
  210. package/datepicker/datepicker/datepicker.component.js +120 -2
  211. package/datepicker/datepicker-next-day/datepicker-next-day.component.js +23 -27
  212. package/datepicker/datepicker-next-day.js +6 -3
  213. package/datepicker/datepicker-previous-day/datepicker-previous-day.component.js +23 -27
  214. package/datepicker/datepicker-previous-day.js +6 -3
  215. package/datepicker/datepicker-toggle/datepicker-toggle.component.js +51 -66
  216. package/datepicker/datepicker-toggle.js +6 -3
  217. package/datepicker/datepicker.js +7 -4
  218. package/datepicker.js +18 -9
  219. package/datepicker.pure.js +13 -5
  220. package/development/accordion/accordion.component.js +132 -2
  221. package/development/accordion.js +5 -8
  222. package/development/accordion.pure.js +5 -2
  223. package/development/action-group/action-group.component.js +305 -2
  224. package/development/action-group.js +5 -8
  225. package/development/action-group.pure.js +5 -2
  226. package/development/alert/alert/alert.component.js +385 -2
  227. package/development/alert/alert-group/alert-group.component.js +166 -2
  228. package/development/alert/alert-group.js +5 -7
  229. package/development/alert/alert.js +5 -7
  230. package/development/alert.js +7 -9
  231. package/development/alert.pure.js +7 -3
  232. package/development/autocomplete/autocomplete-base-element.js +897 -2
  233. package/development/autocomplete/autocomplete.component.js +72 -82
  234. package/development/autocomplete.js +6 -8
  235. package/development/autocomplete.pure.js +6 -2
  236. package/development/breadcrumb/breadcrumb/breadcrumb.component.js +77 -2
  237. package/development/breadcrumb/breadcrumb-group/breadcrumb-group.component.js +263 -2
  238. package/development/breadcrumb/breadcrumb-group.js +5 -7
  239. package/development/breadcrumb/breadcrumb.js +5 -7
  240. package/development/breadcrumb.js +7 -9
  241. package/development/breadcrumb.pure.js +7 -3
  242. package/development/button/accent-button/accent-button.component.js +13 -24
  243. package/development/button/accent-button-link/accent-button-link.component.js +13 -24
  244. package/development/button/accent-button-link.js +7 -9
  245. package/development/button/accent-button-static/accent-button-static.component.js +13 -24
  246. package/development/button/accent-button-static.js +7 -9
  247. package/development/button/accent-button.js +7 -9
  248. package/development/button/button/button.component.js +12 -23
  249. package/development/button/button-link/button-link.component.js +12 -23
  250. package/development/button/button-link.js +7 -9
  251. package/development/button/button-static/button-static.component.js +12 -23
  252. package/development/button/button-static.js +7 -9
  253. package/development/button/button.js +7 -9
  254. package/development/button/common/button-common.js +85 -104
  255. package/development/button/common.js +12 -2
  256. package/development/button/mini-button/mini-button.component.js +17 -28
  257. package/development/button/mini-button-group/mini-button-group.component.js +141 -2
  258. package/development/button/mini-button-group.js +7 -9
  259. package/development/button/mini-button-link/mini-button-link.component.js +34 -2
  260. package/development/button/mini-button-link.js +7 -9
  261. package/development/button/mini-button.js +7 -9
  262. package/development/button/secondary-button/secondary-button.component.js +12 -23
  263. package/development/button/secondary-button-link/secondary-button-link.component.js +12 -23
  264. package/development/button/secondary-button-link.js +7 -9
  265. package/development/button/secondary-button-static/secondary-button-static.component.js +12 -23
  266. package/development/button/secondary-button-static.js +7 -9
  267. package/development/button/secondary-button.js +7 -9
  268. package/development/button/transparent-button/transparent-button.component.js +12 -23
  269. package/development/button/transparent-button-link/transparent-button-link.component.js +12 -23
  270. package/development/button/transparent-button-link.js +7 -9
  271. package/development/button/transparent-button-static/transparent-button-static.component.js +12 -23
  272. package/development/button/transparent-button-static.js +7 -9
  273. package/development/button/transparent-button.js +7 -9
  274. package/development/button.js +29 -10
  275. package/development/button.pure.js +29 -4
  276. package/development/calendar/calendar/calendar.component.js +1984 -2
  277. package/development/calendar/calendar-day/calendar-day.component.js +248 -2
  278. package/development/calendar/calendar-day.js +5 -7
  279. package/development/calendar/calendar.js +7 -7
  280. package/development/calendar.js +9 -9
  281. package/development/calendar.pure.js +8 -3
  282. package/development/card/card/card.component.js +233 -2
  283. package/development/card/card-badge/card-badge.component.js +119 -2
  284. package/development/card/card-badge.js +5 -7
  285. package/development/card/card-button/card-button.component.js +11 -19
  286. package/development/card/card-button.js +4 -6
  287. package/development/card/card-link/card-link.component.js +11 -19
  288. package/development/card/card-link.js +4 -6
  289. package/development/card/card.js +5 -7
  290. package/development/card/common/card-action-common.js +121 -2
  291. package/development/card/common.js +5 -6
  292. package/development/card.js +11 -10
  293. package/development/card.pure.js +11 -4
  294. package/development/carousel/carousel/carousel.component.js +160 -2
  295. package/development/carousel/carousel-item/carousel-item.component.js +32 -2
  296. package/development/carousel/carousel-item.js +5 -7
  297. package/development/carousel/carousel-list/carousel-list.component.js +157 -2
  298. package/development/carousel/carousel-list.js +5 -7
  299. package/development/carousel/carousel.js +5 -7
  300. package/development/carousel.js +9 -10
  301. package/development/carousel.pure.js +9 -4
  302. package/development/checkbox/checkbox-group.js +1 -5
  303. package/development/checkbox/checkbox-panel.js +1 -5
  304. package/development/checkbox/checkbox.component.js +141 -3
  305. package/development/checkbox/checkbox.js +5 -8
  306. package/development/checkbox/common/checkbox-common.js +137 -2
  307. package/development/checkbox/common.js +6 -6
  308. package/development/checkbox-group/checkbox-group.component.js +212 -2
  309. package/development/checkbox-group.js +5 -8
  310. package/development/checkbox-group.pure.js +5 -2
  311. package/development/checkbox-panel/checkbox-panel.component.js +54 -81
  312. package/development/checkbox-panel.js +4 -7
  313. package/development/checkbox-panel.pure.js +4 -1
  314. package/development/checkbox.js +11 -12
  315. package/development/checkbox.pure.js +8 -3
  316. package/development/chip/chip/chip.component.js +164 -2
  317. package/development/chip/chip-group/chip-group.component.js +447 -2
  318. package/development/chip/chip-group.js +5 -7
  319. package/development/chip/chip.js +5 -7
  320. package/development/chip-label/chip-label.component.js +131 -2
  321. package/development/chip-label.js +5 -8
  322. package/development/chip-label.pure.js +5 -2
  323. package/development/chip.js +7 -9
  324. package/development/chip.pure.js +7 -3
  325. package/development/clock/clock.component.js +362 -2
  326. package/development/clock.js +5 -8
  327. package/development/clock.pure.js +5 -2
  328. package/development/container/container/container.component.js +182 -2
  329. package/development/container/container.js +5 -7
  330. package/development/container/sticky-bar/sticky-bar.component.js +357 -2
  331. package/development/container/sticky-bar.js +5 -7
  332. package/development/container.js +7 -9
  333. package/development/container.pure.js +7 -3
  334. package/development/core/a11y/arrow-navigation.js +28 -67
  335. package/development/core/a11y/fake-event-detection.js +8 -10
  336. package/development/core/a11y/focus-trap-controller.js +120 -104
  337. package/development/core/a11y/focus-visible-within-controller.js +24 -25
  338. package/development/core/a11y/focus.js +13 -14
  339. package/development/core/a11y/input-modality-detector.js +75 -128
  340. package/development/core/a11y/interactivity-checker.js +108 -115
  341. package/development/core/a11y/live-announcer.js +80 -76
  342. package/development/core/a11y.js +21 -3
  343. package/development/core/base-elements/action-base-element.js +42 -37
  344. package/development/core/base-elements/button-base-element.js +205 -247
  345. package/development/core/base-elements/element.js +67 -69
  346. package/development/core/base-elements/link-base-element.js +150 -226
  347. package/development/core/base-elements/open-close-base-element.js +49 -54
  348. package/development/core/base-elements.js +10 -2
  349. package/development/core/config/config.js +11 -9
  350. package/development/core/config.js +5 -1
  351. package/development/core/controllers/escapable-overlay-controller.js +36 -34
  352. package/development/core/controllers/id-reference-controller.js +81 -76
  353. package/development/core/controllers/inert-controller.js +105 -99
  354. package/development/core/controllers/language-controller.js +66 -76
  355. package/development/core/controllers/media-matchers-controller.js +138 -145
  356. package/development/core/controllers/overlay-position-controller.js +283 -297
  357. package/development/core/controllers/property-watcher-controller.js +119 -94
  358. package/development/core/controllers/slot-state-controller.js +63 -75
  359. package/development/core/controllers.js +23 -1
  360. package/development/core/datetime/date-adapter.js +166 -143
  361. package/development/core/datetime/native-date-adapter.js +148 -142
  362. package/development/core/datetime/temporal-date-adapter.js +149 -162
  363. package/development/core/datetime.js +14 -1
  364. package/development/core/decorators/base.js +2 -0
  365. package/development/core/decorators/force-type.js +27 -24
  366. package/development/core/decorators/get-override.js +17 -17
  367. package/development/core/decorators/handle-distinct-change.js +21 -20
  368. package/development/core/decorators/host-attributes.js +26 -37
  369. package/development/core/decorators/id-reference.js +114 -115
  370. package/development/core/decorators/omit-empty-converter.js +9 -13
  371. package/development/core/decorators/plain-date.js +31 -36
  372. package/development/core/decorators.js +11 -1
  373. package/development/core/dom/animation.js +9 -8
  374. package/development/core/dom/contains-pierce-shadow-dom.js +12 -12
  375. package/development/core/dom/lean-context.js +5 -9
  376. package/development/core/dom/platform.js +28 -35
  377. package/development/core/dom/queue-dom-content-loaded.js +10 -11
  378. package/development/core/dom/scroll.js +34 -34
  379. package/development/core/dom/set-or-remove-attribute.js +9 -13
  380. package/development/core/dom.js +21 -1
  381. package/development/core/eventing/composed-path-has-attribute.js +10 -17
  382. package/development/core/eventing/event-target.js +5 -7
  383. package/development/core/eventing/form-element-handlers.js +7 -10
  384. package/development/core/eventing/forward-event.js +7 -12
  385. package/development/core/eventing/is-event-prevented.js +6 -8
  386. package/development/core/eventing/throttle.js +17 -16
  387. package/development/core/eventing.js +9 -1
  388. package/development/core/i18n/i18n.js +875 -770
  389. package/development/core/i18n.js +104 -1
  390. package/development/core/images.js +15 -20
  391. package/development/core/interfaces.js +2 -0
  392. package/development/core/mixins/animation-complete-mixin.js +51 -55
  393. package/development/core/mixins/constructor.js +2 -0
  394. package/development/core/mixins/disabled-mixin.js +101 -124
  395. package/development/core/mixins/element-internals-mixin.js +225 -212
  396. package/development/core/mixins/form-associated-checkbox-mixin.js +141 -160
  397. package/development/core/mixins/form-associated-input-mixin.js +314 -334
  398. package/development/core/mixins/form-associated-mixin.js +279 -287
  399. package/development/core/mixins/form-associated-radio-button-mixin.js +247 -260
  400. package/development/core/mixins/hydration-mixin.js +55 -58
  401. package/development/core/mixins/named-slot-list-mixin.js +114 -116
  402. package/development/core/mixins/negative-mixin.js +41 -56
  403. package/development/core/mixins/panel-mixin.js +93 -142
  404. package/development/core/mixins/readonly-mixin.js +43 -54
  405. package/development/core/mixins/required-mixin.js +46 -65
  406. package/development/core/mixins/selection-panel-mixin.js +55 -50
  407. package/development/core/mixins/update-scheduler-mixin.js +25 -30
  408. package/development/core/mixins.js +29 -10
  409. package/development/core/overlay/overlay-option-panel.js +26 -34
  410. package/development/core/overlay/overlay-outside-pointer-event-listener.js +60 -64
  411. package/development/core/overlay/overlay-trigger-attributes.js +39 -42
  412. package/development/core/overlay/overlay.js +5 -10
  413. package/development/core/overlay/position.js +117 -143
  414. package/development/core/overlay.js +16 -2
  415. package/development/core/styles.js +5 -6
  416. package/development/core/testing/event-spy.js +67 -66
  417. package/development/core/testing/mocha-extensions.js +13 -15
  418. package/development/core/testing/wait-for-condition.js +17 -14
  419. package/development/core/testing/wait-for-image-ready.js +27 -20
  420. package/development/core/testing/wait-for-render.js +18 -30
  421. package/development/core/testing.js +10 -1
  422. package/development/date-input/date-input.component.js +278 -2
  423. package/development/date-input.js +5 -8
  424. package/development/date-input.pure.js +5 -2
  425. package/development/datepicker/common/datepicker-button.js +155 -2
  426. package/development/datepicker/common.js +7 -6
  427. package/development/datepicker/datepicker/datepicker.component.js +180 -2
  428. package/development/datepicker/datepicker-next-day/datepicker-next-day.component.js +30 -35
  429. package/development/datepicker/datepicker-next-day.js +4 -6
  430. package/development/datepicker/datepicker-previous-day/datepicker-previous-day.component.js +30 -35
  431. package/development/datepicker/datepicker-previous-day.js +4 -6
  432. package/development/datepicker/datepicker-toggle/datepicker-toggle.component.js +67 -79
  433. package/development/datepicker/datepicker-toggle.js +4 -6
  434. package/development/datepicker/datepicker.js +5 -7
  435. package/development/datepicker.js +12 -9
  436. package/development/datepicker.pure.js +12 -3
  437. package/development/dialog/dialog/dialog.component.js +383 -2
  438. package/development/dialog/dialog-actions/dialog-actions.component.js +42 -2
  439. package/development/dialog/dialog-actions.js +5 -7
  440. package/development/dialog/dialog-close-button/dialog-close-button.component.js +36 -2
  441. package/development/dialog/dialog-close-button.js +5 -7
  442. package/development/dialog/dialog-content/dialog-content.component.js +31 -2
  443. package/development/dialog/dialog-content.js +5 -7
  444. package/development/dialog/dialog-title/dialog-title.component.js +39 -2
  445. package/development/dialog/dialog-title.js +5 -7
  446. package/development/dialog/dialog.js +8 -7
  447. package/development/dialog.js +16 -12
  448. package/development/dialog.pure.js +16 -6
  449. package/development/divider/divider.component.js +73 -2
  450. package/development/divider.js +5 -8
  451. package/development/divider.pure.js +5 -2
  452. package/development/expansion-panel/expansion-panel/expansion-panel.component.js +417 -2
  453. package/development/expansion-panel/expansion-panel-content/expansion-panel-content.component.js +70 -2
  454. package/development/expansion-panel/expansion-panel-content.js +5 -7
  455. package/development/expansion-panel/expansion-panel-header/expansion-panel-header.component.js +170 -2
  456. package/development/expansion-panel/expansion-panel-header.js +5 -7
  457. package/development/expansion-panel/expansion-panel.js +5 -7
  458. package/development/expansion-panel.js +9 -10
  459. package/development/expansion-panel.pure.js +9 -4
  460. package/development/file-selector/common/file-selector-common.js +431 -2
  461. package/development/file-selector/common.js +6 -6
  462. package/development/file-selector/file-selector/file-selector.component.js +18 -27
  463. package/development/file-selector/file-selector-dropzone/file-selector-dropzone.component.js +126 -2
  464. package/development/file-selector/file-selector-dropzone.js +5 -7
  465. package/development/file-selector/file-selector.js +4 -6
  466. package/development/file-selector.js +9 -9
  467. package/development/file-selector.pure.js +9 -3
  468. package/development/flip-card/flip-card/flip-card.component.js +306 -2
  469. package/development/flip-card/flip-card-details/flip-card-details.component.js +69 -2
  470. package/development/flip-card/flip-card-details.js +5 -7
  471. package/development/flip-card/flip-card-summary/flip-card-summary.component.js +124 -2
  472. package/development/flip-card/flip-card-summary.js +5 -7
  473. package/development/flip-card/flip-card.js +5 -7
  474. package/development/flip-card.js +9 -10
  475. package/development/flip-card.pure.js +9 -4
  476. package/development/footer/footer.component.js +251 -2
  477. package/development/footer.js +5 -8
  478. package/development/footer.pure.js +5 -2
  479. package/development/form-field/error/error.component.js +83 -2
  480. package/development/form-field/error.js +5 -7
  481. package/development/form-field/form-field/form-field.component.js +892 -2
  482. package/development/form-field/form-field-clear/form-field-clear.component.js +41 -49
  483. package/development/form-field/form-field-clear.js +4 -6
  484. package/development/form-field/form-field.js +7 -7
  485. package/development/form-field.js +10 -9
  486. package/development/form-field.pure.js +9 -3
  487. package/development/header/common/header-action-common.js +329 -2
  488. package/development/header/common.js +5 -6
  489. package/development/header/header/header.component.js +385 -2
  490. package/development/header/header-button/header-button.component.js +7 -15
  491. package/development/header/header-button.js +4 -6
  492. package/development/header/header-environment/header-environment.component.js +88 -2
  493. package/development/header/header-environment.js +5 -7
  494. package/development/header/header-link/header-link.component.js +7 -15
  495. package/development/header/header-link.js +4 -6
  496. package/development/header/header.js +5 -7
  497. package/development/header.js +11 -10
  498. package/development/header.pure.js +11 -4
  499. package/development/icon/icon-base.js +174 -2
  500. package/development/icon/icon-name-mixin.js +59 -75
  501. package/development/icon/icon-request.js +38 -31
  502. package/development/icon/icon-validate.js +45 -36
  503. package/development/icon/icon.component.js +94 -119
  504. package/development/icon-sidebar/icon-sidebar/icon-sidebar.component.js +74 -2
  505. package/development/icon-sidebar/icon-sidebar-button/icon-sidebar-button.component.js +15 -25
  506. package/development/icon-sidebar/icon-sidebar-button.js +4 -6
  507. package/development/icon-sidebar/icon-sidebar-container/icon-sidebar-container.component.js +30 -2
  508. package/development/icon-sidebar/icon-sidebar-container.js +5 -7
  509. package/development/icon-sidebar/icon-sidebar-content/icon-sidebar-content.component.js +22 -2
  510. package/development/icon-sidebar/icon-sidebar-content.js +5 -7
  511. package/development/icon-sidebar/icon-sidebar-link/icon-sidebar-link.component.js +15 -25
  512. package/development/icon-sidebar/icon-sidebar-link.js +4 -6
  513. package/development/icon-sidebar/icon-sidebar.js +5 -7
  514. package/development/icon-sidebar-button-common-DR6eQvkq.js +93 -0
  515. package/development/icon-sidebar.js +11 -10
  516. package/development/icon-sidebar.pure.js +11 -4
  517. package/development/icon.js +12 -10
  518. package/development/icon.pure.js +12 -4
  519. package/development/image/image.component.js +648 -2
  520. package/development/image.js +5 -8
  521. package/development/image.pure.js +5 -2
  522. package/development/journey-header/journey-header.component.js +158 -2
  523. package/development/journey-header.js +5 -8
  524. package/development/journey-header.pure.js +5 -2
  525. package/development/lead-container/lead-container.component.js +108 -2
  526. package/development/lead-container.js +5 -8
  527. package/development/lead-container.pure.js +5 -2
  528. package/development/link/block-link/block-link.component.js +7 -15
  529. package/development/link/block-link-button/block-link-button.component.js +7 -15
  530. package/development/link/block-link-button.js +7 -9
  531. package/development/link/block-link-static/block-link-static.component.js +7 -15
  532. package/development/link/block-link-static.js +7 -9
  533. package/development/link/block-link.js +7 -9
  534. package/development/link/common/block-link-common.js +124 -3
  535. package/development/link/common/inline-link-common.js +44 -3
  536. package/development/link/common/link-common.js +10 -2
  537. package/development/link/common.js +9 -4
  538. package/development/link/link/link.component.js +7 -14
  539. package/development/link/link-button/link-button.component.js +7 -14
  540. package/development/link/link-button.js +7 -9
  541. package/development/link/link-static/link-static.component.js +7 -14
  542. package/development/link/link-static.js +7 -9
  543. package/development/link/link.js +7 -9
  544. package/development/link-common-d27fHmQw.js +111 -0
  545. package/development/link-list/common/link-list-base.js +131 -2
  546. package/development/link-list/common.js +6 -6
  547. package/development/link-list/link-list-anchor.js +5 -8
  548. package/development/link-list/link-list.component.js +152 -3
  549. package/development/link-list/link-list.js +5 -8
  550. package/development/link-list-anchor/link-list-anchor.component.js +61 -2
  551. package/development/link-list-anchor.js +5 -8
  552. package/development/link-list-anchor.pure.js +5 -2
  553. package/development/link-list.js +9 -11
  554. package/development/link-list.pure.js +8 -3
  555. package/development/link.js +15 -10
  556. package/development/link.pure.js +15 -5
  557. package/development/loading-indicator/loading-indicator.component.d.ts.map +1 -1
  558. package/development/loading-indicator/loading-indicator.component.js +243 -2
  559. package/development/loading-indicator-circle/loading-indicator-circle.component.d.ts.map +1 -1
  560. package/development/loading-indicator-circle/loading-indicator-circle.component.js +120 -2
  561. package/development/loading-indicator-circle.js +5 -8
  562. package/development/loading-indicator-circle.pure.js +5 -2
  563. package/development/loading-indicator.js +5 -8
  564. package/development/loading-indicator.pure.js +5 -2
  565. package/development/logo/logo.component.js +129 -2
  566. package/development/logo.js +5 -8
  567. package/development/logo.pure.js +5 -2
  568. package/development/map-container/map-container.component.js +281 -2
  569. package/development/map-container.js +5 -8
  570. package/development/map-container.pure.js +5 -2
  571. package/development/menu/common/menu-action-common.js +144 -2
  572. package/development/menu/common.js +5 -6
  573. package/development/menu/menu/menu.component.js +683 -2
  574. package/development/menu/menu-button/menu-button.component.js +8 -20
  575. package/development/menu/menu-button.js +4 -6
  576. package/development/menu/menu-link/menu-link.component.js +11 -21
  577. package/development/menu/menu-link.js +4 -6
  578. package/development/menu/menu.js +5 -7
  579. package/development/menu.js +9 -9
  580. package/development/menu.pure.js +9 -3
  581. package/development/message/message.component.js +67 -2
  582. package/development/message.js +5 -8
  583. package/development/message.pure.js +5 -2
  584. package/development/mini-button-label-common-BaMSfSTe.js +558 -0
  585. package/development/mini-calendar/mini-calendar/mini-calendar.component.js +188 -2
  586. package/development/mini-calendar/mini-calendar-day/mini-calendar-day.component.js +166 -2
  587. package/development/mini-calendar/mini-calendar-day.js +5 -7
  588. package/development/mini-calendar/mini-calendar-month/mini-calendar-month.component.js +135 -2
  589. package/development/mini-calendar/mini-calendar-month.js +5 -7
  590. package/development/mini-calendar/mini-calendar.js +5 -7
  591. package/development/mini-calendar.js +9 -10
  592. package/development/mini-calendar.pure.js +9 -4
  593. package/development/navigation/common/navigation-action-common.js +165 -2
  594. package/development/navigation/common.js +5 -6
  595. package/development/navigation/navigation/navigation.component.js +571 -2
  596. package/development/navigation/navigation-button/navigation-button.component.js +7 -14
  597. package/development/navigation/navigation-button.js +4 -6
  598. package/development/navigation/navigation-link/navigation-link.component.js +7 -14
  599. package/development/navigation/navigation-link.js +4 -6
  600. package/development/navigation/navigation-list/navigation-list.component.js +102 -2
  601. package/development/navigation/navigation-list.js +5 -7
  602. package/development/navigation/navigation-marker/navigation-marker.component.js +199 -2
  603. package/development/navigation/navigation-marker.js +5 -7
  604. package/development/navigation/navigation-section/navigation-section.component.js +588 -2
  605. package/development/navigation/navigation-section.js +5 -7
  606. package/development/navigation/navigation.js +5 -7
  607. package/development/navigation.js +15 -12
  608. package/development/navigation.pure.js +15 -6
  609. package/development/notification/notification.component.js +496 -2
  610. package/development/notification.js +5 -8
  611. package/development/notification.pure.js +5 -2
  612. package/development/option/optgroup/optgroup-base-element.js +159 -2
  613. package/development/option/optgroup/optgroup.component.js +37 -40
  614. package/development/option/optgroup.js +6 -7
  615. package/development/option/option/option-base-element.js +276 -349
  616. package/development/option/option/option.component.js +241 -2
  617. package/development/option/option-hint/option-hint.component.js +44 -2
  618. package/development/option/option-hint.js +5 -7
  619. package/development/option/option.js +6 -7
  620. package/development/option.js +11 -10
  621. package/development/option.pure.js +11 -4
  622. package/development/overlay/overlay-base-element.js +247 -238
  623. package/development/overlay/overlay.component.js +374 -2
  624. package/development/overlay.js +9 -8
  625. package/development/overlay.pure.js +9 -2
  626. package/development/paginator/common/paginator-common.js +272 -376
  627. package/development/paginator/common.js +4 -5
  628. package/development/paginator/compact-paginator/compact-paginator.component.js +87 -2
  629. package/development/paginator/compact-paginator.js +5 -7
  630. package/development/paginator/paginator/paginator.component.js +444 -2
  631. package/development/paginator/paginator.js +5 -7
  632. package/development/paginator.js +8 -9
  633. package/development/paginator.pure.js +8 -3
  634. package/development/popover/popover.component.js +718 -2
  635. package/development/popover.js +7 -8
  636. package/development/popover.pure.js +6 -2
  637. package/development/radio-button/common/radio-button-common.js +203 -2
  638. package/development/radio-button/common.js +6 -6
  639. package/development/radio-button/radio-button-group.js +1 -5
  640. package/development/radio-button/radio-button-panel.js +1 -5
  641. package/development/radio-button/radio-button.component.js +97 -3
  642. package/development/radio-button/radio-button.js +5 -8
  643. package/development/radio-button-group/radio-button-group.component.js +308 -2
  644. package/development/radio-button-group.js +5 -8
  645. package/development/radio-button-group.pure.js +5 -2
  646. package/development/radio-button-panel/radio-button-panel.component.js +82 -106
  647. package/development/radio-button-panel.js +4 -7
  648. package/development/radio-button-panel.pure.js +4 -1
  649. package/development/radio-button.js +11 -12
  650. package/development/radio-button.pure.js +8 -3
  651. package/development/sbb-tokens-DQT_xEIZ.js +19 -0
  652. package/development/screen-reader-only/screen-reader-only.component.js +25 -2
  653. package/development/screen-reader-only.js +5 -8
  654. package/development/screen-reader-only.pure.js +5 -2
  655. package/development/select/select.component.js +1087 -2
  656. package/development/select.js +5 -8
  657. package/development/select.pure.js +5 -2
  658. package/development/selection-action-panel/selection-action-panel.component.js +125 -2
  659. package/development/selection-action-panel.js +5 -8
  660. package/development/selection-action-panel.pure.js +5 -2
  661. package/development/selection-expansion-panel/selection-expansion-panel.component.js +306 -2
  662. package/development/selection-expansion-panel.js +5 -8
  663. package/development/selection-expansion-panel.pure.js +5 -2
  664. package/development/sidebar/common/styles.js +7 -2
  665. package/development/sidebar/common.js +7 -6
  666. package/development/sidebar/sidebar/sidebar.component.js +473 -2
  667. package/development/sidebar/sidebar-close-button/sidebar-close-button.component.js +36 -2
  668. package/development/sidebar/sidebar-close-button.js +5 -7
  669. package/development/sidebar/sidebar-container/sidebar-container.component.js +147 -2
  670. package/development/sidebar/sidebar-container.js +5 -7
  671. package/development/sidebar/sidebar-content/sidebar-content.component.js +25 -2
  672. package/development/sidebar/sidebar-content.js +5 -7
  673. package/development/sidebar/sidebar-title/sidebar-title.component.js +53 -2
  674. package/development/sidebar/sidebar-title.js +5 -7
  675. package/development/sidebar/sidebar.js +5 -7
  676. package/development/sidebar.js +13 -12
  677. package/development/sidebar.pure.js +13 -6
  678. package/development/signet/signet.component.js +151 -2
  679. package/development/signet.js +5 -8
  680. package/development/signet.pure.js +5 -2
  681. package/development/skiplink-list/skiplink-list.component.js +160 -2
  682. package/development/skiplink-list.js +5 -8
  683. package/development/skiplink-list.pure.js +5 -2
  684. package/development/slider/slider.component.js +399 -2
  685. package/development/slider.js +5 -8
  686. package/development/slider.pure.js +5 -2
  687. package/development/status/status.component.js +144 -2
  688. package/development/status.js +5 -8
  689. package/development/status.pure.js +5 -2
  690. package/development/stepper/step/step.component.js +216 -2
  691. package/development/stepper/step-label/step-label.component.js +298 -2
  692. package/development/stepper/step-label.js +5 -7
  693. package/development/stepper/step.js +5 -7
  694. package/development/stepper/stepper/stepper.component.js +465 -2
  695. package/development/stepper/stepper.js +7 -7
  696. package/development/stepper.js +11 -10
  697. package/development/stepper.pure.js +10 -4
  698. package/development/tab-label-common-Mfl36Rsa.js +171 -0
  699. package/development/table/table-wrapper/table-wrapper.component.js +120 -2
  700. package/development/table/table-wrapper.js +5 -7
  701. package/development/table.js +5 -8
  702. package/development/table.pure.js +5 -2
  703. package/development/tabs/common/styles.js +6 -2
  704. package/development/tabs/common.js +6 -6
  705. package/development/tabs/tab/tab.component.js +87 -2
  706. package/development/tabs/tab-group/tab-group.component.js +236 -2
  707. package/development/tabs/tab-group.js +5 -7
  708. package/development/tabs/tab-label/tab-label.component.js +369 -2
  709. package/development/tabs/tab-label.js +5 -7
  710. package/development/tabs/tab-nav-bar/tab-nav-bar.component.js +99 -2
  711. package/development/tabs/tab-nav-bar.js +5 -7
  712. package/development/tabs/tab.js +5 -7
  713. package/development/tabs.js +14 -12
  714. package/development/tabs.pure.js +14 -6
  715. package/development/tag/tag/tag.component.js +351 -2
  716. package/development/tag/tag-group/tag-group.component.js +179 -2
  717. package/development/tag/tag-group.js +5 -7
  718. package/development/tag/tag.js +5 -7
  719. package/development/tag.js +7 -9
  720. package/development/tag.pure.js +7 -3
  721. package/development/teaser/teaser.component.js +224 -2
  722. package/development/teaser-hero/teaser-hero.component.js +172 -2
  723. package/development/teaser-hero.js +5 -8
  724. package/development/teaser-hero.pure.js +5 -2
  725. package/development/teaser-product/common/teaser-product-common.js +210 -2
  726. package/development/teaser-product/common.js +6 -6
  727. package/development/teaser-product/teaser-product/teaser-product.component.js +63 -2
  728. package/development/teaser-product/teaser-product-static/teaser-product-static.component.js +8 -21
  729. package/development/teaser-product/teaser-product-static.js +4 -6
  730. package/development/teaser-product/teaser-product.js +5 -7
  731. package/development/teaser-product.js +9 -9
  732. package/development/teaser-product.pure.js +9 -3
  733. package/development/teaser.js +5 -8
  734. package/development/teaser.pure.js +5 -2
  735. package/development/time-input/time-input.component.js +213 -2
  736. package/development/time-input.js +5 -8
  737. package/development/time-input.pure.js +5 -2
  738. package/development/timetable-form/timetable-form/timetable-form.component.js +22 -2
  739. package/development/timetable-form/timetable-form-details/timetable-form-details.component.js +39 -2
  740. package/development/timetable-form/timetable-form-details.js +5 -7
  741. package/development/timetable-form/timetable-form-field/timetable-form-field.component.js +112 -2
  742. package/development/timetable-form/timetable-form-field.js +5 -7
  743. package/development/timetable-form/timetable-form-swap-button/timetable-form-swap-button.component.js +63 -2
  744. package/development/timetable-form/timetable-form-swap-button.js +5 -7
  745. package/development/timetable-form/timetable-form.js +5 -7
  746. package/development/timetable-form.js +11 -11
  747. package/development/timetable-form.pure.js +11 -5
  748. package/development/timetable-occupancy/timetable-occupancy.component.js +140 -2
  749. package/development/timetable-occupancy-icon/timetable-occupancy-icon.component.js +89 -2
  750. package/development/timetable-occupancy-icon.js +5 -8
  751. package/development/timetable-occupancy-icon.pure.js +5 -2
  752. package/development/timetable-occupancy.js +5 -8
  753. package/development/timetable-occupancy.pure.js +5 -2
  754. package/development/title/title-base.js +109 -2
  755. package/development/title/title.component.js +89 -3
  756. package/development/title.js +7 -9
  757. package/development/title.pure.js +7 -3
  758. package/development/toast/toast.component.js +401 -2
  759. package/development/toast.js +5 -8
  760. package/development/toast.pure.js +5 -2
  761. package/development/toggle/toggle/toggle.component.js +331 -2
  762. package/development/toggle/toggle-option/toggle-option.component.js +179 -2
  763. package/development/toggle/toggle-option.js +5 -7
  764. package/development/toggle/toggle.js +5 -7
  765. package/development/toggle-check/toggle-check.component.js +274 -2
  766. package/development/toggle-check.js +5 -8
  767. package/development/toggle-check.pure.js +5 -2
  768. package/development/toggle.js +7 -9
  769. package/development/toggle.pure.js +7 -3
  770. package/development/tooltip/tooltip.component.js +440 -2
  771. package/development/tooltip.js +5 -8
  772. package/development/tooltip.pure.js +5 -2
  773. package/development/train/train/train.component.js +229 -2
  774. package/development/train/train-blocked-passage/train-blocked-passage.component.js +70 -2
  775. package/development/train/train-blocked-passage.js +5 -7
  776. package/development/train/train-formation/train-formation.component.js +274 -2
  777. package/development/train/train-formation.js +5 -7
  778. package/development/train/train-wagon/train-wagon.component.js +387 -2
  779. package/development/train/train-wagon.js +5 -7
  780. package/development/train/train.js +5 -7
  781. package/development/train.js +11 -11
  782. package/development/train.pure.js +11 -5
  783. package/development/visual-checkbox/visual-checkbox.component.js +164 -2
  784. package/development/visual-checkbox.js +5 -8
  785. package/development/visual-checkbox.pure.js +5 -2
  786. package/dialog/dialog/dialog.component.js +148 -2
  787. package/dialog/dialog-actions/dialog-actions.component.js +13 -2
  788. package/dialog/dialog-actions.js +7 -4
  789. package/dialog/dialog-close-button/dialog-close-button.component.js +23 -2
  790. package/dialog/dialog-close-button.js +7 -4
  791. package/dialog/dialog-content/dialog-content.component.js +15 -2
  792. package/dialog/dialog-content.js +7 -4
  793. package/dialog/dialog-title/dialog-title.component.js +13 -2
  794. package/dialog/dialog-title.js +7 -4
  795. package/dialog/dialog.js +10 -4
  796. package/dialog.js +20 -9
  797. package/dialog.pure.js +15 -6
  798. package/divider/divider.component.js +44 -2
  799. package/divider.js +4 -5
  800. package/divider.pure.js +4 -2
  801. package/expansion-panel/expansion-panel/expansion-panel.component.js +156 -2
  802. package/expansion-panel/expansion-panel-content/expansion-panel-content.component.js +24 -2
  803. package/expansion-panel/expansion-panel-content.js +7 -4
  804. package/expansion-panel/expansion-panel-header/expansion-panel-header.component.js +57 -2
  805. package/expansion-panel/expansion-panel-header.js +7 -4
  806. package/expansion-panel/expansion-panel.js +7 -4
  807. package/expansion-panel.js +11 -7
  808. package/expansion-panel.pure.js +8 -4
  809. package/file-selector/common/file-selector-common.js +245 -2
  810. package/file-selector/common.js +7 -5
  811. package/file-selector/file-selector/file-selector.component.js +20 -25
  812. package/file-selector/file-selector-dropzone/file-selector-dropzone.component.js +75 -2
  813. package/file-selector/file-selector-dropzone.js +7 -4
  814. package/file-selector/file-selector.js +6 -3
  815. package/file-selector.js +11 -7
  816. package/file-selector.pure.js +9 -4
  817. package/flip-card/flip-card/flip-card.component.js +120 -2
  818. package/flip-card/flip-card-details/flip-card-details.component.js +36 -2
  819. package/flip-card/flip-card-details.js +7 -4
  820. package/flip-card/flip-card-summary/flip-card-summary.component.js +48 -2
  821. package/flip-card/flip-card-summary.js +7 -4
  822. package/flip-card/flip-card.js +7 -4
  823. package/flip-card.js +11 -7
  824. package/flip-card.pure.js +8 -4
  825. package/footer/footer.component.js +89 -2
  826. package/footer.js +4 -5
  827. package/footer.pure.js +4 -2
  828. package/form-field/error/error.component.js +42 -2
  829. package/form-field/error.js +7 -4
  830. package/form-field/form-field/form-field.component.js +344 -2
  831. package/form-field/form-field-clear/form-field-clear.component.js +28 -35
  832. package/form-field/form-field-clear.js +6 -3
  833. package/form-field/form-field.js +9 -4
  834. package/form-field.js +13 -7
  835. package/form-field.pure.js +9 -4
  836. package/header/common/header-action-common.js +51 -2
  837. package/header/common.js +6 -5
  838. package/header/header/header.component.js +154 -2
  839. package/header/header-button/header-button.component.js +8 -9
  840. package/header/header-button.js +6 -3
  841. package/header/header-environment/header-environment.component.js +29 -2
  842. package/header/header-environment.js +7 -4
  843. package/header/header-link/header-link.component.js +8 -9
  844. package/header/header-link.js +6 -3
  845. package/header/header.js +7 -4
  846. package/header.js +16 -9
  847. package/header.pure.js +12 -6
  848. package/icon/icon-base.js +105 -2
  849. package/icon/icon-name-mixin.js +50 -59
  850. package/icon/icon-request.js +29 -23
  851. package/icon/icon-validate.js +25 -19
  852. package/icon/icon.component.js +76 -88
  853. package/icon-sidebar/icon-sidebar/icon-sidebar.component.js +46 -2
  854. package/icon-sidebar/icon-sidebar-button/icon-sidebar-button.component.js +15 -19
  855. package/icon-sidebar/icon-sidebar-button.js +6 -3
  856. package/icon-sidebar/icon-sidebar-container/icon-sidebar-container.component.js +25 -2
  857. package/icon-sidebar/icon-sidebar-container.js +7 -4
  858. package/icon-sidebar/icon-sidebar-content/icon-sidebar-content.component.js +16 -2
  859. package/icon-sidebar/icon-sidebar-content.js +7 -4
  860. package/icon-sidebar/icon-sidebar-link/icon-sidebar-link.component.js +15 -19
  861. package/icon-sidebar/icon-sidebar-link.js +6 -3
  862. package/icon-sidebar/icon-sidebar.js +7 -4
  863. package/icon-sidebar-button-common-ffAscVDk.js +7 -0
  864. package/icon-sidebar.js +16 -8
  865. package/icon-sidebar.pure.js +12 -6
  866. package/icon.js +14 -10
  867. package/icon.pure.js +13 -6
  868. package/image/image.component.js +455 -2
  869. package/image.js +4 -5
  870. package/image.pure.js +4 -2
  871. package/journey-header/journey-header.component.js +95 -2
  872. package/journey-header.js +4 -5
  873. package/journey-header.pure.js +4 -2
  874. package/lead-container/lead-container.component.js +23 -2
  875. package/lead-container.js +4 -5
  876. package/lead-container.pure.js +4 -2
  877. package/link/block-link/block-link.component.js +8 -9
  878. package/link/block-link-button/block-link-button.component.js +9 -10
  879. package/link/block-link-button.js +6 -6
  880. package/link/block-link-static/block-link-static.component.js +9 -10
  881. package/link/block-link-static.js +4 -4
  882. package/link/block-link.js +6 -6
  883. package/link/common/block-link-common.js +44 -3
  884. package/link/common/inline-link-common.js +13 -3
  885. package/link/common/link-common.js +9 -2
  886. package/link/common.js +8 -4
  887. package/link/link/link.component.js +9 -10
  888. package/link/link-button/link-button.component.js +9 -10
  889. package/link/link-button.js +4 -4
  890. package/link/link-static/link-static.component.js +9 -10
  891. package/link/link-static.js +4 -4
  892. package/link/link.js +6 -6
  893. package/link-common-7IiqjmPD.js +45 -0
  894. package/link-list/common/link-list-base.js +90 -2
  895. package/link-list/common.js +7 -5
  896. package/link-list/link-list-anchor.js +8 -6
  897. package/link-list/link-list.component.js +47 -3
  898. package/link-list/link-list.js +7 -5
  899. package/link-list-anchor/link-list-anchor.component.js +10 -2
  900. package/link-list-anchor.js +4 -5
  901. package/link-list-anchor.pure.js +4 -2
  902. package/link-list.js +10 -8
  903. package/link-list.pure.js +7 -3
  904. package/link.js +25 -12
  905. package/link.pure.js +20 -11
  906. package/loading-indicator/loading-indicator.component.js +65 -2
  907. package/loading-indicator-circle/loading-indicator-circle.component.js +45 -2
  908. package/loading-indicator-circle.js +4 -5
  909. package/loading-indicator-circle.pure.js +4 -2
  910. package/loading-indicator.js +4 -5
  911. package/loading-indicator.pure.js +4 -2
  912. package/logo/logo.component.js +67 -2
  913. package/logo.js +4 -5
  914. package/logo.pure.js +4 -2
  915. package/map-container/map-container.component.js +110 -2
  916. package/map-container.js +4 -5
  917. package/map-container.pure.js +4 -2
  918. package/menu/common/menu-action-common.js +28 -2
  919. package/menu/common.js +6 -5
  920. package/menu/menu/menu.component.js +274 -2
  921. package/menu/menu-button/menu-button.component.js +9 -13
  922. package/menu/menu-button.js +6 -3
  923. package/menu/menu-link/menu-link.component.js +12 -13
  924. package/menu/menu-link.js +6 -3
  925. package/menu/menu.js +7 -4
  926. package/menu.js +12 -7
  927. package/menu.pure.js +10 -5
  928. package/message/message.component.js +23 -2
  929. package/message.js +4 -5
  930. package/message.pure.js +4 -2
  931. package/mini-button-label-common-Dx9JhmQ6.js +11 -0
  932. package/mini-calendar/mini-calendar/mini-calendar.component.js +131 -2
  933. package/mini-calendar/mini-calendar-day/mini-calendar-day.component.js +66 -2
  934. package/mini-calendar/mini-calendar-day.js +7 -4
  935. package/mini-calendar/mini-calendar-month/mini-calendar-month.component.js +63 -2
  936. package/mini-calendar/mini-calendar-month.js +7 -4
  937. package/mini-calendar/mini-calendar.js +7 -4
  938. package/mini-calendar.js +11 -7
  939. package/mini-calendar.pure.js +8 -4
  940. package/navigation/common/navigation-action-common.js +57 -2
  941. package/navigation/common.js +6 -5
  942. package/navigation/navigation/navigation.component.js +188 -2
  943. package/navigation/navigation-button/navigation-button.component.js +8 -9
  944. package/navigation/navigation-button.js +6 -3
  945. package/navigation/navigation-link/navigation-link.component.js +8 -9
  946. package/navigation/navigation-link.js +6 -3
  947. package/navigation/navigation-list/navigation-list.component.js +59 -2
  948. package/navigation/navigation-list.js +7 -4
  949. package/navigation/navigation-marker/navigation-marker.component.js +82 -2
  950. package/navigation/navigation-marker.js +7 -4
  951. package/navigation/navigation-section/navigation-section.component.js +224 -2
  952. package/navigation/navigation-section.js +7 -4
  953. package/navigation/navigation.js +7 -4
  954. package/navigation.js +22 -11
  955. package/navigation.pure.js +16 -8
  956. package/notification/notification.component.js +165 -2
  957. package/notification.js +4 -5
  958. package/notification.pure.js +4 -2
  959. package/off-brand-theme.css +14 -0
  960. package/option/optgroup/optgroup-base-element.js +83 -2
  961. package/option/optgroup/optgroup.component.js +30 -29
  962. package/option/optgroup.js +9 -5
  963. package/option/option/option-base-element.js +201 -257
  964. package/option/option/option.component.js +87 -2
  965. package/option/option-hint/option-hint.component.js +19 -2
  966. package/option/option-hint.js +7 -4
  967. package/option/option.js +9 -5
  968. package/option.js +15 -9
  969. package/option.pure.js +12 -6
  970. package/overlay/overlay-base-element.js +149 -154
  971. package/overlay/overlay.component.js +138 -2
  972. package/overlay.js +10 -7
  973. package/overlay.pure.js +9 -3
  974. package/package.json +2 -2
  975. package/paginator/common/paginator-common.js +201 -268
  976. package/paginator/common.js +6 -5
  977. package/paginator/compact-paginator/compact-paginator.component.js +40 -2
  978. package/paginator/compact-paginator.js +7 -4
  979. package/paginator/paginator/paginator.component.js +175 -2
  980. package/paginator/paginator.js +7 -4
  981. package/paginator.js +10 -7
  982. package/paginator.pure.js +7 -3
  983. package/popover/popover.component.js +316 -2
  984. package/popover.js +6 -5
  985. package/popover.pure.js +5 -2
  986. package/radio-button/common/radio-button-common.js +63 -2
  987. package/radio-button/common.js +7 -5
  988. package/radio-button/radio-button-group.js +3 -2
  989. package/radio-button/radio-button-panel.js +3 -2
  990. package/radio-button/radio-button.component.js +71 -3
  991. package/radio-button/radio-button.js +7 -5
  992. package/radio-button-group/radio-button-group.component.js +167 -2
  993. package/radio-button-group.js +5 -6
  994. package/radio-button-group.pure.js +4 -2
  995. package/radio-button-panel/radio-button-panel.component.js +68 -78
  996. package/radio-button-panel.js +3 -4
  997. package/radio-button-panel.pure.js +4 -2
  998. package/radio-button.js +13 -9
  999. package/radio-button.pure.js +7 -3
  1000. package/safety-theme.css +14 -0
  1001. package/sbb-tokens-HiNSQasB.js +11 -0
  1002. package/screen-reader-only/screen-reader-only.component.js +12 -2
  1003. package/screen-reader-only.js +4 -5
  1004. package/screen-reader-only.pure.js +4 -2
  1005. package/select/select.component.js +498 -2
  1006. package/select.js +4 -5
  1007. package/select.pure.js +4 -2
  1008. package/selection-action-panel/selection-action-panel.component.js +33 -2
  1009. package/selection-action-panel.js +4 -5
  1010. package/selection-action-panel.pure.js +4 -2
  1011. package/selection-expansion-panel/selection-expansion-panel.component.js +116 -2
  1012. package/selection-expansion-panel.js +4 -5
  1013. package/selection-expansion-panel.pure.js +4 -2
  1014. package/sidebar/common/styles.js +6 -2
  1015. package/sidebar/common.js +8 -5
  1016. package/sidebar/sidebar/sidebar.component.js +182 -2
  1017. package/sidebar/sidebar-close-button/sidebar-close-button.component.js +26 -2
  1018. package/sidebar/sidebar-close-button.js +7 -4
  1019. package/sidebar/sidebar-container/sidebar-container.component.js +76 -2
  1020. package/sidebar/sidebar-container.js +7 -4
  1021. package/sidebar/sidebar-content/sidebar-content.component.js +16 -2
  1022. package/sidebar/sidebar-content.js +7 -4
  1023. package/sidebar/sidebar-title/sidebar-title.component.js +39 -2
  1024. package/sidebar/sidebar-title.js +7 -4
  1025. package/sidebar/sidebar.js +7 -4
  1026. package/sidebar.js +17 -9
  1027. package/sidebar.pure.js +12 -6
  1028. package/signet/signet.component.js +74 -2
  1029. package/signet.js +4 -5
  1030. package/signet.pure.js +4 -2
  1031. package/skiplink-list/skiplink-list.component.js +77 -2
  1032. package/skiplink-list.js +4 -5
  1033. package/skiplink-list.pure.js +4 -2
  1034. package/slider/slider.component.js +200 -2
  1035. package/slider.js +4 -5
  1036. package/slider.pure.js +4 -2
  1037. package/standard-theme.css +14 -0
  1038. package/status/status.component.js +69 -2
  1039. package/status.js +4 -5
  1040. package/status.pure.js +4 -2
  1041. package/stepper/step/step.component.js +111 -2
  1042. package/stepper/step-label/step-label.component.js +96 -2
  1043. package/stepper/step-label.js +7 -4
  1044. package/stepper/step.js +7 -4
  1045. package/stepper/stepper/stepper.component.js +236 -2
  1046. package/stepper/stepper.js +9 -4
  1047. package/stepper.js +13 -7
  1048. package/stepper.pure.js +9 -4
  1049. package/tab-label-common-D6k40yRU.js +6 -0
  1050. package/table/table-wrapper/table-wrapper.component.js +70 -2
  1051. package/table/table-wrapper.js +7 -4
  1052. package/table.js +4 -5
  1053. package/table.pure.js +4 -2
  1054. package/tabs/common/styles.js +5 -2
  1055. package/tabs/common.js +7 -5
  1056. package/tabs/tab/tab.component.js +46 -2
  1057. package/tabs/tab-group/tab-group.component.js +167 -2
  1058. package/tabs/tab-group.js +7 -4
  1059. package/tabs/tab-label/tab-label.component.js +128 -2
  1060. package/tabs/tab-label.js +7 -4
  1061. package/tabs/tab-nav-bar/tab-nav-bar.component.js +67 -2
  1062. package/tabs/tab-nav-bar.js +7 -4
  1063. package/tabs/tab.js +7 -4
  1064. package/tabs.js +17 -9
  1065. package/tabs.pure.js +13 -6
  1066. package/tag/tag/tag.component.js +128 -2
  1067. package/tag/tag-group/tag-group.component.js +119 -2
  1068. package/tag/tag-group.js +7 -4
  1069. package/tag/tag.js +7 -4
  1070. package/tag.js +8 -6
  1071. package/tag.pure.js +6 -3
  1072. package/teaser/teaser.component.js +80 -2
  1073. package/teaser-hero/teaser-hero.component.js +62 -2
  1074. package/teaser-hero.js +4 -5
  1075. package/teaser-hero.pure.js +4 -2
  1076. package/teaser-product/common/teaser-product-common.js +54 -2
  1077. package/teaser-product/common.js +7 -5
  1078. package/teaser-product/teaser-product/teaser-product.component.js +28 -2
  1079. package/teaser-product/teaser-product-static/teaser-product-static.component.js +9 -13
  1080. package/teaser-product/teaser-product-static.js +6 -3
  1081. package/teaser-product/teaser-product.js +7 -4
  1082. package/teaser-product.js +11 -7
  1083. package/teaser-product.pure.js +9 -4
  1084. package/teaser.js +4 -5
  1085. package/teaser.pure.js +4 -2
  1086. package/time-input/time-input.component.js +128 -2
  1087. package/time-input.js +4 -5
  1088. package/time-input.pure.js +4 -2
  1089. package/timetable-form/timetable-form/timetable-form.component.js +12 -2
  1090. package/timetable-form/timetable-form-details/timetable-form-details.component.js +12 -2
  1091. package/timetable-form/timetable-form-details.js +7 -4
  1092. package/timetable-form/timetable-form-field/timetable-form-field.component.js +26 -2
  1093. package/timetable-form/timetable-form-field.js +7 -4
  1094. package/timetable-form/timetable-form-swap-button/timetable-form-swap-button.component.js +33 -2
  1095. package/timetable-form/timetable-form-swap-button.js +7 -4
  1096. package/timetable-form/timetable-form.js +7 -4
  1097. package/timetable-form.js +14 -8
  1098. package/timetable-form.pure.js +10 -5
  1099. package/timetable-occupancy/timetable-occupancy.component.js +77 -2
  1100. package/timetable-occupancy-icon/timetable-occupancy-icon.component.js +61 -2
  1101. package/timetable-occupancy-icon.js +4 -5
  1102. package/timetable-occupancy-icon.pure.js +4 -2
  1103. package/timetable-occupancy.js +4 -5
  1104. package/timetable-occupancy.pure.js +4 -2
  1105. package/title/title-base.js +53 -2
  1106. package/title/title.component.js +37 -3
  1107. package/title.js +7 -7
  1108. package/title.pure.js +6 -3
  1109. package/toast/toast.component.js +180 -2
  1110. package/toast.js +4 -5
  1111. package/toast.pure.js +4 -2
  1112. package/toggle/toggle/toggle.component.js +147 -2
  1113. package/toggle/toggle-option/toggle-option.component.js +90 -2
  1114. package/toggle/toggle-option.js +7 -4
  1115. package/toggle/toggle.js +7 -4
  1116. package/toggle-check/toggle-check.component.js +85 -2
  1117. package/toggle-check.js +4 -5
  1118. package/toggle-check.pure.js +4 -2
  1119. package/toggle.js +8 -6
  1120. package/toggle.pure.js +6 -3
  1121. package/tooltip/tooltip.component.js +197 -2
  1122. package/tooltip.js +4 -5
  1123. package/tooltip.pure.js +4 -2
  1124. package/train/train/train.component.js +123 -2
  1125. package/train/train-blocked-passage/train-blocked-passage.component.js +19 -2
  1126. package/train/train-blocked-passage.js +7 -4
  1127. package/train/train-formation/train-formation.component.js +93 -2
  1128. package/train/train-formation.js +7 -4
  1129. package/train/train-wagon/train-wagon.component.js +174 -2
  1130. package/train/train-wagon.js +7 -4
  1131. package/train/train.js +7 -4
  1132. package/train.js +14 -8
  1133. package/train.pure.js +10 -5
  1134. package/visual-checkbox/visual-checkbox.component.js +81 -2
  1135. package/visual-checkbox.js +4 -5
  1136. package/visual-checkbox.pure.js +4 -2
  1137. package/accordion.component-DmaGQH3Q.js +0 -127
  1138. package/action-group.component-KWugkMGf.js +0 -158
  1139. package/alert-group.component-RV1M1OKy.js +0 -141
  1140. package/alert.component-PPR7hfTi.js +0 -165
  1141. package/autocomplete-base-element-DVFCZ4lt.js +0 -425
  1142. package/block-link-common-D4aizuV-.js +0 -63
  1143. package/breadcrumb-group.component-BA8KK3Om.js +0 -145
  1144. package/breadcrumb.component-DjkZzGJD.js +0 -24
  1145. package/calendar-day.component-DqAXvoP3.js +0 -113
  1146. package/calendar.component-BgZDy-rX.js +0 -1246
  1147. package/card-action-common-GpkaNYtV.js +0 -88
  1148. package/card-badge.component-D_PI9Ega.js +0 -65
  1149. package/card.component-Dt2YFmd3.js +0 -62
  1150. package/carousel-item.component-kv3rY8B-.js +0 -25
  1151. package/carousel-list.component-DMMk66SP.js +0 -91
  1152. package/carousel.component-Bd0iGUbf.js +0 -97
  1153. package/checkbox-common-D9htxWLZ.js +0 -68
  1154. package/checkbox-group.component-CNAwwaS0.js +0 -146
  1155. package/checkbox.component-CJcC5JnN.js +0 -125
  1156. package/chip-group.component-DR6GoGCB.js +0 -283
  1157. package/chip-label.component-DBN4jfW7.js +0 -80
  1158. package/chip.component-BNOs8T6O.js +0 -94
  1159. package/clock.component-DDaWbXHW.js +0 -148
  1160. package/common-CI_BB6sF.js +0 -5
  1161. package/compact-paginator.component-BxSy5YXY.js +0 -45
  1162. package/container.component-DXFIvseq.js +0 -117
  1163. package/date-input.component-zZtnd9Og.js +0 -205
  1164. package/datepicker-button-C1TrzFl-.js +0 -109
  1165. package/datepicker.component-cmdnlVgf.js +0 -156
  1166. package/development/accordion.component-BIFcgIa0.js +0 -172
  1167. package/development/action-group.component-CuhO6yb9.js +0 -379
  1168. package/development/alert-group.component-BlrlsRB8.js +0 -219
  1169. package/development/alert.component-CJ2yLyOY.js +0 -411
  1170. package/development/autocomplete-base-element-DCfmuVY6.js +0 -960
  1171. package/development/block-link-common-FvD8So7p.js +0 -145
  1172. package/development/breadcrumb-group.component-DjsoMTPI.js +0 -278
  1173. package/development/breadcrumb.component-DvOf-PiO.js +0 -89
  1174. package/development/calendar-day.component-De9Xn3-q.js +0 -283
  1175. package/development/calendar.component-PHpgLc0z.js +0 -2458
  1176. package/development/card-action-common-DqBn3bPy.js +0 -147
  1177. package/development/card-badge.component-Cs4dow18.js +0 -146
  1178. package/development/card.component-CeOZXXWU.js +0 -258
  1179. package/development/carousel-item.component-DOIXA2QK.js +0 -47
  1180. package/development/carousel-list.component-7Z3dYtAF.js +0 -160
  1181. package/development/carousel.component-b4C-hxkj.js +0 -169
  1182. package/development/checkbox-common-DD7r8g0_.js +0 -147
  1183. package/development/checkbox-group.component-CRZO7CEc.js +0 -265
  1184. package/development/checkbox.component-B43Akyck.js +0 -193
  1185. package/development/chip-group.component-CeRAIWg-.js +0 -493
  1186. package/development/chip-label.component-jN_Fulv_.js +0 -165
  1187. package/development/chip.component-Bn7ffNEr.js +0 -191
  1188. package/development/clock.component-btjeVAaa.js +0 -392
  1189. package/development/common-Da_cep8M.js +0 -565
  1190. package/development/compact-paginator.component-CCDP0TMd.js +0 -96
  1191. package/development/container.component-CVm8-HZ4.js +0 -238
  1192. package/development/date-input.component-CqsEOZfb.js +0 -338
  1193. package/development/datepicker-button-BORzfDaA.js +0 -167
  1194. package/development/datepicker.component-CuFtPZg9.js +0 -223
  1195. package/development/dialog-actions.component-Mbx-Bs3t.js +0 -55
  1196. package/development/dialog-close-button.component-B1dPHPy2.js +0 -48
  1197. package/development/dialog-content.component-qP09Yo_N.js +0 -42
  1198. package/development/dialog-title.component-B4u2w8h5.js +0 -50
  1199. package/development/dialog.component-DaM1FSHB.js +0 -403
  1200. package/development/divider.component-Ddzlu6Fw.js +0 -95
  1201. package/development/error.component-C76eZnXo.js +0 -93
  1202. package/development/expansion-panel-content.component-DTZk3ZKL.js +0 -77
  1203. package/development/expansion-panel-header.component-C7ymZCux.js +0 -175
  1204. package/development/expansion-panel.component-xUWTKeaC.js +0 -489
  1205. package/development/file-selector-common-qMfAccOd.js +0 -512
  1206. package/development/file-selector-dropzone.component-HDUIUSQI.js +0 -154
  1207. package/development/flip-card-details.component-BilGh5Yb.js +0 -85
  1208. package/development/flip-card-summary.component-DDDnvs_c.js +0 -151
  1209. package/development/flip-card.component-CdRzb7IT.js +0 -334
  1210. package/development/footer.component-C057PwF1.js +0 -310
  1211. package/development/form-field.component-D4dQ8sCh.js +0 -1009
  1212. package/development/header-action-common-Dff8K0RB.js +0 -346
  1213. package/development/header-environment.component-DYnJkxCZ.js +0 -101
  1214. package/development/header.component-DYls7wGO.js +0 -446
  1215. package/development/icon-base-CcQCgmqX.js +0 -206
  1216. package/development/icon-sidebar-container.component-BJHjpF-Q.js +0 -41
  1217. package/development/icon-sidebar-content.component-C2wreczL.js +0 -33
  1218. package/development/icon-sidebar.component-PcmjRlDp.js +0 -100
  1219. package/development/image.component-fvsSR3Df.js +0 -820
  1220. package/development/inline-link-common-CyTcO5MN.js +0 -52
  1221. package/development/journey-header.component-BB8WYOqH.js +0 -217
  1222. package/development/lead-container.component-BGf8oqw7.js +0 -122
  1223. package/development/link-common-5ob2nFyv.js +0 -124
  1224. package/development/link-list-anchor.component-rAMp5_jH.js +0 -77
  1225. package/development/link-list-base-DxYNcAX7.js +0 -172
  1226. package/development/link-list.component-DD6UjlwD.js +0 -194
  1227. package/development/loading-indicator-circle.component-C0epUACB.js +0 -159
  1228. package/development/loading-indicator.component-CVdBjI99.js +0 -283
  1229. package/development/logo.component-Cp-EyVpA.js +0 -166
  1230. package/development/map-container.component-DUA7-arY.js +0 -324
  1231. package/development/menu-action-common-CyBv0NwR.js +0 -148
  1232. package/development/menu.component-GHJHhE9D.js +0 -638
  1233. package/development/message.component-uv9eI2gl.js +0 -82
  1234. package/development/mini-button-group.component-ytJZBjmr.js +0 -174
  1235. package/development/mini-button-link.component-DZOOdeZt.js +0 -47
  1236. package/development/mini-calendar-day.component-DLP7Pa6R.js +0 -213
  1237. package/development/mini-calendar-month.component-C1jsGlJ2.js +0 -150
  1238. package/development/mini-calendar.component-BzqjMchx.js +0 -192
  1239. package/development/navigation-action-common-saGbvoji.js +0 -178
  1240. package/development/navigation-list.component-AFM4omXQ.js +0 -124
  1241. package/development/navigation-marker.component-BvC73IoI.js +0 -207
  1242. package/development/navigation-section.component-B-6XU2X5.js +0 -600
  1243. package/development/navigation.component-_gUhpPyO.js +0 -585
  1244. package/development/notification.component-B5EBKKf8.js +0 -530
  1245. package/development/optgroup-base-element-CjwAXrC5.js +0 -181
  1246. package/development/option-hint.component-CHS5Z_sK.js +0 -55
  1247. package/development/option.component-BvOsW8Gn.js +0 -248
  1248. package/development/overlay.component-RS_v3xaA.js +0 -411
  1249. package/development/paginator.component-cRqJW9bc.js +0 -492
  1250. package/development/popover.component-BTfbUEzF.js +0 -745
  1251. package/development/radio-button-common-CjbP9yKf.js +0 -231
  1252. package/development/radio-button-group.component-5jDkRqSJ.js +0 -404
  1253. package/development/radio-button.component-CVATlwTb.js +0 -137
  1254. package/development/sbb-tokens-Dajio3u-.js +0 -13
  1255. package/development/screen-reader-only.component-D-KOAjrF.js +0 -36
  1256. package/development/select.component-DyF5Tw3J.js +0 -1084
  1257. package/development/selection-action-panel.component-elyz1Xsb.js +0 -134
  1258. package/development/selection-expansion-panel.component-hL2jyaAT.js +0 -326
  1259. package/development/sidebar-close-button.component-j4wY_hAt.js +0 -48
  1260. package/development/sidebar-container.component-CToGMqKH.js +0 -136
  1261. package/development/sidebar-content.component-s3GsQtNv.js +0 -37
  1262. package/development/sidebar-title.component-Htm_hqKX.js +0 -76
  1263. package/development/sidebar.component-Ct6TAsph.js +0 -506
  1264. package/development/signet.component-COqrcZqk.js +0 -188
  1265. package/development/skiplink-list.component-_SDkIoHp.js +0 -198
  1266. package/development/slider.component-B7EFECZk.js +0 -479
  1267. package/development/status.component-CE3e9OIO.js +0 -171
  1268. package/development/step-label.component-BH28AI5Z.js +0 -298
  1269. package/development/step.component-WY7qdrR8.js +0 -220
  1270. package/development/stepper.component-D1tAcpWs.js +0 -508
  1271. package/development/sticky-bar.component-BlgfxSRo.js +0 -382
  1272. package/development/styles-CIZBf9Yc.js +0 -173
  1273. package/development/styles-CYlzu-f2.js +0 -96
  1274. package/development/tab-group.component-DZPKWjI7.js +0 -292
  1275. package/development/tab-label.component-BJgr4u6Z.js +0 -420
  1276. package/development/tab-nav-bar.component-rNmuMIsv.js +0 -123
  1277. package/development/tab.component-C8jaB2_O.js +0 -101
  1278. package/development/table-wrapper.component-6WtB_fHq.js +0 -133
  1279. package/development/tag-group.component-C-EXr8Rq.js +0 -219
  1280. package/development/tag.component-B7RY4cfx.js +0 -419
  1281. package/development/teaser-hero.component-5vVIZZ9L.js +0 -202
  1282. package/development/teaser-product-common-DgnRgO6O.js +0 -223
  1283. package/development/teaser-product.component-BsdU2W2T.js +0 -75
  1284. package/development/teaser.component-KRkFbP9-.js +0 -243
  1285. package/development/time-input.component-Cf6cXrIN.js +0 -222
  1286. package/development/timetable-form-details.component-B--aGycf.js +0 -50
  1287. package/development/timetable-form-field.component-9jwIZzIm.js +0 -119
  1288. package/development/timetable-form-swap-button.component-Ne1-XwSf.js +0 -74
  1289. package/development/timetable-form.component-BYHhDRXE.js +0 -34
  1290. package/development/timetable-occupancy-icon.component-BbW73Fqd.js +0 -101
  1291. package/development/timetable-occupancy.component-C3nWG5Vg.js +0 -172
  1292. package/development/title-base-BUQgNaUI.js +0 -142
  1293. package/development/title.component-DgFvxLIt.js +0 -115
  1294. package/development/toast.component-Csifrfnq.js +0 -430
  1295. package/development/toggle-check.component-CEYmGCDZ.js +0 -326
  1296. package/development/toggle-option.component--wHdeFI6.js +0 -216
  1297. package/development/toggle.component-CGNDEU9B.js +0 -367
  1298. package/development/tooltip.component-bVPXm6Pu.js +0 -480
  1299. package/development/train-blocked-passage.component-CYnTeq7k.js +0 -79
  1300. package/development/train-formation.component-QmoA0u6E.js +0 -303
  1301. package/development/train-wagon.component-CWlRDq-Z.js +0 -485
  1302. package/development/train.component-DcMyi7HP.js +0 -294
  1303. package/development/visual-checkbox.component-DtEIq9rH.js +0 -213
  1304. package/dialog-actions.component-B4JYi2Ym.js +0 -17
  1305. package/dialog-close-button.component-BtxXASCn.js +0 -27
  1306. package/dialog-content.component-CNhoC-NZ.js +0 -19
  1307. package/dialog-title.component-C8Jsbuqt.js +0 -17
  1308. package/dialog.component-BHsekf9B.js +0 -170
  1309. package/divider.component-DFw-P_dA.js +0 -61
  1310. package/error.component-DL9hm4i9.js +0 -44
  1311. package/expansion-panel-content.component-CbWIxgH4.js +0 -29
  1312. package/expansion-panel-header.component-CxLeXeGi.js +0 -56
  1313. package/expansion-panel.component-Bs4icI9T.js +0 -226
  1314. package/file-selector-common-C-gZH55c.js +0 -313
  1315. package/file-selector-dropzone.component-LHNtOZPr.js +0 -94
  1316. package/flip-card-details.component-CiiCNjd2.js +0 -45
  1317. package/flip-card-summary.component-nO7zKRiB.js +0 -65
  1318. package/flip-card.component-uSdokrC9.js +0 -138
  1319. package/footer.component-Cdsiwn4D.js +0 -129
  1320. package/form-field.component-CZzQYOSP.js +0 -447
  1321. package/header-action-common-C2YPvOxq.js +0 -62
  1322. package/header-environment.component-KqUmsOPQ.js +0 -36
  1323. package/header.component-BssLZ6b7.js +0 -203
  1324. package/icon-base-BYJzaEDb.js +0 -127
  1325. package/icon-sidebar-container.component-BcoT4uhN.js +0 -26
  1326. package/icon-sidebar-content.component-toRpXgxi.js +0 -20
  1327. package/icon-sidebar.component-B5xCvDvj.js +0 -62
  1328. package/image.component-Cq2t-XZu.js +0 -413
  1329. package/inline-link-common-Dgdi7qpI.js +0 -18
  1330. package/journey-header.component-CR8AO0b2.js +0 -143
  1331. package/lead-container.component-CXKHfBiS.js +0 -27
  1332. package/link-common-CYxyP4XZ.js +0 -52
  1333. package/link-list-anchor.component--u5j_aqv.js +0 -18
  1334. package/link-list-base-CzFYpTOG.js +0 -115
  1335. package/link-list.component-9ndHNGPS.js +0 -78
  1336. package/loading-indicator-circle.component-CjJkIeJ0.js +0 -64
  1337. package/loading-indicator.component-BrVz6vJo.js +0 -94
  1338. package/logo.component-nxragzaC.js +0 -94
  1339. package/map-container.component-BfxezELq.js +0 -130
  1340. package/menu-action-common-BcB_Tyvl.js +0 -29
  1341. package/menu.component-BdqUbvww.js +0 -252
  1342. package/message.component-DbmXg6DI.js +0 -27
  1343. package/mini-button-group.component-D5Dph1Z7.js +0 -89
  1344. package/mini-button-link.component-BYK_EUud.js +0 -31
  1345. package/mini-calendar-day.component-cAawa9Gr.js +0 -106
  1346. package/mini-calendar-month.component-DiYSVb-Y.js +0 -74
  1347. package/mini-calendar.component-DpPMb47Y.js +0 -144
  1348. package/navigation-action-common-Dcb95pqU.js +0 -64
  1349. package/navigation-list.component-BhV-uAfU.js +0 -71
  1350. package/navigation-marker.component-CIUu5VVZ.js +0 -88
  1351. package/navigation-section.component-DwEXj603.js +0 -237
  1352. package/navigation.component-BYqJ9Cqt.js +0 -208
  1353. package/notification.component-DZS8z1oa.js +0 -197
  1354. package/optgroup-base-element-DWKHCat8.js +0 -107
  1355. package/option-hint.component-Goyhv5ss.js +0 -23
  1356. package/option.component-uzmmREt4.js +0 -98
  1357. package/overlay.component-r0Rp_b-3.js +0 -163
  1358. package/paginator.component-D_fV260x.js +0 -206
  1359. package/popover.component-Dh9vbuDG.js +0 -353
  1360. package/radio-button-common-CCQ3bJPI.js +0 -77
  1361. package/radio-button-group.component-Cf8r6Whf.js +0 -232
  1362. package/radio-button.component-B5b5OhBw.js +0 -93
  1363. package/sbb-tokens-BJzKBCf8.js +0 -4
  1364. package/screen-reader-only.component-B06hVxPg.js +0 -16
  1365. package/select.component-BZbDGrv8.js +0 -522
  1366. package/selection-action-panel.component-_kh6l2sj.js +0 -35
  1367. package/selection-expansion-panel.component-ChMYCw38.js +0 -144
  1368. package/sidebar-close-button.component-B9QGnQLs.js +0 -30
  1369. package/sidebar-container.component-BW24Ap9F.js +0 -63
  1370. package/sidebar-content.component-DSTp9Iu6.js +0 -20
  1371. package/sidebar-title.component-COjEsAkk.js +0 -53
  1372. package/sidebar.component-C2YYQj-Q.js +0 -238
  1373. package/signet.component-CixiIpLj.js +0 -101
  1374. package/skiplink-list.component-CINJgt_l.js +0 -102
  1375. package/slider.component-BhtuB-8p.js +0 -249
  1376. package/status.component-BZ8zajOL.js +0 -83
  1377. package/step-label.component-COJYo-MI.js +0 -82
  1378. package/step.component-BIOQdZVR.js +0 -94
  1379. package/stepper.component-D2vhtDCy.js +0 -286
  1380. package/sticky-bar.component-CYCOEGz7.js +0 -141
  1381. package/styles-DpIXFSVm.js +0 -5
  1382. package/styles-uZGSPqgK.js +0 -5
  1383. package/tab-group.component-nprcnwFB.js +0 -185
  1384. package/tab-label.component-BeLuYRBg.js +0 -165
  1385. package/tab-nav-bar.component-Du1JyNtu.js +0 -81
  1386. package/tab.component-D8Rz05Fo.js +0 -48
  1387. package/table-wrapper.component-DkaL4T5V.js +0 -83
  1388. package/tag-group.component-CW6Z9-P6.js +0 -143
  1389. package/tag.component-CvZpvIuw.js +0 -170
  1390. package/teaser-hero.component-Dolg4-Yz.js +0 -80
  1391. package/teaser-product-common-q2IZHbkr.js +0 -62
  1392. package/teaser-product.component-DVdyKe6h.js +0 -29
  1393. package/teaser.component-DPvDVG6b.js +0 -91
  1394. package/time-input.component-ChWhDF5l.js +0 -141
  1395. package/timetable-form-details.component-Du6WPn3y.js +0 -16
  1396. package/timetable-form-field.component-Cb3FYKL7.js +0 -32
  1397. package/timetable-form-swap-button.component-ByQDf7oy.js +0 -37
  1398. package/timetable-form.component-BqokC_4S.js +0 -16
  1399. package/timetable-occupancy-icon.component-BhXQSFZR.js +0 -72
  1400. package/timetable-occupancy.component-DnaQ0TIW.js +0 -101
  1401. package/title-base-D4nE41tH.js +0 -80
  1402. package/title.component-DNBy2mIm.js +0 -54
  1403. package/toast.component-B9Gm8Kls.js +0 -189
  1404. package/toggle-check.component-BcxMe5Zi.js +0 -119
  1405. package/toggle-option.component-DvdEjT2c.js +0 -123
  1406. package/toggle.component-Lnj5TugJ.js +0 -161
  1407. package/tooltip.component-B5fKuZdI.js +0 -228
  1408. package/train-blocked-passage.component-Dz7lD_V1.js +0 -23
  1409. package/train-formation.component-CGTqQgp7.js +0 -121
  1410. package/train-wagon.component-BW-JxcK6.js +0 -259
  1411. package/train.component-B_Nlu8Kh.js +0 -176
  1412. package/visual-checkbox.component-bB_pG0vn.js +0 -118
@@ -1,2 +1,1227 @@
1
- import { n as e, t } from "../../calendar.component-BgZDy-rX.js";
2
- export { t as SbbCalendarElement, e as SbbMonthChangeEvent };
1
+ var Ye = (o) => {
2
+ throw TypeError(o);
3
+ };
4
+ var ze = (o, n, d) => n.has(o) || Ye("Cannot " + d);
5
+ var A = (o, n, d) => (ze(o, n, "read from private field"), d ? d.call(o) : n.get(o)), x = (o, n, d) => n.has(o) ? Ye("Cannot add the same private member more than once") : n instanceof WeakSet ? n.add(o) : n.set(o, d), _ = (o, n, d, h) => (ze(o, n, "write to private field"), h ? h.call(o, d) : n.set(o, d), d);
6
+ import { __esDecorate as w, __runInitializers as u } from "tslib";
7
+ import { css as Se, isServer as Fe, nothing as p, html as c } from "lit";
8
+ import { property as Y, state as Q } from "lit/decorators.js";
9
+ import { classMap as J } from "lit/directives/class-map.js";
10
+ import { isArrowKeyOrPageKeysPressed as Te } from "../../core/a11y.js";
11
+ import { SbbElement as Pe } from "../../core/base-elements.js";
12
+ import { readConfig as Ee } from "../../core/config.js";
13
+ import { SbbLanguageController as Le, SbbMediaMatcherController as Be, SbbMediaQueryBreakpointLargeAndAbove as Oe } from "../../core/controllers.js";
14
+ import { defaultDateAdapter as He, YEARS_PER_PAGE as $, DAYS_PER_ROW as y, MONTHS_PER_ROW as j, YEARS_PER_ROW as G, MONTHS_PER_PAGE as qe } from "../../core/datetime.js";
15
+ import { forceType as X, plainDate as We, handleDistinctChange as Ke } from "../../core/decorators.js";
16
+ import { i18nPreviousMonth as Ue, i18nNextMonth as Qe, i18nYearMonthSelection as je, i18nCalendarWeekNumber as K, i18nPreviousYear as Ge, i18nNextYear as Je, i18nCalendarDateSelection as Ne, i18nPreviousYearRange as Xe, i18nNextYearRange as Ze } from "../../core/i18n.js";
17
+ import { boxSizingStyles as et } from "../../core/styles.js";
18
+ import { SbbCalendarDayElement as tt } from "../calendar-day/calendar-day.component.js";
19
+ import "../../button/secondary-button.js";
20
+ import "../../icon.js";
21
+ import "../../screen-reader-only.js";
22
+ const at = 6048e5, Ie = /* @__PURE__ */ Symbol.for("constructDateFrom");
23
+ function F(o, n) {
24
+ return typeof o == "function" ? o(n) : o && typeof o == "object" && Ie in o ? o[Ie](n) : o instanceof Date ? new o.constructor(n) : new Date(n);
25
+ }
26
+ function U(o, n) {
27
+ return F(n || o, o);
28
+ }
29
+ function st(o, n, d) {
30
+ const h = U(o, d?.in);
31
+ return isNaN(n) ? F(o, NaN) : (n && h.setDate(h.getDate() + n), h);
32
+ }
33
+ let rt = {};
34
+ function Z() {
35
+ return rt;
36
+ }
37
+ function z(o, n) {
38
+ const d = Z(), h = n?.weekStartsOn ?? n?.locale?.options?.weekStartsOn ?? d.weekStartsOn ?? d.locale?.options?.weekStartsOn ?? 0, m = U(o, n?.in), v = m.getDay(), V = (v < h ? 7 : 0) + v - h;
39
+ return m.setDate(m.getDate() - V), m.setHours(0, 0, 0, 0), m;
40
+ }
41
+ function it(o, ...n) {
42
+ const d = F.bind(
43
+ null,
44
+ o || n.find((h) => typeof h == "object")
45
+ );
46
+ return n.map(d);
47
+ }
48
+ function nt(o, n, d) {
49
+ return st(o, n * 7, d);
50
+ }
51
+ function lt(o, n) {
52
+ const d = U(o, n?.in), h = d.getMonth();
53
+ return d.setFullYear(d.getFullYear(), h + 1, 0), d.setHours(23, 59, 59, 999), d;
54
+ }
55
+ function ot(o, n) {
56
+ const [d, h] = it(o, n.start, n.end);
57
+ return { start: d, end: h };
58
+ }
59
+ function dt(o, n) {
60
+ const { start: d, end: h } = ot(n?.in, o);
61
+ let m = +d > +h;
62
+ const v = z(m ? h : d, n), V = z(m ? d : h, n);
63
+ v.setHours(15), V.setHours(15);
64
+ const O = +V.getTime();
65
+ let D = v, M = n?.step ?? 1;
66
+ if (!M) return [];
67
+ M < 0 && (M = -M, m = !m);
68
+ const W = [];
69
+ for (; +D <= O; )
70
+ D.setHours(0), W.push(F(d, D)), D = nt(D, M), D.setHours(15);
71
+ return m ? W.reverse() : W;
72
+ }
73
+ function ct(o, n) {
74
+ const d = U(o, n?.in);
75
+ return d.setDate(1), d.setHours(0, 0, 0, 0), d;
76
+ }
77
+ function ht(o, n) {
78
+ const d = U(o, n?.in), h = d.getFullYear(), m = Z(), v = n?.firstWeekContainsDate ?? n?.locale?.options?.firstWeekContainsDate ?? m.firstWeekContainsDate ?? m.locale?.options?.firstWeekContainsDate ?? 1, V = F(n?.in || o, 0);
79
+ V.setFullYear(h + 1, 0, v), V.setHours(0, 0, 0, 0);
80
+ const O = z(V, n), D = F(n?.in || o, 0);
81
+ D.setFullYear(h, 0, v), D.setHours(0, 0, 0, 0);
82
+ const M = z(D, n);
83
+ return +d >= +O ? h + 1 : +d >= +M ? h : h - 1;
84
+ }
85
+ function bt(o, n) {
86
+ const d = Z(), h = n?.firstWeekContainsDate ?? n?.locale?.options?.firstWeekContainsDate ?? d.firstWeekContainsDate ?? d.locale?.options?.firstWeekContainsDate ?? 1, m = ht(o, n), v = F(n?.in || o, 0);
87
+ return v.setFullYear(m, 0, h), v.setHours(0, 0, 0, 0), z(v, n);
88
+ }
89
+ function Ce(o, n) {
90
+ const d = U(o, n?.in), h = +z(d, n) - +bt(d, n);
91
+ return Math.round(h / at) + 1;
92
+ }
93
+ const _t = Se`:host{display:block;width:max-content;--sbb-calendar-cell-size: 2.5rem;--sbb-calendar-hover-shift: .0625rem;--sbb-calendar-wide-cell-size: 4.375rem;--sbb-calendar-header-color: var(--sbb-color-granite);--sbb-calendar-header-color: light-dark(var(--sbb-color-granite), var(--sbb-color-smoke));--sbb-calendar-cell-background-color: transparent;--sbb-calendar-cell-background-color-hover: var(--sbb-background-color-3);--sbb-calendar-cell-background-color-active: var(--sbb-background-color-4);--sbb-calendar-cell-padding: .125rem;--sbb-calendar-cell-color: var(--sbb-color-2);--sbb-calendar-cell-border-radius: var(--sbb-border-radius-4x);--sbb-calendar-cell-selected-border: var(--sbb-border-width-2x) solid var(--sbb-border-color-2);--sbb-calendar-cell-selected-background-color: var(--sbb-background-color-2-inverted);--sbb-calendar-cell-disabled-height: .09375rem;--sbb-calendar-cell-disabled-width: 1.59375rem;--sbb-calendar-cell-disabled-color: var(--sbb-color-granite);--sbb-calendar-cell-disabled-color: light-dark(var(--sbb-color-granite), var(--sbb-color-smoke));--sbb-calendar-cell-transition-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-2x) );--sbb-calendar-cell-transition-easing-function: var(--sbb-animation-easing);--sbb-calendar-tables-gap: var(--sbb-spacing-fixed-10x);--sbb-calendar-table-animation-shift: .00625rem;--sbb-calendar-table-animation-duration: .1ms;--sbb-calendar-table-column-spaces: 12;--sbb-calendar-control-view-change-height: 2.75rem;--sbb-calendar-control-view-change-color: var(--sbb-color-3);--sbb-calendar-control-view-change-background: var(--sbb-background-color-1);--sbb-calendar-cell-year-month-width: 4.8125rem;--sbb-calendar-cell-year-month-height: 2.75rem}@media(min-width:37.5rem){:host{--sbb-calendar-cell-size: 2.75rem;--sbb-calendar-wide-cell-size: 4.8125rem;--sbb-calendar-control-view-change-height: 3rem}}:host(:is(:state(enhanced),[state--enhanced])){--sbb-calendar-cell-padding-block-end: var(--sbb-spacing-fixed-3x)}.sbb-calendar__wrapper{width:100%;display:block;transition-duration:var(--sbb-calendar-cell-transition-duration)}.sbb-calendar__controls{width:100%;display:inline-flex;align-items:center;gap:var(--sbb-spacing-fixed-2x);margin-block-end:var(--sbb-spacing-fixed-4x)}.sbb-calendar__controls-month{width:100%;display:flex;gap:var(--sbb-calendar-tables-gap)}#sbb-calendar__controls-previous,#sbb-calendar__controls-next{-webkit-tap-highlight-color:transparent}.sbb-calendar__controls-change-date{appearance:none;box-sizing:border-box;outline:none;border:none;border-radius:0;padding:0;background:none;-webkit-tap-highlight-color:transparent;color:inherit;--sbb-text-font-size: var(--sbb-text-font-size-s);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-text);letter-spacing:var(--sbb-typo-letter-spacing-text);font-size:var(--sbb-text-font-size);display:flex;align-items:center;margin:auto;height:var(--sbb-calendar-control-view-change-height);text-transform:capitalize;cursor:var(--sbb-cursor-pointer);padding-inline:var(--sbb-spacing-fixed-5x) var(--sbb-spacing-fixed-2x);border-radius:var(--sbb-border-radius-infinity);background-color:var(--sbb-calendar-control-view-change-background);color:var(--sbb-calendar-control-view-change-color);transition-duration:var(--sbb-calendar-cell-transition-duration);transition-timing-function:var(--sbb-calendar-cell-transition-easing-function);transition-property:background-color,padding-block-end}.sbb-calendar__controls-change-date:disabled{--sbb-calendar-control-view-change-background: var(--sbb-color-milk);--sbb-calendar-control-view-change-background: light-dark( var(--sbb-color-milk), var(--sbb-color-anthracite) );--sbb-calendar-control-view-change-color: var(--sbb-color-granite);--sbb-calendar-control-view-change-color: light-dark( var(--sbb-color-granite), var(--sbb-color-aluminium) );cursor:unset}.sbb-calendar__controls-change-date:focus-visible{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);outline-offset:var(--sbb-spacing-fixed-1x)}@media(any-hover:hover){.sbb-calendar__controls-change-date:not(:active,:disabled):hover{padding-block-end:var(--sbb-calendar-hover-shift)}}.sbb-calendar__controls-change-date:not(:disabled):active{--sbb-calendar-control-view-change-background: var(--sbb-background-color-3)}.sbb-calendar__table-month-view,.sbb-calendar__table-year-view{--sbb-calendar-table-column-spaces: 6}.sbb-calendar__table-overflow-break{contain:layout}.sbb-calendar__table-container{display:flex;gap:var(--sbb-calendar-tables-gap);margin-inline:var(--sbb-calendar-margin);--sbb-calendar-min-width: calc(7 * var(--sbb-calendar-cell-size));--sbb-calendar-overflow: calc(100% - var(--sbb-calendar-min-width));--sbb-calendar-start-offset: min( 0px, -1 * (var(--sbb-calendar-overflow) / var(--sbb-calendar-table-column-spaces)) );--sbb-calendar-margin: var(--sbb-calendar-start-offset)}:host(:is(:state(wide),[state--wide])) .sbb-calendar__table-container{--sbb-calendar-min-width: calc( 2 * 7 * var(--sbb-calendar-cell-size) + var(--sbb-calendar-tables-gap) );--sbb-calendar-margin: calc(.5 * var(--sbb-calendar-start-offset))}:host([orientation=horizontal][week-numbers]) .sbb-calendar__table-container{--sbb-calendar-min-width: calc(8 * var(--sbb-calendar-cell-size))}:host([orientation=horizontal][week-numbers]:is(:state(wide),[state--wide])) .sbb-calendar__table-container{--sbb-calendar-min-width: calc( 2 * 8 * var(--sbb-calendar-cell-size) + var(--sbb-calendar-tables-gap) )}:host([orientation=vertical]) .sbb-calendar__table-container{min-width:var(--sbb-calendar-min-width);--sbb-calendar-start-offset: 0}:host([orientation=vertical]:is(:state(wide),[state--wide])) .sbb-calendar__table-container{--sbb-calendar-min-width: calc( 13 * var(--sbb-calendar-cell-size) + var(--sbb-calendar-tables-gap) )}.sbb-calendar__table{width:100%;border-collapse:collapse;height:max-content;animation-name:show;animation-duration:var(--sbb-calendar-table-animation-duration)}.sbb-calendar__table.sbb-calendar__table-hide{--sbb-calendar-cell-transition-duration: 0ms;animation-name:hide;animation-duration:var(--sbb-calendar-table-animation-duration)}:host(:not(:is(:state(wide),[state--wide]))) .sbb-calendar__table{min-width:100%}.sbb-calendar__table-header,.sbb-calendar__table-body{text-align:center}.sbb-calendar__table-header-cell,.sbb-calendar__table-header-cell-vertical{--sbb-text-font-size: var(--sbb-text-font-size-xs);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-text);letter-spacing:var(--sbb-typo-letter-spacing-text);font-size:var(--sbb-text-font-size);width:var(--sbb-calendar-cell-size);color:var(--sbb-calendar-header-color);padding:0}:host(:not([multiple])) .sbb-calendar__table-header-cell,:host(:not([multiple])) .sbb-calendar__table-header-cell-vertical{height:var(--sbb-calendar-cell-size)}.sbb-calendar__table-header-cell-vertical{padding-block-end:var(--sbb-calendar-cell-padding-block-end)}.sbb-calendar__table-data{position:relative;padding:0;text-align:center}.sbb-calendar__header-cell,.sbb-calendar__cell{appearance:none;box-sizing:border-box;margin:0;outline:none;border:none;border-radius:0;padding:0;background:none;-webkit-tap-highlight-color:transparent;color:inherit;--sbb-text-font-size: var(--sbb-text-font-size-s);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-text);letter-spacing:var(--sbb-typo-letter-spacing-text);font-size:var(--sbb-text-font-size);height:var(--sbb-calendar-cell-size);color:var(--sbb-calendar-cell-color);cursor:var(--sbb-cursor-pointer);position:relative;z-index:0}.sbb-calendar__header-cell:before,.sbb-calendar__cell:before{content:"";position:absolute;inset:var(--sbb-calendar-cell-padding);background-color:var(--sbb-calendar-cell-background-color);border-radius:var(--sbb-calendar-cell-border-radius);z-index:-1;transition-duration:var(--sbb-calendar-cell-transition-duration);transition-timing-function:var(--sbb-calendar-cell-transition-easing-function);transition-property:background-color}@media(any-hover:hover){.sbb-calendar__header-cell:not(:active,:disabled):hover,.sbb-calendar__cell:not(:active,:disabled):hover{--sbb-calendar-cell-background-color: var(--sbb-calendar-cell-background-color-hover);padding-block-end:var(--sbb-calendar-hover-shift)}}@media(any-hover:hover)and (forced-colors:active){.sbb-calendar__header-cell:not(:active,:disabled):hover:before,.sbb-calendar__cell:not(:active,:disabled):hover:before{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);--sbb-focus-outline-style: initial}}.sbb-calendar__header-cell:disabled,.sbb-calendar__cell:disabled{--sbb-calendar-cell-color: var(--sbb-calendar-cell-disabled-color);cursor:unset}.sbb-calendar__header-cell:focus-visible:before,.sbb-calendar__cell:focus-visible:before{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width)}.sbb-calendar__header-cell:not(:disabled):active,.sbb-calendar__cell:not(:disabled):active{--sbb-calendar-cell-background-color: var(--sbb-calendar-cell-background-color-active)}@media(forced-colors:active){.sbb-calendar__header-cell:not(:disabled):active:before,.sbb-calendar__cell:not(:disabled):active:before{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);--sbb-focus-outline-style: initial}}.sbb-calendar__header-cell{--sbb-text-font-size: var(--sbb-text-font-size-xs);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-text);letter-spacing:var(--sbb-typo-letter-spacing-text);font-size:var(--sbb-text-font-size);color:var(--sbb-calendar-header-color)}.sbb-calendar__cell{height:var(--sbb-calendar-cell-year-month-height);width:var(--sbb-calendar-cell-year-month-width)}.sbb-calendar__weekday{width:var(--sbb-calendar-cell-size)}.sbb-calendar__day-cell{padding-block-end:var(--sbb-calendar-cell-padding-block-end)}.sbb-calendar__crossed-out:after{content:"";height:var(--sbb-calendar-cell-disabled-height);width:var(--sbb-calendar-cell-disabled-width);position:absolute;background-color:var(--sbb-calendar-cell-disabled-color);top:50%;left:50%;transform:translate(-50%,-50%) rotate(-45deg)}.sbb-calendar__cell-current{--sbb-text-font-size: var(--sbb-text-font-size-s);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-text);letter-spacing:var(--sbb-typo-letter-spacing-text);font-size:var(--sbb-text-font-size);font-weight:700}.sbb-calendar__selected:before{border:var(--sbb-calendar-cell-selected-border);border-radius:var(--sbb-calendar-cell-border-radius)}sbb-calendar-day{--sbb-calendar-day-flex-direction: row;--sbb-calendar-day-justify-content: center;--sbb-calendar-day-align-items: center;--sbb-calendar-day-extra-display: none;--sbb-calendar-day-crossed-out-top: 50%;--sbb-calendar-day-crossed-out-translate: translate(-50%, -50%) rotate(-45deg);--sbb-calendar-day-height: 2.75rem;--sbb-calendar-day-value-height: unset}@keyframes show{0%{opacity:0;transform:translateY(var(--sbb-calendar-table-animation-shift))}to{opacity:1;transform:translateY(0)}}@keyframes hide{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(var(--sbb-calendar-table-animation-shift))}}`;
94
+ tt.define();
95
+ class ut extends Event {
96
+ get range() {
97
+ return this._range;
98
+ }
99
+ constructor(n) {
100
+ super("monthchange", { bubbles: !0, composed: !0 }), this._range = Object.freeze(n || []);
101
+ }
102
+ }
103
+ let Wt = (() => {
104
+ var N, I, C, R, S, T, P, E, L, B, H, q, g;
105
+ let o = Pe, n = [], d, h = [], m = [], v, V = [], O = [], D, M = [], W = [], ee, te = [], ae = [], se, re = [], ie = [], ne, le, oe = [], de = [], ce, he = [], be = [], _e, ue = [], fe = [], ge, me = [], pe = [], ve, we = [], ye = [], De, ke, Ae = [], xe = [], Ve, $e = [], Me = [];
106
+ return g = class extends o {
107
+ constructor() {
108
+ super();
109
+ x(this, N);
110
+ x(this, I);
111
+ x(this, C);
112
+ x(this, R);
113
+ x(this, S);
114
+ x(this, T);
115
+ x(this, P);
116
+ x(this, E);
117
+ x(this, L);
118
+ x(this, B);
119
+ x(this, H);
120
+ x(this, q);
121
+ _(this, N, (u(this, n), u(this, h, !1))), _(this, I, (u(this, m), u(this, V, "day"))), _(this, C, (u(this, O), u(this, M, null))), _(this, R, (u(this, W), u(this, te, null))), _(this, S, (u(this, ae), u(this, re, !1))), _(this, T, (u(this, ie), u(this, oe, null))), _(this, P, (u(this, de), u(this, he, null))), _(this, E, (u(this, be), u(this, ue, "horizontal"))), _(this, L, (u(this, fe), u(this, me, !1))), this._dateAdapter = (u(this, pe), Ee().datetime?.dateAdapter ?? He), _(this, B, u(this, we, this._dateAdapter.today())), this._wideInternal = (u(this, ye), !1), _(this, H, u(this, Ae, "day")), this._nextCalendarView = (u(this, xe), "day"), this._keyboardNavigationDayViewParameters = {
122
+ firstDayInView: null,
123
+ lastDayInView: null,
124
+ firstMonthOffset: 0,
125
+ firstMonthLength: 0,
126
+ secondMonthOffset: 0
127
+ }, this._weeks = [], this._monthNames = this._dateAdapter.getMonthNames("long"), this._enhancedVariant = !1, this._resetFocus = !1, this._containingFocus = !1, _(this, q, u(this, $e, !1)), this._language = (u(this, Me), new Le(this).withHandler(() => {
128
+ this._monthNames = this._dateAdapter.getMonthNames("long"), this._createMonthRows();
129
+ })), this._mediaMatcher = new Be(this, {
130
+ [Oe]: () => this._init()
131
+ }), this._onSlotChange = () => {
132
+ this._enhancedVariant = Array.from(this.children).some((e) => e.localName === "sbb-calendar-day"), this.toggleState("enhanced", this._enhancedVariant), this._setTabIndex();
133
+ }, this._createMonthRows(), this._setWeekdays(), this.addEventListener("focusin", () => this._containingFocus = !0), this.addEventListener("focusout", () => this._containingFocus = !1), this.addEventListener("click", (e) => {
134
+ const t = e.target.closest("sbb-calendar-day");
135
+ t && this._selectDate(t.value);
136
+ }), this.addEventListener("keydown", (e) => {
137
+ e.target.localName === "sbb-calendar-day" && this._handleKeyboardEvent(e, this._mapDateToDay(e.target.value));
138
+ });
139
+ }
140
+ /** If set to true, two months are displayed */
141
+ get wide() {
142
+ return A(this, N);
143
+ }
144
+ set wide(e) {
145
+ _(this, N, e);
146
+ }
147
+ /** The initial view of the calendar which should be displayed on opening. */
148
+ get view() {
149
+ return A(this, I);
150
+ }
151
+ set view(e) {
152
+ _(this, I, e);
153
+ }
154
+ /**
155
+ * The minimum valid date. Accepts a date object or null.
156
+ * Accepts an ISO8601 formatted string (e.g. 2024-12-24) as attribute.
157
+ */
158
+ get min() {
159
+ return A(this, C);
160
+ }
161
+ set min(e) {
162
+ _(this, C, e);
163
+ }
164
+ /**
165
+ * The maximum valid date. Accepts a date object or null.
166
+ * Accepts an ISO8601 formatted string (e.g. 2024-12-24) as attribute.
167
+ */
168
+ get max() {
169
+ return A(this, R);
170
+ }
171
+ set max(e) {
172
+ _(this, R, e);
173
+ }
174
+ /** Whether the calendar allows for multiple date selection. */
175
+ get multiple() {
176
+ return A(this, S);
177
+ }
178
+ set multiple(e) {
179
+ _(this, S, e);
180
+ }
181
+ /**
182
+ * The selected date: accepts a date object, or, if `multiple`, an array of dates.
183
+ */
184
+ set selected(e) {
185
+ if (Array.isArray(e))
186
+ this._selected = e.map((t) => this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(t))).filter((t) => t !== null).filter((t) => !this._isDayInRange(this._dateAdapter.toIso8601(t)) || this._dateFilter(t));
187
+ else {
188
+ const t = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(e));
189
+ t && (!this._isDayInRange(this._dateAdapter.toIso8601(t)) || this._dateFilter(t)) ? this._selected = t : this._selected = null;
190
+ }
191
+ }
192
+ get selected() {
193
+ return this._selected;
194
+ }
195
+ get _selected() {
196
+ return A(this, T);
197
+ }
198
+ set _selected(e) {
199
+ _(this, T, e);
200
+ }
201
+ /** A function used to filter out dates. */
202
+ get dateFilter() {
203
+ return A(this, P);
204
+ }
205
+ set dateFilter(e) {
206
+ _(this, P, e);
207
+ }
208
+ /** The orientation of days in the calendar. */
209
+ get orientation() {
210
+ return A(this, E);
211
+ }
212
+ set orientation(e) {
213
+ _(this, E, e);
214
+ }
215
+ /** Whether it has to display the week numbers in addition to week days. */
216
+ get weekNumbers() {
217
+ return A(this, L);
218
+ }
219
+ set weekNumbers(e) {
220
+ _(this, L, e);
221
+ }
222
+ /** The currently active date. */
223
+ get _activeDate() {
224
+ return A(this, B);
225
+ }
226
+ set _activeDate(e) {
227
+ _(this, B, e);
228
+ }
229
+ /** The current wide property considering property value and breakpoints. From zero to small `wide` has always to be false. */
230
+ set _wide(e) {
231
+ this.toggleState("wide", e), this._wideInternal = e;
232
+ }
233
+ get _wide() {
234
+ return this._wideInternal;
235
+ }
236
+ get _calendarView() {
237
+ return A(this, H);
238
+ }
239
+ set _calendarView(e) {
240
+ _(this, H, e);
241
+ }
242
+ /** A list of buttons corresponding to days, months or years depending on the view. */
243
+ get _cells() {
244
+ return Array.from((this._calendarView === "day" ? this._getRootForQuerySelector()?.querySelectorAll("sbb-calendar-day") : this.shadowRoot?.querySelectorAll(".sbb-calendar__cell")) ?? []);
245
+ }
246
+ get _initialized() {
247
+ return A(this, q);
248
+ }
249
+ set _initialized(e) {
250
+ _(this, q, e);
251
+ }
252
+ _getRootForQuerySelector() {
253
+ return this._enhancedVariant ? this : this.shadowRoot;
254
+ }
255
+ _dateFilter(e) {
256
+ return this.dateFilter?.(e) ?? !0;
257
+ }
258
+ /** Resets the active month according to the new state of the calendar. */
259
+ resetPosition() {
260
+ this._resetCalendarView(), this._init();
261
+ }
262
+ connectedCallback() {
263
+ super.connectedCallback(), this.resetPosition(), this.shadowRoot?.addEventListener("slotchange", this._onSlotChange, { capture: !0 });
264
+ }
265
+ disconnectedCallback() {
266
+ super.disconnectedCallback(), this.shadowRoot?.removeEventListener("slotchange", this._onSlotChange, { capture: !0 });
267
+ }
268
+ /** @internal */
269
+ focus() {
270
+ this._resetFocus = !0, this._focusCell();
271
+ }
272
+ willUpdate(e) {
273
+ super.willUpdate(e), this._initialized && ((e.has("wide") || e.has("orientation")) && this.resetPosition(), e.has("view") && (this._setChosenYear(), this._chosenMonth = void 0, this._nextCalendarView = this._calendarView = this.view));
274
+ }
275
+ updated(e) {
276
+ super.updated(e), this._setTabIndex(), this._focusCell();
277
+ }
278
+ /**
279
+ * The `_selected` state should be adapted when the `multiple` property changes:
280
+ * - if it changes to true, the '_selected' is set to an array;
281
+ * - if it changes to false, the first available option is set as 'value' otherwise it's set to null.
282
+ */
283
+ _onMultipleChanged(e) {
284
+ e && !Array.isArray(this._selected) && (this._selected = this._selected ? [this._selected] : []), !e && Array.isArray(this._selected) && (this._selected = this._selected.length ? this._selected[0] : null);
285
+ }
286
+ /** Initializes the component. */
287
+ _init(e) {
288
+ if (!Fe) {
289
+ if (this.hydrationRequired) {
290
+ this.hydrationComplete.then(() => this._init());
291
+ return;
292
+ }
293
+ if (e && this._assignActiveDate(e), this._wide = (this._mediaMatcher.matches(Oe) ?? !1) && this.wide, this._weeks = this._createWeekRows(this._activeDate), this._years = this._createYearRows(), this._weekNumbers = this._createWeekNumbers(this._activeDate), this._nextMonthWeeks = [[]], this._nextMonthYears = [[]], this._wide) {
294
+ const t = this._dateAdapter.addCalendarMonths(this._activeDate, 1);
295
+ this._nextMonthWeeks = this._createWeekRows(t, !0), this._nextMonthYears = this._createYearRows($), this._nextMonthWeekNumbers = this._createWeekNumbers(t);
296
+ }
297
+ this._initialized = !0;
298
+ }
299
+ }
300
+ /** Focuses on a day cell prioritizing the selected day, the current day, and lastly, the first selectable day. */
301
+ _focusCell() {
302
+ this._resetFocus && (this._getFirstFocusable()?.focus(), this._resetFocus = !1);
303
+ }
304
+ /** Creates the array of weekdays. */
305
+ _setWeekdays() {
306
+ const e = this._dateAdapter.getDayOfWeekNames("narrow"), a = this._dateAdapter.getDayOfWeekNames("long").map((r, i) => ({
307
+ long: r,
308
+ narrow: e[i]
309
+ })), s = this._dateAdapter.getFirstDayOfWeek();
310
+ this._weekdays = a.slice(s).concat(a.slice(0, s));
311
+ }
312
+ /**
313
+ * Given a date, it returns the week numbers for the month the date belongs to.
314
+ * TODO: check if date-fns can be replaced with custom logic.
315
+ *
316
+ * Since the calculation is not simple (see https://en.wikipedia.org/wiki/Week#Numbering),
317
+ * the date-fns library has been used this way:
318
+ * the first and the last day of the month are calculated and then passed to the `eachWeekOfInterval` function,
319
+ * which returns an array containing the starting day of every ISO week of the month,
320
+ * considering Monday as the first day.
321
+ * Then, this array is mapped via the `getWeek` function, which returns the ISO week number for that date.
322
+ */
323
+ _createWeekNumbers(e) {
324
+ return dt({ start: ct(e), end: lt(e) }, { weekStartsOn: 1 }).map((t) => Ce(t, { weekStartsOn: 1, firstWeekContainsDate: 4 }));
325
+ }
326
+ /** Creates the rows along the horizontal direction and sets the parameters used in keyboard navigation. */
327
+ _createWeekRows(e, t = !1) {
328
+ const a = this._dateAdapter.getNumDaysInMonth(e), s = this._dateAdapter.getFirstWeekOffset(e);
329
+ return t ? (this._keyboardNavigationDayViewParameters.secondMonthOffset = s, this._keyboardNavigationDayViewParameters.lastDayInView = this._dateAdapter.toIso8601(this._dateAdapter.createDate(this._dateAdapter.getYear(e), this._dateAdapter.getMonth(e), a))) : (this._keyboardNavigationDayViewParameters.firstMonthLength = a, this._keyboardNavigationDayViewParameters.firstMonthOffset = s, this._keyboardNavigationDayViewParameters.firstDayInView = this._dateAdapter.toIso8601(this._dateAdapter.createDate(this._dateAdapter.getYear(e), this._dateAdapter.getMonth(e), 1)), this._keyboardNavigationDayViewParameters.lastDayInView = this._dateAdapter.toIso8601(this._dateAdapter.createDate(this._dateAdapter.getYear(e), this._dateAdapter.getMonth(e), a))), this.orientation === "horizontal" ? this._createWeekRowsHorizontal(e, a, s) : this._createWeekRowsVertical(e, a, s);
330
+ }
331
+ /**
332
+ * Creates the rows for each week in orientation='horizontal'.
333
+ *
334
+ * Iterates through the days of the months, creates a Day object for each and pushes it into and array.
335
+ * Each seven days (considering the offset at the beginning of the month) restarts from an empty array.
336
+ *
337
+ * The result is a matrix in which every row is a week (or part of it, considering offset).
338
+ */
339
+ _createWeekRowsHorizontal(e, t, a) {
340
+ const s = [[]];
341
+ for (let r = 0, i = a; r < t; r++, i++) {
342
+ i === y && (s.push([]), i = 0);
343
+ const l = this._dateAdapter.createDate(this._dateAdapter.getYear(e), this._dateAdapter.getMonth(e), r + 1);
344
+ s[s.length - 1].push(this._mapDateToDay(l));
345
+ }
346
+ return s;
347
+ }
348
+ /**
349
+ * Creates the rows for each week in orientation='vertical'.
350
+ *
351
+ * Creates a matrix with seven empty rows.
352
+ * Iterates through the days of the months, creates a Day object for each
353
+ * and pushes it into the correct array considering the offset at the beginning of the month.
354
+ * Each seven days (including offset) restarts from the first.
355
+ *
356
+ * The result is a matrix in which every row is a set of weekdays, so:
357
+ * - row 0: all the Mondays;
358
+ * - row 1: all the Tuesdays;
359
+ * - ...
360
+ * - row 7: all the Sundays.
361
+ */
362
+ _createWeekRowsVertical(e, t, a) {
363
+ const s = Array.from({ length: y }, () => []);
364
+ for (let r = 0, i = a; r < t; r++, i++) {
365
+ i === y && (i = 0);
366
+ const l = this._dateAdapter.createDate(this._dateAdapter.getYear(e), this._dateAdapter.getMonth(e), r + 1);
367
+ s[i].push(this._mapDateToDay(l));
368
+ }
369
+ return s;
370
+ }
371
+ _mapDateToDay(e) {
372
+ const t = this._dateAdapter.toIso8601(e);
373
+ return {
374
+ value: t,
375
+ dateValue: e,
376
+ dayValue: String(this._dateAdapter.getDate(e)),
377
+ monthValue: String(this._dateAdapter.getMonth(e)),
378
+ yearValue: String(this._dateAdapter.getYear(e)),
379
+ weekValue: Ce(t, { weekStartsOn: 1, firstWeekContainsDate: 4 }),
380
+ weekDayValue: this._dateAdapter.getDayOfWeek(e)
381
+ };
382
+ }
383
+ /** Force the conversion to ISO8601 formatted string. */
384
+ _mapValueToISODate(e) {
385
+ return typeof e == "string" ? e : this._dateAdapter.toIso8601(e);
386
+ }
387
+ /** Creates the rows for the month selection view. */
388
+ _createMonthRows() {
389
+ const e = this._dateAdapter.getMonthNames("short"), t = new Array(12).fill(null).map((r, i) => ({
390
+ value: e[i],
391
+ longValue: this._monthNames[i],
392
+ monthValue: i + 1
393
+ })), a = 12 / j, s = [];
394
+ for (let r = 0; r < a; r++)
395
+ s.push(t.slice(j * r, j * (r + 1)));
396
+ this._months = s;
397
+ }
398
+ /** Creates the rows for the year selection view. */
399
+ _createYearRows(e = 0) {
400
+ const t = this._getStartValueYearView(), a = new Array($).fill(0).map((i, l) => t + e + l), s = $ / G, r = [];
401
+ for (let i = 0; i < s; i++)
402
+ r.push(a.slice(G * i, G * (i + 1)));
403
+ return r;
404
+ }
405
+ /**
406
+ * Calculates the first year that will be shown in the year selection panel.
407
+ * If `minDate` and `maxDate` are both null, the starting year is calculated as
408
+ * the multiple of YEARS_PER_PAGE closest to and less than activeDate,
409
+ * e.g., with `YEARS_PER_PAGE` = 24 and `activeDate` = 2020, the function will return 2016 (24 * 83),
410
+ * while with `activeDate` = 2000, the function will return 1992 (24 * 82).
411
+ * If `minDate` is not null, it returns the corresponding year; if `maxDate` is not null,
412
+ * it returns the corresponding year minus `YEARS_PER_PAGE`, so that the `maxDate` is the last rendered year.
413
+ * If both are not null, `maxDate` has priority over `minDate`.
414
+ */
415
+ _getStartValueYearView() {
416
+ let e = 0;
417
+ this.max ? e = this._dateAdapter.getYear(this.max) - $ + 1 : this.min && (e = this._dateAdapter.getYear(this.min));
418
+ const t = this._dateAdapter.getYear(this._activeDate);
419
+ return t - ((t - e) % $ + $) % $;
420
+ }
421
+ /** Checks if date is within the min-max range. */
422
+ _isDayInRange(e) {
423
+ if (!this.min && !this.max)
424
+ return !0;
425
+ const t = this._dateAdapter.deserialize(e);
426
+ return this._dateAdapter.sameDate(t, this._dateAdapter.clampDate(t, this.min, this.max));
427
+ }
428
+ /** Checks if date is within the min-max range in month view. */
429
+ _isMonthInRange(e, t) {
430
+ if (!this.min && !this.max)
431
+ return !0;
432
+ const a = this._dateAdapter.isValid(this.min) && (t < this._dateAdapter.getYear(this.min) || t === this._dateAdapter.getYear(this.min) && e < this._dateAdapter.getMonth(this.min)), s = this._dateAdapter.isValid(this.max) && (t > this._dateAdapter.getYear(this.max) || t === this._dateAdapter.getYear(this.max) && e > this._dateAdapter.getMonth(this.max));
433
+ return !(a || s);
434
+ }
435
+ /** Checks if date is within the min-max range in year view. */
436
+ _isYearInRange(e) {
437
+ if (!this.min && !this.max)
438
+ return !0;
439
+ const t = this._dateAdapter.isValid(this.min) && this._dateAdapter.getYear(this.min) > e, a = this._dateAdapter.isValid(this.max) && this._dateAdapter.getYear(this.max) < e;
440
+ return !(t || a);
441
+ }
442
+ // Implementation adapted from https://github.com/angular/components/blob/main/src/material/datepicker/year-view.ts#L366
443
+ _isMonthFilteredOut(e, t) {
444
+ if (!this.dateFilter)
445
+ return !0;
446
+ const a = this._dateAdapter.createDate(t, e, 1);
447
+ for (let s = a; this._dateAdapter.getMonth(s) == e; s = this._dateAdapter.addCalendarDays(s, 1))
448
+ if (this.dateFilter(s))
449
+ return !0;
450
+ return !1;
451
+ }
452
+ // Implementation adapted from https://github.com/angular/components/blob/main/src/material/datepicker/multi-year-view.ts#L351
453
+ _isYearFilteredOut(e) {
454
+ if (!this.dateFilter)
455
+ return !0;
456
+ const t = this._dateAdapter.createDate(e, 1, 1);
457
+ for (let a = t; this._dateAdapter.getYear(a) == e; a = this._dateAdapter.addCalendarDays(a, 1))
458
+ if (this.dateFilter(a))
459
+ return !0;
460
+ return !1;
461
+ }
462
+ /** Emits the selected date and sets it internally. */
463
+ _selectDate(e) {
464
+ if (this._chosenMonth = void 0, this._setChosenYear(), this.multiple) {
465
+ if (this._selected && this._selected.length > 0) {
466
+ const t = this._selected.findIndex((a) => this._dateAdapter.compareDate(a, e) === 0);
467
+ t !== -1 ? this._selected = this._selected.filter((a, s) => s !== t) : this._selected = [...this._selected, e];
468
+ } else
469
+ this._selected = [e];
470
+ this._emitDateSelectedEvent(this._selected.map((t) => this._dateAdapter.deserialize(t)));
471
+ } else
472
+ (!this._selected || this._dateAdapter.compareDate(this._selected, e) !== 0) && (this._selected = e, this._emitDateSelectedEvent(this._dateAdapter.deserialize(e)));
473
+ }
474
+ /**
475
+ * Handle multiple dates selection via weekNumber / weekDay buttons:
476
+ * - if Cmd or Ctrl are pressed, add the new date to the current ones;
477
+ * - if not,
478
+ * - if the new dates are the same of the current ones, it means that the same button has been clicked twice, so do nothing;
479
+ * - if not, the selected dates are the new ones.
480
+ */
481
+ _selectMultipleDates(e) {
482
+ const t = this._cells.filter((l) => !l.disabled).map((l) => this._mapValueToISODate(l.value)), a = e.map((l) => l.value).filter((l) => t.includes(l)), s = new Set(a), r = new Set(this._selected.map((l) => this._dateAdapter.toIso8601(l))), i = this._updateSelectedWithMultipleDates(a, s, r);
483
+ this._selected = i.map((l) => this._dateAdapter.deserialize(l)), this._emitDateSelectedEvent(this._selected.map((l) => this._dateAdapter.deserialize(l)));
484
+ }
485
+ /**
486
+ * Emits the dateselected event given the detail (as T or T[] based on the value of the multiple flag).
487
+ */
488
+ _emitDateSelectedEvent(e) {
489
+ this.dispatchEvent(new CustomEvent("dateselected", {
490
+ detail: e,
491
+ composed: !0,
492
+ bubbles: !0
493
+ }));
494
+ }
495
+ _emitMonthChange() {
496
+ const e = (this.wide ? [...this._weeks, ...this._nextMonthWeeks] : this._weeks).flat().sort((t, a) => t.value.localeCompare(a.value));
497
+ this.dispatchEvent(new ut(e));
498
+ }
499
+ /**
500
+ * In case of multiple selection, newly added days must be added to the existing ones, without duplication.
501
+ * If the days to add are exactly the same as the selected ones, the set must be emptied.
502
+ */
503
+ _updateSelectedWithMultipleDates(e, t, a) {
504
+ return e.every((s) => a.has(s)) ? t.forEach((s) => a.delete(s)) : t.forEach((s) => a.add(s)), Array.from(a);
505
+ }
506
+ _setChosenYear() {
507
+ if (this.view === "month") {
508
+ let e;
509
+ this.multiple ? e = this.selected.at(-1) : e = this.selected, this._chosenYear = this._dateAdapter.getYear(e ?? this._dateAdapter.today());
510
+ } else
511
+ this._chosenYear = void 0;
512
+ }
513
+ _assignActiveDate(e) {
514
+ if (this.min && this._dateAdapter.compareDate(this.min, e) > 0) {
515
+ this._activeDate = this.min;
516
+ return;
517
+ }
518
+ if (this.max && this._dateAdapter.compareDate(this.max, e) < 0) {
519
+ this._activeDate = this.max;
520
+ return;
521
+ }
522
+ this._activeDate = e;
523
+ }
524
+ /** Goes to the month identified by the shift. */
525
+ _goToDifferentMonth(e) {
526
+ this._init(this._dateAdapter.addCalendarMonths(this._activeDate, e)), this._emitMonthChange();
527
+ }
528
+ _goToDifferentYear(e) {
529
+ this._chosenYear += e, this._activeDate = this._dateAdapter.createDate(this._chosenYear, this._dateAdapter.getMonth(this._activeDate), this._dateAdapter.getDate(this._activeDate)), this._init();
530
+ }
531
+ _goToDifferentYearRange(e) {
532
+ this._init(this._dateAdapter.addCalendarYears(this._activeDate, e));
533
+ }
534
+ _prevDisabled(e) {
535
+ return this.min ? this._dateAdapter.compareDate(e, this.min) < 0 : !1;
536
+ }
537
+ _nextDisabled(e) {
538
+ return this.max ? this._dateAdapter.compareDate(e, this.max) > 0 : !1;
539
+ }
540
+ /** Checks if the "previous month" button should be disabled. */
541
+ _previousMonthDisabled() {
542
+ const e = this._dateAdapter.addCalendarDays(this._activeDate, this._dateAdapter.getDate(this._activeDate) * -1);
543
+ return this._prevDisabled(e);
544
+ }
545
+ /** Checks if the "next month" button should be disabled. */
546
+ _nextMonthDisabled() {
547
+ let e = this._dateAdapter.addCalendarMonths(this._activeDate, this._wide ? 2 : 1);
548
+ return e = this._dateAdapter.createDate(this._dateAdapter.getYear(e), this._dateAdapter.getMonth(e), 1), this._nextDisabled(e);
549
+ }
550
+ /** Checks if the "previous year" button should be disabled. */
551
+ _previousYearDisabled() {
552
+ const e = this._dateAdapter.createDate(this._dateAdapter.getYear(this._activeDate) - 1, 12, 31);
553
+ return this._prevDisabled(e);
554
+ }
555
+ /** Checks if the "next year" button should be disabled. */
556
+ _nextYearDisabled() {
557
+ const e = this._dateAdapter.createDate(this._dateAdapter.getYear(this._activeDate) + (this._wide ? 2 : 1), 1, 1);
558
+ return this._nextDisabled(e);
559
+ }
560
+ /** Checks if the "previous year" button should be disabled in year view. */
561
+ _previousYearRangeDisabled() {
562
+ const e = this._dateAdapter.createDate(this._years[0][0] - 1, 12, 31);
563
+ return this._prevDisabled(e);
564
+ }
565
+ /** Checks if the "next year" button should be disabled in year view. */
566
+ _nextYearRangeDisabled() {
567
+ const e = this._wide ? this._nextMonthYears : this._years, t = e[e.length - 1], a = t[t.length - 1], s = this._dateAdapter.createDate(a + 1, 1, 1);
568
+ return this._nextDisabled(s);
569
+ }
570
+ _handleTableBlur(e) {
571
+ e?.localName !== "sbb-calendar-day" && this._setTabIndex();
572
+ }
573
+ _setTabIndex() {
574
+ const e = this._calendarView === "day" ? "sbb-calendar-day" : ".sbb-calendar__cell";
575
+ Array.from(this._getRootForQuerySelector().querySelectorAll(`${e}[tabindex="0"]`) ?? []).forEach((a) => a.tabIndex = -1);
576
+ const t = this._getFirstFocusable();
577
+ t && (t.tabIndex = 0);
578
+ }
579
+ /** Get the element in the calendar to assign focus. */
580
+ _getFirstFocusable() {
581
+ const e = this._getRootForQuerySelector();
582
+ if (this._calendarView === "day") {
583
+ const t = e.querySelector(":is(:state(selected),[state--selected])") ?? e.querySelector(":is(:state(current),[state--current])");
584
+ return t && !t.disabled ? t : this._getFirstFocusableDay();
585
+ } else {
586
+ const t = this.shadowRoot?.querySelector(".sbb-calendar__cell-current");
587
+ return t && !t.disabled ? t : this.shadowRoot.querySelector(".sbb-calendar__cell:not([disabled])");
588
+ }
589
+ }
590
+ /**
591
+ * In `day` view in `vertical` orientation,
592
+ * if the first of the month is not a Monday, it is not the first rendered element in the table,
593
+ * so `this.shadowRoot!.querySelector('.sbb-calendar__cell:not([disabled])')` will return a wrong value.
594
+ *
595
+ * To solve this, the element with the lowest `value` is taken (ISO String are ordered).
596
+ */
597
+ _getFirstFocusableDay() {
598
+ const e = Array.from(this._getRootForQuerySelector().querySelectorAll("sbb-calendar-day:not([disabled])"));
599
+ if (!e || e.length === 0)
600
+ return null;
601
+ {
602
+ const t = e.map((a) => this._dateAdapter.toIso8601(a.value)).sort()[0];
603
+ return this._getRootForQuerySelector().querySelector(`sbb-calendar-day[slot="${t}"]`);
604
+ }
605
+ }
606
+ _handleKeyboardEvent(e, t) {
607
+ Te(e) && e.preventDefault();
608
+ const a = this._cells, s = a.findIndex((l) => l === e.target);
609
+ let r;
610
+ t ? r = this._navigateByKeyboardDayView(e, s, a, t) : r = this._navigateByKeyboard(e, s, a);
611
+ const i = (this._enhancedVariant ? document : this.shadowRoot).activeElement;
612
+ r !== i && (r.tabIndex = 0, r?.focus(), i.tabIndex = -1);
613
+ }
614
+ _navigateByKeyboardDayView(e, t, a, s) {
615
+ const r = this.orientation === "horizontal" ? { leftRight: 1, upDown: y } : { leftRight: y, upDown: 1 }, i = t < this._keyboardNavigationDayViewParameters.firstMonthLength ? this._keyboardNavigationDayViewParameters.firstMonthOffset : this._keyboardNavigationDayViewParameters.secondMonthOffset;
616
+ switch (e.key) {
617
+ case "ArrowUp":
618
+ return this._findDayArrows(a, t, s.dateValue, -r.upDown);
619
+ case "ArrowDown":
620
+ return this._findDayArrows(a, t, s.dateValue, r.upDown);
621
+ case "ArrowLeft":
622
+ return this._findDayArrows(a, t, s.dateValue, -r.leftRight);
623
+ case "ArrowRight":
624
+ return this._findDayArrows(a, t, s.dateValue, r.leftRight);
625
+ case "PageUp":
626
+ if (this.orientation === "horizontal") {
627
+ const b = (+s.dayValue % y || y) - +s.dayValue;
628
+ return this._findDayPageUpDown(a, t, s, b, r.upDown);
629
+ } else {
630
+ const f = (Math.ceil((+s.dayValue + i) / y) - 1) * y - i + 1 - +s.dayValue;
631
+ return this._findDayPageUpDown(a, t, s, f, r.upDown);
632
+ }
633
+ case "PageDown":
634
+ if (this.orientation === "horizontal") {
635
+ const l = +s.monthValue + 1 > 12 ? 1 : +s.monthValue + 1, b = +s.monthValue + 1 > 12 ? +s.yearValue + 1 : +s.yearValue, f = this._dateAdapter.createDate(b, l, 1), k = this._dateAdapter.getDate(this._dateAdapter.addCalendarDays(f, -1)), Re = Math.trunc((k - +s.dayValue) / y) * y;
636
+ return this._findDayPageUpDown(a, t, s, Re, -r.upDown);
637
+ } else {
638
+ const f = Math.ceil((+s.dayValue + i) / y) * y - i - +s.dayValue;
639
+ return this._findDayPageUpDown(a, t, s, f, -r.upDown);
640
+ }
641
+ case "Home":
642
+ return this._findDayFirst(a, t, s, 1);
643
+ case "End": {
644
+ const l = +s.monthValue + 1 > 12 ? 1 : +s.monthValue + 1, b = +s.monthValue + 1 > 12 ? +s.yearValue + 1 : +s.yearValue, f = this._dateAdapter.createDate(b, l, 1);
645
+ return this._findDayLast(a, t, f);
646
+ }
647
+ default:
648
+ return a[t];
649
+ }
650
+ }
651
+ _isDayOutOfView(e) {
652
+ return e < this._keyboardNavigationDayViewParameters.firstDayInView || e > this._keyboardNavigationDayViewParameters.lastDayInView;
653
+ }
654
+ _findDayArrows(e, t, a, s) {
655
+ const r = this._dateAdapter.toIso8601(this._dateAdapter.addCalendarDays(a, s));
656
+ if (this._isDayOutOfView(r))
657
+ return e[t];
658
+ const i = e.find((l) => this._mapValueToISODate(l.value) === r);
659
+ return !i || i.disabled ? this._findDayArrows(e, t, this._dateAdapter.deserialize(r), s) : i;
660
+ }
661
+ _findDayPageUpDown(e, t, a, s, r) {
662
+ const i = this._dateAdapter.toIso8601(this._dateAdapter.addCalendarDays(a.dateValue, s));
663
+ if (this._isDayOutOfView(i))
664
+ return e[t];
665
+ const l = e.find((b) => this._mapValueToISODate(b.value) === i);
666
+ return !l || l.disabled ? this._findDayPageUpDown(e, t, a, s + r, r) : l;
667
+ }
668
+ _findDayFirst(e, t, a, s) {
669
+ const r = this._dateAdapter.toIso8601(this._dateAdapter.createDate(+a.yearValue, +a.monthValue, s));
670
+ if (this._isDayOutOfView(r))
671
+ return e[t];
672
+ const i = e.find((l) => this._mapValueToISODate(l.value) === r);
673
+ return !i || i.disabled ? this._findDayFirst(e, t, a, s + 1) : i;
674
+ }
675
+ _findDayLast(e, t, a) {
676
+ const s = this._dateAdapter.toIso8601(this._dateAdapter.addCalendarDays(a, -1));
677
+ if (this._isDayOutOfView(s))
678
+ return e[t];
679
+ const r = e.find((i) => this._mapValueToISODate(i.value) === s);
680
+ return !r || r.disabled ? this._findDayLast(e, t, this._dateAdapter.deserialize(s)) : r;
681
+ }
682
+ /**
683
+ * Gets the index of the element to move to, based on a list of elements (which can be potentially disabled),
684
+ * the keyboard input and the position of the current element in the list.
685
+ * In the day view, the `day?: Day` parameter is mandatory for calculation,
686
+ * while in month and year view it's not due to the fixed amount of rendered cells.
687
+ */
688
+ _navigateByKeyboard(e, t, a) {
689
+ const { elementIndexForWideMode: s, offsetForWideMode: r, lastElementIndexForWideMode: i, verticalOffset: l } = this._calculateParametersForKeyboardNavigation(t, this._calendarView === "year");
690
+ switch (e.key) {
691
+ case "ArrowUp":
692
+ return this._findNext(a, t, -l);
693
+ case "ArrowDown":
694
+ return this._findNext(a, t, l);
695
+ case "ArrowLeft":
696
+ return this._findNext(a, t, -1);
697
+ case "ArrowRight":
698
+ return this._findNext(a, t, 1);
699
+ case "Home":
700
+ return this._findFirst(a, r);
701
+ case "PageUp":
702
+ return this._findFirstOnColumn(a, s, r, l);
703
+ case "PageDown":
704
+ return this._findLastOnColumn(a, t, i, l);
705
+ case "End":
706
+ return this._findLast(a, i - 1);
707
+ default:
708
+ return a[t];
709
+ }
710
+ }
711
+ /**
712
+ * Calculates the parameters needed in keyboard navigation in year and month view.
713
+ * @param index The starting element's index in the cell array.
714
+ * @param isYearView Whether the displayed `view` is the year one.
715
+ */
716
+ _calculateParametersForKeyboardNavigation(e, t) {
717
+ const a = t ? $ : qe, s = Math.trunc(e / a) * a, r = s === 0 ? e : e - a;
718
+ return {
719
+ verticalOffset: t ? G : j,
720
+ elementIndexForWideMode: r,
721
+ offsetForWideMode: e - r,
722
+ lastElementIndexForWideMode: s === 0 ? a : a * 2
723
+ };
724
+ }
725
+ /**
726
+ * Gets the next element of the provided array starting from `index` by adding `delta`.
727
+ * If the found element is disabled, it continues adding `delta` until it finds an enabled one in the array bounds.
728
+ */
729
+ _findNext(e, t, a) {
730
+ let s = t + a;
731
+ for (; s < e.length && e[s]?.disabled; )
732
+ s += a;
733
+ return e[s] ?? e[t];
734
+ }
735
+ /** Find the first enabled element in the provided array. */
736
+ _findFirst(e, t) {
737
+ return e[t].disabled ? this._findNext(e, t, 1) : e[t];
738
+ }
739
+ /** Find the last enabled element in the provided array. */
740
+ _findLast(e, t) {
741
+ return e[t].disabled ? this._findNext(e, t, -1) : e[t];
742
+ }
743
+ /** Find the first enabled element in the same column of the provided array. */
744
+ _findFirstOnColumn(e, t, a, s) {
745
+ const r = t % s + a;
746
+ return e[r].disabled ? this._findNext(e, r, s) : e[r];
747
+ }
748
+ /** Find the last enabled element in the same column of the provided array. */
749
+ _findLastOnColumn(e, t, a, s) {
750
+ const r = t + Math.trunc((a - t - 1) / s) * s;
751
+ return e[r].disabled ? this._findNext(e, r, -s) : e[r];
752
+ }
753
+ _resetCalendarViewAndEmitMonthChange(e = !1) {
754
+ this._resetCalendarView(e), this._emitMonthChange();
755
+ }
756
+ _resetCalendarView(e = !1) {
757
+ this._containingFocus && (this._resetFocus = !0), this._activeDate = (this.multiple ? this._selected.at(-1) : this._selected) ?? this._dateAdapter.today(), this._setChosenYear(), this._chosenMonth = void 0, this._init(), this._nextCalendarView = this._calendarView = this.view, e && this._startTableTransition();
758
+ }
759
+ /** Render the view for the day selection. */
760
+ _renderDayView() {
761
+ const e = this._wide ? this._dateAdapter.addCalendarMonths(this._activeDate, 1) : void 0;
762
+ return c`
763
+ <div class="sbb-calendar__controls">
764
+ ${this._getArrow("left", () => this._goToDifferentMonth(-1), Ue[this._language.current], this._previousMonthDisabled())}
765
+ <div class="sbb-calendar__controls-month">
766
+ ${this._createLabelForDayView(this._activeDate)}
767
+ ${this._wide ? this._createLabelForDayView(e) : p}
768
+ <sbb-screen-reader-only role="status">
769
+ ${this._createAriaLabelForDayView(this._activeDate, e)}
770
+ </sbb-screen-reader-only>
771
+ </div>
772
+ ${this._getArrow("right", () => this._goToDifferentMonth(1), Qe[this._language.current], this._nextMonthDisabled())}
773
+ </div>
774
+ <div class="sbb-calendar__table-overflow-break">
775
+ <div class="sbb-calendar__table-container sbb-calendar__table-day-view">
776
+ ${this.orientation === "horizontal" ? c`
777
+ ${this._createDayTable(this._weeks, this._weekNumbers)}
778
+ ${this._wide ? this._createDayTable(this._nextMonthWeeks, this._nextMonthWeekNumbers, !0) : p}
779
+ ` : c`
780
+ ${this._createDayTableVertical(this._weeks, this._weekNumbers)}
781
+ ${this._wide ? this._createDayTableVertical(this._nextMonthWeeks, this._nextMonthWeekNumbers, e) : p}
782
+ `}
783
+ </div>
784
+ </div>
785
+ `;
786
+ }
787
+ /** Creates the label with the month for the daily view. */
788
+ _createLabelForDayView(e) {
789
+ const t = `${this._monthNames[this._dateAdapter.getMonth(e) - 1]} ${this._dateAdapter.getYear(e)}`;
790
+ return c`
791
+ <button
792
+ type="button"
793
+ class="sbb-calendar__date-selection sbb-calendar__controls-change-date"
794
+ aria-label="${je[this._language.current]} ${t}"
795
+ @click=${() => {
796
+ this._resetFocus = !0, this._nextCalendarView = "year", this._startTableTransition();
797
+ }}
798
+ >
799
+ ${t}
800
+ <sbb-icon name="chevron-small-down-small"></sbb-icon>
801
+ </button>
802
+ `;
803
+ }
804
+ /** Creates the aria-label for the daily view. */
805
+ _createAriaLabelForDayView(...e) {
806
+ let t = "";
807
+ for (const a of e)
808
+ a && (t += `${this._monthNames[this._dateAdapter.getMonth(a) - 1]} ${this._dateAdapter.getYear(a)} `);
809
+ return t;
810
+ }
811
+ /** Creates the calendar table for the daily view. */
812
+ _createDayTable(e, t, a = !1) {
813
+ const s = (this._wide ? [...this._weeks, ...this._nextMonthWeeks] : a ? this._nextMonthWeeks : this._weeks).flat(), r = (a ? this._nextMonthWeeks : this._weeks).flat();
814
+ return c`
815
+ <table
816
+ class="sbb-calendar__table"
817
+ @focusout=${(i) => this._handleTableBlur(i.relatedTarget)}
818
+ @animationend=${(i) => this._tableAnimationEnd(i)}
819
+ >
820
+ <thead class="sbb-calendar__table-header">
821
+ <tr>
822
+ ${this.weekNumbers ? c`<th class="sbb-calendar__table-header-cell"></th>` : p}
823
+ ${this._weekdays.map((i, l) => c`
824
+ <th class="sbb-calendar__table-header-cell">
825
+ ${this.multiple ? c`
826
+ <button
827
+ class="sbb-calendar__header-cell sbb-calendar__weekday"
828
+ aria-label=${i.long}
829
+ @click=${() => {
830
+ const b = r.filter((f) => f.weekDayValue === (l + 1) % 7);
831
+ this._selectMultipleDates(b);
832
+ }}
833
+ >
834
+ ${i.narrow}
835
+ </button>
836
+ ` : c`
837
+ <sbb-screen-reader-only>${i.long}</sbb-screen-reader-only>
838
+ <span aria-hidden="true">${i.narrow}</span>
839
+ `}
840
+ </th>
841
+ `)}
842
+ </tr>
843
+ </thead>
844
+ <tbody class="sbb-calendar__table-body">
845
+ ${e.map((i, l) => {
846
+ const b = y - i.length;
847
+ return l === 0 && b ? c`
848
+ <tr>
849
+ ${this.weekNumbers ? c`
850
+ <td class="sbb-calendar__table-header-cell-vertical">
851
+ ${this.multiple ? c`
852
+ <button
853
+ class="sbb-calendar__header-cell sbb-calendar__weekday"
854
+ aria-label=${`${K[this._language.current]} ${t[0]}`}
855
+ @click=${() => {
856
+ const f = s.filter((k) => k.weekValue === t[0]);
857
+ this._selectMultipleDates(f);
858
+ }}
859
+ >
860
+ ${t[0]}
861
+ </button>
862
+ ` : c`
863
+ <sbb-screen-reader-only
864
+ >${`${K[this._language.current]} ${t[0]}`}</sbb-screen-reader-only
865
+ >
866
+ <span aria-hidden="true">${t[0]}</span>
867
+ `}
868
+ </td>
869
+ ` : p}
870
+ ${[...Array(b).keys()].map(() => c`<td class="sbb-calendar__table-data"></td>`)}
871
+ ${this._createDayCells(i)}
872
+ </tr>
873
+ ` : c`
874
+ <tr>
875
+ ${this.weekNumbers ? c`
876
+ <td class="sbb-calendar__table-header-cell-vertical">
877
+ ${this.multiple ? c`
878
+ <button
879
+ class="sbb-calendar__header-cell sbb-calendar__weekday"
880
+ aria-label=${`${K[this._language.current]} ${t[l]}`}
881
+ @click=${() => {
882
+ const f = s.filter((k) => k.weekValue === t[l]);
883
+ this._selectMultipleDates(f);
884
+ }}
885
+ >
886
+ ${t[l]}
887
+ </button>
888
+ ` : c`
889
+ <sbb-screen-reader-only
890
+ >${`${K[this._language.current]} ${t[l]}`}</sbb-screen-reader-only
891
+ >
892
+ <span aria-hidden="true">${t[l]}</span>
893
+ `}
894
+ </td>
895
+ ` : p}
896
+ ${this._createDayCells(i)}
897
+ </tr>
898
+ `;
899
+ })}
900
+ </tbody>
901
+ </table>
902
+ `;
903
+ }
904
+ /** Creates the table in orientation='vertical'. */
905
+ _createDayTableVertical(e, t, a) {
906
+ const s = this._dateAdapter.getFirstWeekOffset(a ?? this._activeDate), r = (this._wide ? [...this._weeks, ...this._nextMonthWeeks] : a ? this._nextMonthWeeks : this._weeks).flat();
907
+ return c`
908
+ <table
909
+ class="sbb-calendar__table"
910
+ @focusout=${(i) => this._handleTableBlur(i.relatedTarget)}
911
+ @animationend=${(i) => this._tableAnimationEnd(i)}
912
+ >
913
+ ${this.weekNumbers ? c`
914
+ <thead class="sbb-calendar__table-header">
915
+ <tr>
916
+ ${a ? p : c`<th class="sbb-calendar__table-data"></th>`}
917
+ ${t.map((i) => c`
918
+ <th class="sbb-calendar__table-header-cell">
919
+ ${this.multiple ? c`
920
+ <button
921
+ class="sbb-calendar__header-cell sbb-calendar__weekday"
922
+ aria-label=${`${K[this._language.current]} ${i}`}
923
+ @click=${() => {
924
+ const l = r.filter((b) => b.weekValue === i);
925
+ this._selectMultipleDates(l);
926
+ }}
927
+ >
928
+ ${i}
929
+ </button>
930
+ ` : c`
931
+ <sbb-screen-reader-only
932
+ >${`${K[this._language.current]} ${i}`}</sbb-screen-reader-only
933
+ >
934
+ <span aria-hidden="true">${i}</span>
935
+ `}
936
+ </th>
937
+ `)}
938
+ </tr>
939
+ </thead>
940
+ ` : p}
941
+ <tbody class="sbb-calendar__table-body">
942
+ ${e.map((i, l) => {
943
+ const b = this._weekdays[l], f = this._wide ? [...i, ...this._nextMonthWeeks[l]] : i;
944
+ return c`
945
+ <tr>
946
+ ${a ? p : c`
947
+ <td class="sbb-calendar__table-header-cell-vertical">
948
+ ${this.multiple ? c`
949
+ <button
950
+ class="sbb-calendar__header-cell sbb-calendar__weekday"
951
+ aria-label=${b.long}
952
+ @click=${() => this._selectMultipleDates(f)}
953
+ >
954
+ ${b.narrow}
955
+ </button>
956
+ ` : c`
957
+ <sbb-screen-reader-only>${b.long}</sbb-screen-reader-only>
958
+ <span aria-hidden="true">${b.narrow}</span>
959
+ `}
960
+ </td>
961
+ `}
962
+ ${l < s ? c`<td class="sbb-calendar__table-data"></td>` : p}
963
+ ${this._createDayCells(i)}
964
+ </tr>
965
+ `;
966
+ })}
967
+ </tbody>
968
+ </table>
969
+ `;
970
+ }
971
+ /** Creates the cells for the daily view. */
972
+ _createDayCells(e) {
973
+ return e.map((t) => c`
974
+ <td class=" sbb-calendar__table-data sbb-calendar__day-cell">
975
+ <slot name=${t.value}>
976
+ <sbb-calendar-day
977
+ slot=${t.value}
978
+ @click=${() => this._selectDate(t.dateValue)}
979
+ @keydown=${(a) => this._handleKeyboardEvent(a, t)}
980
+ ></sbb-calendar-day>
981
+ </slot>
982
+ </td>
983
+ `);
984
+ }
985
+ /** Render the view for the month selection. */
986
+ _renderMonthView() {
987
+ return c`
988
+ <div class="sbb-calendar__controls">
989
+ ${this._getArrow("left", () => this._goToDifferentYear(-1), Ge[this._language.current], this._previousYearDisabled())}
990
+ <div class="sbb-calendar__controls-month">${this._createLabelForMonthView()}</div>
991
+ ${this._getArrow("right", () => this._goToDifferentYear(1), Je[this._language.current], this._nextYearDisabled())}
992
+ </div>
993
+ <div class="sbb-calendar__table-overflow-break">
994
+ <div class="sbb-calendar__table-container sbb-calendar__table-month-view">
995
+ ${this._createMonthTable(this._months, this._chosenYear)}
996
+ ${this._wide ? this._createMonthTable(this._months, this._chosenYear + 1) : p}
997
+ </div>
998
+ </div>
999
+ `;
1000
+ }
1001
+ /** Creates the label with the year for the monthly view. */
1002
+ _createLabelForMonthView() {
1003
+ return c` <button
1004
+ type="button"
1005
+ id="sbb-calendar__month-selection"
1006
+ class="sbb-calendar__controls-change-date"
1007
+ aria-label=${`${Ne[this._language.current]} ${this._chosenYear}`}
1008
+ @click=${() => this._resetCalendarViewAndEmitMonthChange(!0)}
1009
+ >
1010
+ ${this._chosenYear} ${this._wide ? ` - ${this._chosenYear + 1}` : p}
1011
+ <sbb-icon name="chevron-small-up-small"></sbb-icon>
1012
+ </button>
1013
+ <sbb-screen-reader-only role="status"> ${this._chosenYear} </sbb-screen-reader-only>`;
1014
+ }
1015
+ /** Creates the table for the month selection view. */
1016
+ _createMonthTable(e, t) {
1017
+ return c`
1018
+ <table
1019
+ class="sbb-calendar__table"
1020
+ @animationend=${(a) => this._tableAnimationEnd(a)}
1021
+ >
1022
+ ${this._wide ? c`<thead class="sbb-calendar__table-header" aria-hidden="true">
1023
+ <tr>
1024
+ <th class="sbb-calendar__table-header-cell" colspan=${j}>${t}</th>
1025
+ </tr>
1026
+ </thead>` : p}
1027
+ <tbody class="sbb-calendar__table-body">
1028
+ ${e.map((a) => c`
1029
+ <tr>
1030
+ ${a.map((s) => {
1031
+ let r;
1032
+ if (this.multiple)
1033
+ r = this._selected.find((f) => t === this._dateAdapter.getYear(f) && s.monthValue === this._dateAdapter.getMonth(f)) !== void 0;
1034
+ else {
1035
+ const f = this._selected ? this._dateAdapter.getMonth(this._selected) : void 0, k = this._selected ? this._dateAdapter.getYear(this._selected) : void 0;
1036
+ r = !!this._selected && t === k && s.monthValue === f;
1037
+ }
1038
+ const i = !this._isMonthInRange(s.monthValue, t), l = !this._isMonthFilteredOut(s.monthValue, t), b = t === this._dateAdapter.getYear(this._dateAdapter.today()) && this._dateAdapter.getMonth(this._dateAdapter.today()) === s.monthValue;
1039
+ return c` <td
1040
+ class=${J({
1041
+ "sbb-calendar__table-data": !0,
1042
+ "sbb-calendar__table-month": !0
1043
+ })}
1044
+ >
1045
+ <button
1046
+ class=${J({
1047
+ "sbb-calendar__cell": !0,
1048
+ "sbb-calendar__cell-current": b,
1049
+ "sbb-calendar__crossed-out": !i && l,
1050
+ "sbb-calendar__selected": r
1051
+ })}
1052
+ @click=${() => this._onMonthSelection(s.monthValue, t)}
1053
+ ?disabled=${i || l}
1054
+ aria-label=${`${s.longValue} ${t}`}
1055
+ aria-pressed=${r}
1056
+ aria-disabled=${String(i || l)}
1057
+ tabindex="-1"
1058
+ data-month=${s.monthValue || p}
1059
+ @keydown=${(f) => this._handleKeyboardEvent(f)}
1060
+ >
1061
+ ${s.value}
1062
+ </button>
1063
+ </td>`;
1064
+ })}
1065
+ </tr>
1066
+ `)}
1067
+ </tbody>
1068
+ </table>
1069
+ `;
1070
+ }
1071
+ /** Select the month and change the view to day selection. */
1072
+ _onMonthSelection(e, t) {
1073
+ this._chosenMonth = e, this._nextCalendarView = "day", this._init(this._dateAdapter.createDate(t, this._chosenMonth, this._dateAdapter.getDate(this._activeDate))), this._startTableTransition(), this._emitMonthChange();
1074
+ }
1075
+ /** Render the view for the year selection. */
1076
+ _renderYearView() {
1077
+ return c`
1078
+ <div class="sbb-calendar__controls">
1079
+ ${this._getArrow("left", () => this._goToDifferentYearRange(-$), Xe($)[this._language.current], this._previousYearRangeDisabled())}
1080
+ <div class="sbb-calendar__controls-month">${this._createLabelForYearView()}</div>
1081
+ ${this._getArrow("right", () => this._goToDifferentYearRange($), Ze($)[this._language.current], this._nextYearRangeDisabled())}
1082
+ </div>
1083
+ <div class="sbb-calendar__table-overflow-break">
1084
+ <div class="sbb-calendar__table-container sbb-calendar__table-year-view">
1085
+ ${this._createYearTable(this._years)}
1086
+ ${this._wide ? this._createYearTable(this._nextMonthYears, !0) : p}
1087
+ </div>
1088
+ </div>
1089
+ `;
1090
+ }
1091
+ /** Creates the button arrow for all the views. */
1092
+ _getArrow(e, t, a, s) {
1093
+ return c`<sbb-secondary-button
1094
+ size="m"
1095
+ icon-name="chevron-small-${e}-small"
1096
+ aria-label=${a}
1097
+ @click=${t}
1098
+ ?disabled=${s}
1099
+ id="sbb-calendar__controls-${e === "left" ? "previous" : "next"}"
1100
+ ></sbb-secondary-button>`;
1101
+ }
1102
+ /** Creates the label with the year range for the yearly view. */
1103
+ _createLabelForYearView() {
1104
+ const e = this._years.flat()[0], t = (this._wide ? this._nextMonthYears : this._years).flat(), a = t[t.length - 1], s = `${e} - ${a}`;
1105
+ return c`
1106
+ <button
1107
+ type="button"
1108
+ id="sbb-calendar__year-selection"
1109
+ class="sbb-calendar__controls-change-date"
1110
+ aria-label="${Ne[this._language.current]} ${s}"
1111
+ @click=${() => this._resetCalendarViewAndEmitMonthChange(!0)}
1112
+ >
1113
+ ${s}
1114
+ <sbb-icon name="chevron-small-up-small"></sbb-icon>
1115
+ </button>
1116
+ <sbb-screen-reader-only role="status"> ${s} </sbb-screen-reader-only>
1117
+ `;
1118
+ }
1119
+ /** Creates the table for the year selection view. */
1120
+ _createYearTable(e, t = !1) {
1121
+ const a = this._dateAdapter.today();
1122
+ return c` <table
1123
+ class="sbb-calendar__table"
1124
+ @animationend=${(s) => this._tableAnimationEnd(s)}
1125
+ >
1126
+ <tbody class="sbb-calendar__table-body">
1127
+ ${e.map((s) => c` <tr>
1128
+ ${s.map((r) => {
1129
+ let i;
1130
+ if (this.multiple)
1131
+ i = this._selected.find((k) => r === this._dateAdapter.getYear(k)) !== void 0;
1132
+ else {
1133
+ const k = this._selected ? this._dateAdapter.getYear(this._selected) : void 0;
1134
+ i = !!this._selected && r === k;
1135
+ }
1136
+ const l = !this._isYearInRange(r), b = !this._isYearFilteredOut(r), f = this._dateAdapter.getYear(a) === r;
1137
+ return c` <td class="sbb-calendar__table-data sbb-calendar__table-year">
1138
+ <button
1139
+ class=${J({
1140
+ "sbb-calendar__cell": !0,
1141
+ "sbb-calendar__cell-current": f,
1142
+ "sbb-calendar__crossed-out": !l && b,
1143
+ "sbb-calendar__selected": i
1144
+ })}
1145
+ @click=${() => this._onYearSelection(r, t)}
1146
+ ?disabled=${l || b}
1147
+ aria-label=${r}
1148
+ aria-pressed=${i}
1149
+ aria-disabled=${String(l || b)}
1150
+ tabindex="-1"
1151
+ data-year=${r || p}
1152
+ @keydown=${(k) => this._handleKeyboardEvent(k)}
1153
+ >
1154
+ ${r}
1155
+ </button>
1156
+ </td>`;
1157
+ })}
1158
+ </tr>`)}
1159
+ </tbody>
1160
+ </table>`;
1161
+ }
1162
+ /** Select the year and change the view to month selection. */
1163
+ _onYearSelection(e, t) {
1164
+ this._chosenYear = t ? e - 1 : e, this._nextCalendarView = "month", this._assignActiveDate(this._dateAdapter.createDate(this._chosenYear, this._dateAdapter.getMonth(this._activeDate), this._dateAdapter.getDate(this._activeDate))), this._startTableTransition();
1165
+ }
1166
+ _getView() {
1167
+ if (Fe || this.hydrationRequired)
1168
+ return c`${p}`;
1169
+ switch (this._calendarView) {
1170
+ case "year":
1171
+ return this._renderYearView();
1172
+ case "month":
1173
+ return this._renderMonthView();
1174
+ default:
1175
+ return this._renderDayView();
1176
+ }
1177
+ }
1178
+ _tableAnimationEnd(e) {
1179
+ const t = e.target;
1180
+ e.animationName === "hide" ? (t.classList.remove("sbb-calendar__table-hide"), this._containingFocus && (this._resetFocus = !0), this._calendarView = this._nextCalendarView) : e.animationName === "show" && this.internals.states.delete("transition");
1181
+ }
1182
+ _startTableTransition() {
1183
+ this.internals.states.add("transition"), this.shadowRoot?.querySelectorAll("table")?.forEach((e) => e.classList.toggle("sbb-calendar__table-hide"));
1184
+ }
1185
+ render() {
1186
+ return c`<div class="sbb-calendar__wrapper">${this._getView()}</div>`;
1187
+ }
1188
+ }, N = new WeakMap(), I = new WeakMap(), C = new WeakMap(), R = new WeakMap(), S = new WeakMap(), T = new WeakMap(), P = new WeakMap(), E = new WeakMap(), L = new WeakMap(), B = new WeakMap(), H = new WeakMap(), q = new WeakMap(), (() => {
1189
+ const e = typeof Symbol == "function" && Symbol.metadata ? Object.create(o[Symbol.metadata] ?? null) : void 0;
1190
+ d = [X(), Y({ type: Boolean })], v = [Y()], D = [We(), Y()], ee = [We(), Y()], se = [X(), Ke((t, a) => t._onMultipleChanged(a)), Y({ type: Boolean })], ne = [Y()], le = [Q()], ce = [Y({ attribute: "date-filter" })], _e = [Y({ reflect: !0 })], ge = [X(), Y({ attribute: "week-numbers", type: Boolean })], ve = [Q()], De = [Q()], ke = [Q()], Ve = [Q()], w(g, null, d, { kind: "accessor", name: "wide", static: !1, private: !1, access: { has: (t) => "wide" in t, get: (t) => t.wide, set: (t, a) => {
1191
+ t.wide = a;
1192
+ } }, metadata: e }, h, m), w(g, null, v, { kind: "accessor", name: "view", static: !1, private: !1, access: { has: (t) => "view" in t, get: (t) => t.view, set: (t, a) => {
1193
+ t.view = a;
1194
+ } }, metadata: e }, V, O), w(g, null, D, { kind: "accessor", name: "min", static: !1, private: !1, access: { has: (t) => "min" in t, get: (t) => t.min, set: (t, a) => {
1195
+ t.min = a;
1196
+ } }, metadata: e }, M, W), w(g, null, ee, { kind: "accessor", name: "max", static: !1, private: !1, access: { has: (t) => "max" in t, get: (t) => t.max, set: (t, a) => {
1197
+ t.max = a;
1198
+ } }, metadata: e }, te, ae), w(g, null, se, { kind: "accessor", name: "multiple", static: !1, private: !1, access: { has: (t) => "multiple" in t, get: (t) => t.multiple, set: (t, a) => {
1199
+ t.multiple = a;
1200
+ } }, metadata: e }, re, ie), w(g, null, ne, { kind: "setter", name: "selected", static: !1, private: !1, access: { has: (t) => "selected" in t, set: (t, a) => {
1201
+ t.selected = a;
1202
+ } }, metadata: e }, null, n), w(g, null, le, { kind: "accessor", name: "_selected", static: !1, private: !1, access: { has: (t) => "_selected" in t, get: (t) => t._selected, set: (t, a) => {
1203
+ t._selected = a;
1204
+ } }, metadata: e }, oe, de), w(g, null, ce, { kind: "accessor", name: "dateFilter", static: !1, private: !1, access: { has: (t) => "dateFilter" in t, get: (t) => t.dateFilter, set: (t, a) => {
1205
+ t.dateFilter = a;
1206
+ } }, metadata: e }, he, be), w(g, null, _e, { kind: "accessor", name: "orientation", static: !1, private: !1, access: { has: (t) => "orientation" in t, get: (t) => t.orientation, set: (t, a) => {
1207
+ t.orientation = a;
1208
+ } }, metadata: e }, ue, fe), w(g, null, ge, { kind: "accessor", name: "weekNumbers", static: !1, private: !1, access: { has: (t) => "weekNumbers" in t, get: (t) => t.weekNumbers, set: (t, a) => {
1209
+ t.weekNumbers = a;
1210
+ } }, metadata: e }, me, pe), w(g, null, ve, { kind: "accessor", name: "_activeDate", static: !1, private: !1, access: { has: (t) => "_activeDate" in t, get: (t) => t._activeDate, set: (t, a) => {
1211
+ t._activeDate = a;
1212
+ } }, metadata: e }, we, ye), w(g, null, De, { kind: "setter", name: "_wide", static: !1, private: !1, access: { has: (t) => "_wide" in t, set: (t, a) => {
1213
+ t._wide = a;
1214
+ } }, metadata: e }, null, n), w(g, null, ke, { kind: "accessor", name: "_calendarView", static: !1, private: !1, access: { has: (t) => "_calendarView" in t, get: (t) => t._calendarView, set: (t, a) => {
1215
+ t._calendarView = a;
1216
+ } }, metadata: e }, Ae, xe), w(g, null, Ve, { kind: "accessor", name: "_initialized", static: !1, private: !1, access: { has: (t) => "_initialized" in t, get: (t) => t._initialized, set: (t, a) => {
1217
+ t._initialized = a;
1218
+ } }, metadata: e }, $e, Me), e && Object.defineProperty(g, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: e });
1219
+ })(), g.elementName = "sbb-calendar", g.styles = [et, _t], g.events = {
1220
+ dateselected: "dateselected",
1221
+ monthchange: "monthchange"
1222
+ }, g;
1223
+ })();
1224
+ export {
1225
+ Wt as SbbCalendarElement,
1226
+ ut as SbbMonthChangeEvent
1227
+ };