@sbb-esta/lyne-elements 1.13.0 → 1.14.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (889) hide show
  1. package/accordion/accordion.d.ts +4 -8
  2. package/accordion/accordion.d.ts.map +1 -1
  3. package/accordion.js +90 -81
  4. package/action-group/action-group.d.ts +5 -5
  5. package/action-group/action-group.d.ts.map +1 -1
  6. package/action-group.js +100 -50
  7. package/alert/alert/alert.d.ts +11 -11
  8. package/alert/alert/alert.d.ts.map +1 -1
  9. package/alert/alert-group/alert-group.d.ts +4 -4
  10. package/alert/alert-group/alert-group.d.ts.map +1 -1
  11. package/alert/alert-group.js +101 -69
  12. package/alert/alert.js +191 -104
  13. package/autocomplete/autocomplete-base-element.d.ts +3 -7
  14. package/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  15. package/autocomplete/autocomplete.d.ts.map +1 -1
  16. package/autocomplete-grid/autocomplete-grid/autocomplete-grid.d.ts.map +1 -1
  17. package/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.d.ts +1 -0
  18. package/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.d.ts.map +1 -1
  19. package/autocomplete-grid/autocomplete-grid-button.js +53 -60
  20. package/autocomplete-grid/autocomplete-grid-cell/autocomplete-grid-cell.d.ts.map +1 -1
  21. package/autocomplete-grid/autocomplete-grid-cell.js +20 -22
  22. package/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.d.ts.map +1 -1
  23. package/autocomplete-grid/autocomplete-grid-optgroup.js +31 -35
  24. package/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.d.ts.map +1 -1
  25. package/autocomplete-grid/autocomplete-grid-option.js +45 -63
  26. package/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.d.ts.map +1 -1
  27. package/autocomplete-grid/autocomplete-grid-row.js +23 -25
  28. package/autocomplete-grid/autocomplete-grid.js +112 -133
  29. package/autocomplete.js +283 -295
  30. package/breadcrumb/breadcrumb/breadcrumb.d.ts +1 -1
  31. package/breadcrumb/breadcrumb/breadcrumb.d.ts.map +1 -1
  32. package/breadcrumb/breadcrumb-group/breadcrumb-group.d.ts.map +1 -1
  33. package/breadcrumb/breadcrumb-group.js +107 -114
  34. package/breadcrumb/breadcrumb.js +44 -35
  35. package/button/button/button.d.ts.map +1 -1
  36. package/button/button-link/button-link.d.ts.map +1 -1
  37. package/button/button-link.js +15 -18
  38. package/button/button-static/button-static.d.ts.map +1 -1
  39. package/button/button-static.js +15 -18
  40. package/button/button.js +15 -18
  41. package/button/common/button-common.d.ts +4 -4
  42. package/button/common/button-common.d.ts.map +1 -1
  43. package/button/common.js +41 -30
  44. package/button/mini-button/mini-button-base-element.d.ts.map +1 -1
  45. package/button/mini-button/mini-button.d.ts.map +1 -1
  46. package/button/mini-button-group/mini-button-group.d.ts +2 -2
  47. package/button/mini-button-group/mini-button-group.d.ts.map +1 -1
  48. package/button/mini-button-group.js +55 -43
  49. package/button/mini-button.js +30 -34
  50. package/button/secondary-button/secondary-button.d.ts.map +1 -1
  51. package/button/secondary-button-link/secondary-button-link.d.ts.map +1 -1
  52. package/button/secondary-button-link.js +15 -18
  53. package/button/secondary-button-static/secondary-button-static.d.ts.map +1 -1
  54. package/button/secondary-button-static.js +15 -18
  55. package/button/secondary-button.js +15 -18
  56. package/button/tertiary-button/tertiary-button.d.ts.map +1 -1
  57. package/button/tertiary-button-link/tertiary-button-link.d.ts.map +1 -1
  58. package/button/tertiary-button-link.js +15 -18
  59. package/button/tertiary-button-static/tertiary-button-static.d.ts.map +1 -1
  60. package/button/tertiary-button-static.js +15 -18
  61. package/button/tertiary-button.js +15 -18
  62. package/button/transparent-button/transparent-button.d.ts.map +1 -1
  63. package/button/transparent-button-link/transparent-button-link.d.ts.map +1 -1
  64. package/button/transparent-button-link.js +15 -18
  65. package/button/transparent-button-static/transparent-button-static.d.ts.map +1 -1
  66. package/button/transparent-button-static.js +15 -18
  67. package/button/transparent-button.js +15 -18
  68. package/calendar/calendar.d.ts +7 -7
  69. package/calendar/calendar.d.ts.map +1 -1
  70. package/calendar.js +644 -699
  71. package/card/card/card.d.ts +2 -2
  72. package/card/card/card.d.ts.map +1 -1
  73. package/card/card-badge/card-badge.d.ts +1 -1
  74. package/card/card-badge/card-badge.d.ts.map +1 -1
  75. package/card/card-badge.js +45 -34
  76. package/card/card-button/card-button.d.ts.map +1 -1
  77. package/card/card-button.js +16 -16
  78. package/card/card-link/card-link.d.ts.map +1 -1
  79. package/card/card-link.js +17 -17
  80. package/card/card.js +55 -36
  81. package/card/common/card-action-common.d.ts +1 -1
  82. package/card/common/card-action-common.d.ts.map +1 -1
  83. package/card/common.js +27 -33
  84. package/checkbox/checkbox/checkbox.d.ts +3 -4
  85. package/checkbox/checkbox/checkbox.d.ts.map +1 -1
  86. package/checkbox/checkbox-group/checkbox-group.d.ts +4 -4
  87. package/checkbox/checkbox-group/checkbox-group.d.ts.map +1 -1
  88. package/checkbox/checkbox-group.js +99 -76
  89. package/checkbox/checkbox-panel/checkbox-panel.d.ts +2 -3
  90. package/checkbox/checkbox-panel/checkbox-panel.d.ts.map +1 -1
  91. package/checkbox/checkbox-panel.js +51 -50
  92. package/checkbox/checkbox.js +54 -43
  93. package/checkbox/common/checkbox-common.d.ts +1 -1
  94. package/checkbox/common/checkbox-common.d.ts.map +1 -1
  95. package/checkbox/common.js +39 -24
  96. package/chip/chip.d.ts +2 -2
  97. package/chip/chip.d.ts.map +1 -1
  98. package/chip.js +45 -26
  99. package/clock/clock.d.ts +1 -1
  100. package/clock/clock.d.ts.map +1 -1
  101. package/clock.js +136 -144
  102. package/container/container/container.d.ts +3 -3
  103. package/container/container/container.d.ts.map +1 -1
  104. package/container/container.js +60 -35
  105. package/container/sticky-bar/sticky-bar.d.ts +1 -1
  106. package/container/sticky-bar/sticky-bar.d.ts.map +1 -1
  107. package/container/sticky-bar.js +55 -47
  108. package/core/a11y.js +29 -51
  109. package/core/base-elements/action-base-element.d.ts.map +1 -1
  110. package/core/base-elements/button-base-element.d.ts +2 -2
  111. package/core/base-elements/button-base-element.d.ts.map +1 -1
  112. package/core/base-elements/link-base-element.d.ts +5 -5
  113. package/core/base-elements/link-base-element.d.ts.map +1 -1
  114. package/core/base-elements.js +243 -196
  115. package/core/controllers.js +8 -13
  116. package/core/decorators/base.d.ts +14 -0
  117. package/core/decorators/base.d.ts.map +1 -0
  118. package/core/decorators/force-type.d.ts +8 -0
  119. package/core/decorators/force-type.d.ts.map +1 -0
  120. package/core/decorators/get-override.d.ts +7 -0
  121. package/core/decorators/get-override.d.ts.map +1 -0
  122. package/core/decorators/handle-distinct-change.d.ts +8 -0
  123. package/core/decorators/handle-distinct-change.d.ts.map +1 -0
  124. package/core/decorators/omit-empty-converter.d.ts +8 -0
  125. package/core/decorators/omit-empty-converter.d.ts.map +1 -0
  126. package/core/decorators.d.ts +4 -0
  127. package/core/decorators.d.ts.map +1 -1
  128. package/core/decorators.js +59 -15
  129. package/core/dom.js +1 -5
  130. package/core/eventing.js +1 -4
  131. package/core/interfaces/paginator-page.d.ts +7 -0
  132. package/core/interfaces/paginator-page.d.ts.map +1 -0
  133. package/core/interfaces.d.ts +1 -0
  134. package/core/interfaces.d.ts.map +1 -1
  135. package/core/mixins/disabled-mixin.d.ts +2 -3
  136. package/core/mixins/disabled-mixin.d.ts.map +1 -1
  137. package/core/mixins/named-slot-list-mixin.d.ts +1 -1
  138. package/core/mixins/named-slot-list-mixin.d.ts.map +1 -1
  139. package/core/mixins/negative-mixin.d.ts +1 -1
  140. package/core/mixins/negative-mixin.d.ts.map +1 -1
  141. package/core/mixins/panel-mixin.d.ts +3 -3
  142. package/core/mixins/panel-mixin.d.ts.map +1 -1
  143. package/core/mixins/required-mixin.d.ts +1 -2
  144. package/core/mixins/required-mixin.d.ts.map +1 -1
  145. package/core/mixins.js +290 -237
  146. package/core/testing/private.d.ts +1 -0
  147. package/core/testing/private.d.ts.map +1 -1
  148. package/core/testing.js +7 -13
  149. package/custom-elements.json +15974 -15154
  150. package/datepicker/common/datepicker-button.d.ts +2 -2
  151. package/datepicker/common/datepicker-button.d.ts.map +1 -1
  152. package/datepicker/common.js +110 -116
  153. package/datepicker/datepicker/datepicker.d.ts +6 -6
  154. package/datepicker/datepicker/datepicker.d.ts.map +1 -1
  155. package/datepicker/datepicker-next-day/datepicker-next-day.d.ts.map +1 -1
  156. package/datepicker/datepicker-next-day.js +24 -26
  157. package/datepicker/datepicker-previous-day/datepicker-previous-day.d.ts.map +1 -1
  158. package/datepicker/datepicker-previous-day.js +25 -27
  159. package/datepicker/datepicker-toggle/datepicker-toggle.d.ts +6 -6
  160. package/datepicker/datepicker-toggle/datepicker-toggle.d.ts.map +1 -1
  161. package/datepicker/datepicker-toggle.js +154 -136
  162. package/datepicker/datepicker.js +248 -213
  163. package/development/accordion/accordion.d.ts +4 -8
  164. package/development/accordion/accordion.d.ts.map +1 -1
  165. package/development/accordion.js +118 -93
  166. package/development/action-group/action-group.d.ts +5 -5
  167. package/development/action-group/action-group.d.ts.map +1 -1
  168. package/development/action-group.js +138 -64
  169. package/development/alert/alert/alert.d.ts +11 -11
  170. package/development/alert/alert/alert.d.ts.map +1 -1
  171. package/development/alert/alert-group/alert-group.d.ts +4 -4
  172. package/development/alert/alert-group/alert-group.d.ts.map +1 -1
  173. package/development/alert/alert-group.js +135 -79
  174. package/development/alert/alert.js +259 -109
  175. package/development/autocomplete/autocomplete-base-element.d.ts +3 -7
  176. package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  177. package/development/autocomplete/autocomplete.d.ts.map +1 -1
  178. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.d.ts.map +1 -1
  179. package/development/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.d.ts +1 -0
  180. package/development/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.d.ts.map +1 -1
  181. package/development/autocomplete-grid/autocomplete-grid-button.js +74 -75
  182. package/development/autocomplete-grid/autocomplete-grid-cell/autocomplete-grid-cell.d.ts.map +1 -1
  183. package/development/autocomplete-grid/autocomplete-grid-cell.js +24 -24
  184. package/development/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.d.ts.map +1 -1
  185. package/development/autocomplete-grid/autocomplete-grid-optgroup.js +38 -39
  186. package/development/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.d.ts.map +1 -1
  187. package/development/autocomplete-grid/autocomplete-grid-option.js +57 -73
  188. package/development/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.d.ts.map +1 -1
  189. package/development/autocomplete-grid/autocomplete-grid-row.js +28 -28
  190. package/development/autocomplete-grid/autocomplete-grid.js +142 -160
  191. package/development/autocomplete.js +394 -393
  192. package/development/breadcrumb/breadcrumb/breadcrumb.d.ts +1 -1
  193. package/development/breadcrumb/breadcrumb/breadcrumb.d.ts.map +1 -1
  194. package/development/breadcrumb/breadcrumb-group/breadcrumb-group.d.ts.map +1 -1
  195. package/development/breadcrumb/breadcrumb-group.js +130 -130
  196. package/development/breadcrumb/breadcrumb.js +53 -36
  197. package/development/button/button/button.d.ts.map +1 -1
  198. package/development/button/button-link/button-link.d.ts.map +1 -1
  199. package/development/button/button-link.js +18 -19
  200. package/development/button/button-static/button-static.d.ts.map +1 -1
  201. package/development/button/button-static.js +18 -19
  202. package/development/button/button.js +18 -19
  203. package/development/button/common/button-common.d.ts +4 -4
  204. package/development/button/common/button-common.d.ts.map +1 -1
  205. package/development/button/common.js +50 -29
  206. package/development/button/mini-button/mini-button-base-element.d.ts.map +1 -1
  207. package/development/button/mini-button/mini-button.d.ts.map +1 -1
  208. package/development/button/mini-button-group/mini-button-group.d.ts +2 -2
  209. package/development/button/mini-button-group/mini-button-group.d.ts.map +1 -1
  210. package/development/button/mini-button-group.js +77 -50
  211. package/development/button/mini-button.js +38 -37
  212. package/development/button/secondary-button/secondary-button.d.ts.map +1 -1
  213. package/development/button/secondary-button-link/secondary-button-link.d.ts.map +1 -1
  214. package/development/button/secondary-button-link.js +18 -19
  215. package/development/button/secondary-button-static/secondary-button-static.d.ts.map +1 -1
  216. package/development/button/secondary-button-static.js +18 -19
  217. package/development/button/secondary-button.js +18 -19
  218. package/development/button/tertiary-button/tertiary-button.d.ts.map +1 -1
  219. package/development/button/tertiary-button-link/tertiary-button-link.d.ts.map +1 -1
  220. package/development/button/tertiary-button-link.js +18 -19
  221. package/development/button/tertiary-button-static/tertiary-button-static.d.ts.map +1 -1
  222. package/development/button/tertiary-button-static.js +18 -19
  223. package/development/button/tertiary-button.js +18 -19
  224. package/development/button/transparent-button/transparent-button.d.ts.map +1 -1
  225. package/development/button/transparent-button-link/transparent-button-link.d.ts.map +1 -1
  226. package/development/button/transparent-button-link.js +18 -19
  227. package/development/button/transparent-button-static/transparent-button-static.d.ts.map +1 -1
  228. package/development/button/transparent-button-static.js +18 -19
  229. package/development/button/transparent-button.js +18 -19
  230. package/development/calendar/calendar.d.ts +7 -7
  231. package/development/calendar/calendar.d.ts.map +1 -1
  232. package/development/calendar.js +774 -773
  233. package/development/card/card/card.d.ts +2 -2
  234. package/development/card/card/card.d.ts.map +1 -1
  235. package/development/card/card-badge/card-badge.d.ts +1 -1
  236. package/development/card/card-badge/card-badge.d.ts.map +1 -1
  237. package/development/card/card-badge.js +65 -45
  238. package/development/card/card-button/card-button.d.ts.map +1 -1
  239. package/development/card/card-button.js +23 -20
  240. package/development/card/card-link/card-link.d.ts.map +1 -1
  241. package/development/card/card-link.js +23 -20
  242. package/development/card/card.js +72 -41
  243. package/development/card/common/card-action-common.d.ts +1 -1
  244. package/development/card/common/card-action-common.d.ts.map +1 -1
  245. package/development/card/common.js +74 -73
  246. package/development/checkbox/checkbox/checkbox.d.ts +3 -4
  247. package/development/checkbox/checkbox/checkbox.d.ts.map +1 -1
  248. package/development/checkbox/checkbox-group/checkbox-group.d.ts +4 -4
  249. package/development/checkbox/checkbox-group/checkbox-group.d.ts.map +1 -1
  250. package/development/checkbox/checkbox-group.js +139 -92
  251. package/development/checkbox/checkbox-panel/checkbox-panel.d.ts +2 -3
  252. package/development/checkbox/checkbox-panel/checkbox-panel.d.ts.map +1 -1
  253. package/development/checkbox/checkbox-panel.js +68 -60
  254. package/development/checkbox/checkbox.js +69 -46
  255. package/development/checkbox/common/checkbox-common.d.ts +1 -1
  256. package/development/checkbox/common/checkbox-common.d.ts.map +1 -1
  257. package/development/checkbox/common.js +65 -46
  258. package/development/chip/chip.d.ts +2 -2
  259. package/development/chip/chip.d.ts.map +1 -1
  260. package/development/chip.js +64 -33
  261. package/development/clock/clock.d.ts +1 -1
  262. package/development/clock/clock.d.ts.map +1 -1
  263. package/development/clock.js +203 -201
  264. package/development/container/container/container.d.ts +3 -3
  265. package/development/container/container/container.d.ts.map +1 -1
  266. package/development/container/container.js +86 -45
  267. package/development/container/sticky-bar/sticky-bar.d.ts +1 -1
  268. package/development/container/sticky-bar/sticky-bar.d.ts.map +1 -1
  269. package/development/container/sticky-bar.js +76 -58
  270. package/development/core/a11y.js +40 -62
  271. package/development/core/base-elements/action-base-element.d.ts.map +1 -1
  272. package/development/core/base-elements/button-base-element.d.ts +2 -2
  273. package/development/core/base-elements/button-base-element.d.ts.map +1 -1
  274. package/development/core/base-elements/link-base-element.d.ts +5 -5
  275. package/development/core/base-elements/link-base-element.d.ts.map +1 -1
  276. package/development/core/base-elements.js +329 -226
  277. package/development/core/config.js +1 -1
  278. package/development/core/controllers.js +13 -21
  279. package/development/core/datetime.js +1 -1
  280. package/development/core/decorators/base.d.ts +14 -0
  281. package/development/core/decorators/base.d.ts.map +1 -0
  282. package/development/core/decorators/force-type.d.ts +8 -0
  283. package/development/core/decorators/force-type.d.ts.map +1 -0
  284. package/development/core/decorators/get-override.d.ts +7 -0
  285. package/development/core/decorators/get-override.d.ts.map +1 -0
  286. package/development/core/decorators/handle-distinct-change.d.ts +8 -0
  287. package/development/core/decorators/handle-distinct-change.d.ts.map +1 -0
  288. package/development/core/decorators/omit-empty-converter.d.ts +8 -0
  289. package/development/core/decorators/omit-empty-converter.d.ts.map +1 -0
  290. package/development/core/decorators.d.ts +4 -0
  291. package/development/core/decorators.d.ts.map +1 -1
  292. package/development/core/decorators.js +69 -5
  293. package/development/core/dom.js +2 -6
  294. package/development/core/eventing.js +2 -5
  295. package/development/core/i18n.js +1 -1
  296. package/development/core/interfaces/paginator-page.d.ts +7 -0
  297. package/development/core/interfaces/paginator-page.d.ts.map +1 -0
  298. package/development/core/interfaces.d.ts +1 -0
  299. package/development/core/interfaces.d.ts.map +1 -1
  300. package/development/core/mixins/disabled-mixin.d.ts +2 -3
  301. package/development/core/mixins/disabled-mixin.d.ts.map +1 -1
  302. package/development/core/mixins/named-slot-list-mixin.d.ts +1 -1
  303. package/development/core/mixins/named-slot-list-mixin.d.ts.map +1 -1
  304. package/development/core/mixins/negative-mixin.d.ts +1 -1
  305. package/development/core/mixins/negative-mixin.d.ts.map +1 -1
  306. package/development/core/mixins/panel-mixin.d.ts +3 -3
  307. package/development/core/mixins/panel-mixin.d.ts.map +1 -1
  308. package/development/core/mixins/required-mixin.d.ts +1 -2
  309. package/development/core/mixins/required-mixin.d.ts.map +1 -1
  310. package/development/core/mixins.js +573 -475
  311. package/development/core/observers.js +1 -1
  312. package/development/core/overlay.js +1 -1
  313. package/development/core/testing/private.d.ts +1 -0
  314. package/development/core/testing/private.d.ts.map +1 -1
  315. package/development/core/testing.js +16 -22
  316. package/development/datepicker/common/datepicker-button.d.ts +2 -2
  317. package/development/datepicker/common/datepicker-button.d.ts.map +1 -1
  318. package/development/datepicker/common.js +144 -142
  319. package/development/datepicker/datepicker/datepicker.d.ts +6 -6
  320. package/development/datepicker/datepicker/datepicker.d.ts.map +1 -1
  321. package/development/datepicker/datepicker-next-day/datepicker-next-day.d.ts.map +1 -1
  322. package/development/datepicker/datepicker-next-day.js +32 -32
  323. package/development/datepicker/datepicker-previous-day/datepicker-previous-day.d.ts.map +1 -1
  324. package/development/datepicker/datepicker-previous-day.js +32 -32
  325. package/development/datepicker/datepicker-toggle/datepicker-toggle.d.ts +6 -6
  326. package/development/datepicker/datepicker-toggle/datepicker-toggle.d.ts.map +1 -1
  327. package/development/datepicker/datepicker-toggle.js +227 -174
  328. package/development/datepicker/datepicker.js +327 -249
  329. package/development/dialog/dialog/dialog.d.ts +1 -1
  330. package/development/dialog/dialog/dialog.d.ts.map +1 -1
  331. package/development/dialog/dialog-actions/dialog-actions.d.ts.map +1 -1
  332. package/development/dialog/dialog-actions.js +21 -20
  333. package/development/dialog/dialog-content/dialog-content.d.ts.map +1 -1
  334. package/development/dialog/dialog-content.js +22 -21
  335. package/development/dialog/dialog-title/dialog-title.d.ts +3 -3
  336. package/development/dialog/dialog-title/dialog-title.d.ts.map +1 -1
  337. package/development/dialog/dialog-title.js +121 -66
  338. package/development/dialog/dialog.js +205 -191
  339. package/development/divider/divider.d.ts +1 -1
  340. package/development/divider/divider.d.ts.map +1 -1
  341. package/development/divider.js +55 -36
  342. package/development/expansion-panel/expansion-panel/expansion-panel.d.ts +4 -4
  343. package/development/expansion-panel/expansion-panel/expansion-panel.d.ts.map +1 -1
  344. package/development/expansion-panel/expansion-panel-content/expansion-panel-content.d.ts.map +1 -1
  345. package/development/expansion-panel/expansion-panel-content.js +25 -25
  346. package/development/expansion-panel/expansion-panel-header/expansion-panel-header.d.ts +1 -1
  347. package/development/expansion-panel/expansion-panel-header/expansion-panel-header.d.ts.map +1 -1
  348. package/development/expansion-panel/expansion-panel-header.js +56 -63
  349. package/development/expansion-panel/expansion-panel.js +227 -182
  350. package/development/file-selector/file-selector.d.ts +8 -7
  351. package/development/file-selector/file-selector.d.ts.map +1 -1
  352. package/development/file-selector.js +295 -198
  353. package/development/flip-card/flip-card/flip-card.d.ts +2 -2
  354. package/development/flip-card/flip-card/flip-card.d.ts.map +1 -1
  355. package/development/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -1
  356. package/development/flip-card/flip-card-details.js +39 -39
  357. package/development/flip-card/flip-card-summary/flip-card-summary.d.ts +1 -1
  358. package/development/flip-card/flip-card-summary/flip-card-summary.d.ts.map +1 -1
  359. package/development/flip-card/flip-card-summary.js +57 -38
  360. package/development/flip-card/flip-card.js +110 -78
  361. package/development/footer/footer.d.ts +4 -4
  362. package/development/footer/footer.d.ts.map +1 -1
  363. package/development/footer.js +103 -41
  364. package/development/form-error/form-error.d.ts.map +1 -1
  365. package/development/form-error.js +29 -28
  366. package/development/form-field/form-field/form-field.d.ts +10 -10
  367. package/development/form-field/form-field/form-field.d.ts.map +1 -1
  368. package/development/form-field/form-field-clear/form-field-clear.d.ts.map +1 -1
  369. package/development/form-field/form-field-clear.js +50 -50
  370. package/development/form-field/form-field.js +439 -328
  371. package/development/header/common/header-action-common.d.ts +2 -2
  372. package/development/header/common/header-action-common.d.ts.map +1 -1
  373. package/development/header/common.js +44 -24
  374. package/development/header/header/header.d.ts +4 -4
  375. package/development/header/header/header.d.ts.map +1 -1
  376. package/development/header/header-button/header-button.d.ts.map +1 -1
  377. package/development/header/header-button.js +19 -18
  378. package/development/header/header-link/header-link.d.ts.map +1 -1
  379. package/development/header/header-link.js +19 -16
  380. package/development/header/header.js +198 -140
  381. package/development/icon/icon-base.d.ts +3 -4
  382. package/development/icon/icon-base.d.ts.map +1 -1
  383. package/development/icon/icon-name-mixin.d.ts +1 -1
  384. package/development/icon/icon-name-mixin.d.ts.map +1 -1
  385. package/development/icon/icon.d.ts +2 -2
  386. package/development/icon/icon.d.ts.map +1 -1
  387. package/development/icon.js +258 -157
  388. package/development/image/image.d.ts +17 -17
  389. package/development/image/image.d.ts.map +1 -1
  390. package/development/image.js +584 -216
  391. package/development/journey-header/journey-header.d.ts +5 -5
  392. package/development/journey-header/journey-header.d.ts.map +1 -1
  393. package/development/journey-header.js +115 -43
  394. package/development/lead-container/lead-container.d.ts.map +1 -1
  395. package/development/lead-container.js +22 -21
  396. package/development/link/block-link/block-link.d.ts.map +1 -1
  397. package/development/link/block-link-button/block-link-button.d.ts.map +1 -1
  398. package/development/link/block-link-button.js +19 -18
  399. package/development/link/block-link-static/block-link-static.d.ts.map +1 -1
  400. package/development/link/block-link-static.js +19 -18
  401. package/development/link/block-link.js +19 -18
  402. package/development/link/common/block-link-common.d.ts +4 -3
  403. package/development/link/common/block-link-common.d.ts.map +1 -1
  404. package/development/link/common/link-common.d.ts +1 -1
  405. package/development/link/common/link-common.d.ts.map +1 -1
  406. package/development/link/common.js +81 -51
  407. package/development/link/link/link.d.ts.map +1 -1
  408. package/development/link/link-button/link-button.d.ts.map +1 -1
  409. package/development/link/link-button.js +19 -18
  410. package/development/link/link-static/link-static.d.ts.map +1 -1
  411. package/development/link/link-static.js +19 -18
  412. package/development/link/link.js +19 -18
  413. package/development/link-list/common/link-list-base.d.ts +3 -3
  414. package/development/link-list/common/link-list-base.d.ts.map +1 -1
  415. package/development/link-list/common.js +97 -48
  416. package/development/link-list/link-list/link-list.d.ts +2 -2
  417. package/development/link-list/link-list/link-list.d.ts.map +1 -1
  418. package/development/link-list/link-list-anchor/link-list-anchor.d.ts.map +1 -1
  419. package/development/link-list/link-list-anchor.js +18 -17
  420. package/development/link-list/link-list.js +60 -28
  421. package/development/loading-indicator/loading-indicator.d.ts +3 -3
  422. package/development/loading-indicator/loading-indicator.d.ts.map +1 -1
  423. package/development/loading-indicator.js +82 -40
  424. package/development/logo/logo.d.ts +2 -2
  425. package/development/logo/logo.d.ts.map +1 -1
  426. package/development/logo.js +64 -32
  427. package/development/map-container/map-container.d.ts +2 -2
  428. package/development/map-container/map-container.d.ts.map +1 -1
  429. package/development/map-container.js +107 -75
  430. package/development/menu/common/menu-action-common.d.ts +2 -2
  431. package/development/menu/common/menu-action-common.d.ts.map +1 -1
  432. package/development/menu/common.js +41 -20
  433. package/development/menu/menu/menu.d.ts +1 -1
  434. package/development/menu/menu/menu.d.ts.map +1 -1
  435. package/development/menu/menu-button/menu-button.d.ts.map +1 -1
  436. package/development/menu/menu-button.js +19 -18
  437. package/development/menu/menu-link/menu-link.d.ts.map +1 -1
  438. package/development/menu/menu-link.js +19 -18
  439. package/development/menu/menu.js +261 -241
  440. package/development/message/message.d.ts +2 -2
  441. package/development/message/message.d.ts.map +1 -1
  442. package/development/message.js +65 -32
  443. package/development/navigation/common/navigation-action-common.d.ts +1 -1
  444. package/development/navigation/common/navigation-action-common.d.ts.map +1 -1
  445. package/development/navigation/common.js +63 -52
  446. package/development/navigation/navigation/navigation.d.ts +2 -2
  447. package/development/navigation/navigation/navigation.d.ts.map +1 -1
  448. package/development/navigation/navigation-button/navigation-button.d.ts.map +1 -1
  449. package/development/navigation/navigation-button.js +19 -18
  450. package/development/navigation/navigation-link/navigation-link.d.ts.map +1 -1
  451. package/development/navigation/navigation-link.js +19 -18
  452. package/development/navigation/navigation-list/navigation-list.d.ts +1 -1
  453. package/development/navigation/navigation-list/navigation-list.d.ts.map +1 -1
  454. package/development/navigation/navigation-list.js +64 -41
  455. package/development/navigation/navigation-marker/navigation-marker.d.ts +1 -1
  456. package/development/navigation/navigation-marker/navigation-marker.d.ts.map +1 -1
  457. package/development/navigation/navigation-marker.js +108 -91
  458. package/development/navigation/navigation-section/navigation-section.d.ts +3 -3
  459. package/development/navigation/navigation-section/navigation-section.d.ts.map +1 -1
  460. package/development/navigation/navigation-section.js +282 -236
  461. package/development/navigation/navigation.js +278 -254
  462. package/development/notification/notification.d.ts +6 -6
  463. package/development/notification/notification.d.ts.map +1 -1
  464. package/development/notification.js +212 -146
  465. package/development/option/optgroup/optgroup-base-element.d.ts +3 -3
  466. package/development/option/optgroup/optgroup-base-element.d.ts.map +1 -1
  467. package/development/option/optgroup/optgroup.d.ts.map +1 -1
  468. package/development/option/optgroup.js +187 -142
  469. package/development/option/option/option-base-element.d.ts +7 -7
  470. package/development/option/option/option-base-element.d.ts.map +1 -1
  471. package/development/option/option/option.d.ts.map +1 -1
  472. package/development/option/option.js +392 -296
  473. package/development/overlay/overlay-base-element.d.ts +1 -1
  474. package/development/overlay/overlay-base-element.d.ts.map +1 -1
  475. package/development/overlay/overlay.d.ts +4 -4
  476. package/development/overlay/overlay.d.ts.map +1 -1
  477. package/development/overlay.js +260 -207
  478. package/development/paginator/common/paginator-common.d.ts +26 -0
  479. package/development/paginator/common/paginator-common.d.ts.map +1 -0
  480. package/development/paginator/common.d.ts +2 -0
  481. package/development/paginator/common.d.ts.map +1 -0
  482. package/development/paginator/common.js +189 -0
  483. package/development/paginator/compact-paginator/compact-paginator.d.ts +20 -0
  484. package/development/paginator/compact-paginator/compact-paginator.d.ts.map +1 -0
  485. package/development/paginator/compact-paginator.d.ts +2 -0
  486. package/development/paginator/compact-paginator.d.ts.map +1 -0
  487. package/development/paginator/compact-paginator.js +96 -0
  488. package/development/paginator/paginator/paginator.d.ts +51 -0
  489. package/development/paginator/paginator/paginator.d.ts.map +1 -0
  490. package/development/paginator/paginator.d.ts +1 -90
  491. package/development/paginator/paginator.d.ts.map +1 -1
  492. package/development/paginator/paginator.js +449 -0
  493. package/development/paginator.d.ts +2 -0
  494. package/development/paginator.d.ts.map +1 -1
  495. package/development/paginator.js +4 -541
  496. package/development/popover/popover/popover.d.ts +6 -7
  497. package/development/popover/popover/popover.d.ts.map +1 -1
  498. package/development/popover/popover-trigger/popover-trigger.d.ts.map +1 -1
  499. package/development/popover/popover-trigger.js +28 -29
  500. package/development/popover/popover.js +358 -303
  501. package/development/radio-button/common/radio-button-common.d.ts +1 -1
  502. package/development/radio-button/common/radio-button-common.d.ts.map +1 -1
  503. package/development/radio-button/common.js +170 -127
  504. package/development/radio-button/radio-button/radio-button.d.ts +2 -6
  505. package/development/radio-button/radio-button/radio-button.d.ts.map +1 -1
  506. package/development/radio-button/radio-button-group/radio-button-group.d.ts +6 -6
  507. package/development/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  508. package/development/radio-button/radio-button-group.js +269 -199
  509. package/development/radio-button/radio-button-panel/radio-button-panel.d.ts +2 -6
  510. package/development/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -1
  511. package/development/radio-button/radio-button-panel.js +60 -48
  512. package/development/radio-button/radio-button.js +54 -40
  513. package/development/screen-reader-only/screen-reader-only.d.ts.map +1 -1
  514. package/development/screen-reader-only.js +22 -21
  515. package/development/select/select.d.ts +5 -4
  516. package/development/select/select.d.ts.map +1 -1
  517. package/development/select.js +555 -555
  518. package/development/selection-expansion-panel/selection-expansion-panel.d.ts +3 -3
  519. package/development/selection-expansion-panel/selection-expansion-panel.d.ts.map +1 -1
  520. package/development/selection-expansion-panel.js +223 -193
  521. package/development/signet/signet.d.ts +2 -2
  522. package/development/signet/signet.d.ts.map +1 -1
  523. package/development/signet.js +65 -33
  524. package/development/skiplink-list/skiplink-list.d.ts +2 -2
  525. package/development/skiplink-list/skiplink-list.d.ts.map +1 -1
  526. package/development/skiplink-list.js +74 -41
  527. package/development/slider/slider.d.ts +5 -4
  528. package/development/slider/slider.d.ts.map +1 -1
  529. package/development/slider.js +260 -184
  530. package/development/status/status.d.ts +3 -3
  531. package/development/status/status.d.ts.map +1 -1
  532. package/development/status.js +96 -51
  533. package/development/stepper/step/step.d.ts.map +1 -1
  534. package/development/stepper/step-label/step-label.d.ts.map +1 -1
  535. package/development/stepper/step-label.js +86 -90
  536. package/development/stepper/step.js +122 -126
  537. package/development/stepper/stepper/stepper.d.ts +3 -3
  538. package/development/stepper/stepper/stepper.d.ts.map +1 -1
  539. package/development/stepper/stepper.js +291 -241
  540. package/development/table/table-wrapper/table-wrapper.d.ts.map +1 -1
  541. package/development/table/table-wrapper.js +37 -39
  542. package/development/tabs/tab/tab.d.ts.map +1 -1
  543. package/development/tabs/tab-group/tab-group.d.ts +2 -2
  544. package/development/tabs/tab-group/tab-group.d.ts.map +1 -1
  545. package/development/tabs/tab-group.js +296 -279
  546. package/development/tabs/tab-label/tab-label.d.ts +3 -3
  547. package/development/tabs/tab-label/tab-label.d.ts.map +1 -1
  548. package/development/tabs/tab-label.js +83 -37
  549. package/development/tabs/tab.js +40 -39
  550. package/development/tag/tag/tag.d.ts +3 -5
  551. package/development/tag/tag/tag.d.ts.map +1 -1
  552. package/development/tag/tag-group/tag-group.d.ts +3 -3
  553. package/development/tag/tag-group/tag-group.d.ts.map +1 -1
  554. package/development/tag/tag-group.js +143 -88
  555. package/development/tag/tag.js +126 -89
  556. package/development/teaser/teaser.d.ts +4 -4
  557. package/development/teaser/teaser.d.ts.map +1 -1
  558. package/development/teaser-hero/teaser-hero.d.ts +3 -3
  559. package/development/teaser-hero/teaser-hero.d.ts.map +1 -1
  560. package/development/teaser-hero.js +83 -36
  561. package/development/teaser-product/common/teaser-product-common.d.ts +1 -1
  562. package/development/teaser-product/common/teaser-product-common.d.ts.map +1 -1
  563. package/development/teaser-product/common.js +51 -26
  564. package/development/teaser-product/teaser-product/teaser-product.d.ts.map +1 -1
  565. package/development/teaser-product/teaser-product-static/teaser-product-static.d.ts.map +1 -1
  566. package/development/teaser-product/teaser-product-static.js +18 -19
  567. package/development/teaser-product/teaser-product.js +18 -19
  568. package/development/teaser.js +94 -40
  569. package/development/time-input/time-input.d.ts +1 -1
  570. package/development/time-input/time-input.d.ts.map +1 -1
  571. package/development/time-input.js +225 -219
  572. package/development/timetable-occupancy/timetable-occupancy.d.ts +2 -2
  573. package/development/timetable-occupancy/timetable-occupancy.d.ts.map +1 -1
  574. package/development/timetable-occupancy-icon/timetable-occupancy-icon.d.ts +1 -1
  575. package/development/timetable-occupancy-icon/timetable-occupancy-icon.d.ts.map +1 -1
  576. package/development/timetable-occupancy-icon.js +78 -57
  577. package/development/timetable-occupancy.js +67 -35
  578. package/development/title/title-base.d.ts +3 -3
  579. package/development/title/title-base.d.ts.map +1 -1
  580. package/development/title/title.d.ts.map +1 -1
  581. package/development/title.js +106 -58
  582. package/development/toast/toast.d.ts +4 -4
  583. package/development/toast/toast.d.ts.map +1 -1
  584. package/development/toast.js +204 -146
  585. package/development/toggle/toggle/toggle.d.ts +3 -5
  586. package/development/toggle/toggle/toggle.d.ts.map +1 -1
  587. package/development/toggle/toggle-option/toggle-option.d.ts +2 -2
  588. package/development/toggle/toggle-option/toggle-option.d.ts.map +1 -1
  589. package/development/toggle/toggle-option.js +127 -93
  590. package/development/toggle/toggle.js +200 -163
  591. package/development/toggle-check/toggle-check.d.ts +4 -3
  592. package/development/toggle-check/toggle-check.d.ts.map +1 -1
  593. package/development/toggle-check.js +87 -49
  594. package/development/train/train/train.d.ts +5 -5
  595. package/development/train/train/train.d.ts.map +1 -1
  596. package/development/train/train-blocked-passage/train-blocked-passage.d.ts.map +1 -1
  597. package/development/train/train-blocked-passage.js +22 -21
  598. package/development/train/train-formation/train-formation.d.ts +2 -2
  599. package/development/train/train-formation/train-formation.d.ts.map +1 -1
  600. package/development/train/train-formation.js +113 -90
  601. package/development/train/train-wagon/train-wagon.d.ts +7 -9
  602. package/development/train/train-wagon/train-wagon.d.ts.map +1 -1
  603. package/development/train/train-wagon.js +166 -87
  604. package/development/train/train.js +142 -75
  605. package/development/visual-checkbox/visual-checkbox.d.ts +3 -3
  606. package/development/visual-checkbox/visual-checkbox.d.ts.map +1 -1
  607. package/development/visual-checkbox.js +79 -36
  608. package/dialog/dialog/dialog.d.ts +1 -1
  609. package/dialog/dialog/dialog.d.ts.map +1 -1
  610. package/dialog/dialog-actions/dialog-actions.d.ts.map +1 -1
  611. package/dialog/dialog-actions.js +18 -19
  612. package/dialog/dialog-content/dialog-content.d.ts.map +1 -1
  613. package/dialog/dialog-content.js +17 -18
  614. package/dialog/dialog-title/dialog-title.d.ts +3 -3
  615. package/dialog/dialog-title/dialog-title.d.ts.map +1 -1
  616. package/dialog/dialog-title.js +98 -66
  617. package/dialog/dialog.js +120 -114
  618. package/divider/divider.d.ts +1 -1
  619. package/divider/divider.d.ts.map +1 -1
  620. package/divider.js +41 -30
  621. package/expansion-panel/expansion-panel/expansion-panel.d.ts +4 -4
  622. package/expansion-panel/expansion-panel/expansion-panel.d.ts.map +1 -1
  623. package/expansion-panel/expansion-panel-content/expansion-panel-content.d.ts.map +1 -1
  624. package/expansion-panel/expansion-panel-content.js +20 -22
  625. package/expansion-panel/expansion-panel-header/expansion-panel-header.d.ts +1 -1
  626. package/expansion-panel/expansion-panel-header/expansion-panel-header.d.ts.map +1 -1
  627. package/expansion-panel/expansion-panel-header.js +53 -61
  628. package/expansion-panel/expansion-panel.js +145 -130
  629. package/file-selector/file-selector.d.ts +8 -7
  630. package/file-selector/file-selector.d.ts.map +1 -1
  631. package/file-selector.js +224 -174
  632. package/flip-card/flip-card/flip-card.d.ts +2 -2
  633. package/flip-card/flip-card/flip-card.d.ts.map +1 -1
  634. package/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -1
  635. package/flip-card/flip-card-details.js +36 -38
  636. package/flip-card/flip-card-summary/flip-card-summary.d.ts +1 -1
  637. package/flip-card/flip-card-summary/flip-card-summary.d.ts.map +1 -1
  638. package/flip-card/flip-card-summary.js +42 -31
  639. package/flip-card/flip-card.js +88 -69
  640. package/footer/footer.d.ts +4 -4
  641. package/footer/footer.d.ts.map +1 -1
  642. package/footer.js +78 -37
  643. package/form-error/form-error.d.ts.map +1 -1
  644. package/form-error.js +24 -25
  645. package/form-field/form-field/form-field.d.ts +10 -10
  646. package/form-field/form-field/form-field.d.ts.map +1 -1
  647. package/form-field/form-field-clear/form-field-clear.d.ts.map +1 -1
  648. package/form-field/form-field-clear.js +39 -41
  649. package/form-field/form-field.js +295 -239
  650. package/header/common/header-action-common.d.ts +2 -2
  651. package/header/common/header-action-common.d.ts.map +1 -1
  652. package/header/common.js +36 -21
  653. package/header/header/header.d.ts +4 -4
  654. package/header/header/header.d.ts.map +1 -1
  655. package/header/header-button/header-button.d.ts.map +1 -1
  656. package/header/header-button.js +14 -16
  657. package/header/header-link/header-link.d.ts.map +1 -1
  658. package/header/header-link.js +14 -14
  659. package/header/header.js +138 -109
  660. package/icon/icon-base.d.ts +3 -4
  661. package/icon/icon-base.d.ts.map +1 -1
  662. package/icon/icon-name-mixin.d.ts +1 -1
  663. package/icon/icon-name-mixin.d.ts.map +1 -1
  664. package/icon/icon.d.ts +2 -2
  665. package/icon/icon.d.ts.map +1 -1
  666. package/icon.js +230 -165
  667. package/image/image.d.ts +17 -17
  668. package/image/image.d.ts.map +1 -1
  669. package/image.js +465 -195
  670. package/index.d.ts +3 -1
  671. package/index.js +3 -1
  672. package/journey-header/journey-header.d.ts +5 -5
  673. package/journey-header/journey-header.d.ts.map +1 -1
  674. package/journey-header.js +89 -49
  675. package/lead-container/lead-container.d.ts.map +1 -1
  676. package/lead-container.js +17 -18
  677. package/link/block-link/block-link.d.ts.map +1 -1
  678. package/link/block-link-button/block-link-button.d.ts.map +1 -1
  679. package/link/block-link-button.js +15 -17
  680. package/link/block-link-static/block-link-static.d.ts.map +1 -1
  681. package/link/block-link-static.js +14 -16
  682. package/link/block-link.js +15 -17
  683. package/link/common/block-link-common.d.ts +4 -3
  684. package/link/common/block-link-common.d.ts.map +1 -1
  685. package/link/common/link-common.d.ts +1 -1
  686. package/link/common/link-common.d.ts.map +1 -1
  687. package/link/common.js +64 -46
  688. package/link/link/link.d.ts.map +1 -1
  689. package/link/link-button/link-button.d.ts.map +1 -1
  690. package/link/link-button.js +15 -17
  691. package/link/link-static/link-static.d.ts.map +1 -1
  692. package/link/link-static.js +15 -17
  693. package/link/link.js +15 -17
  694. package/link-list/common/link-list-base.d.ts +3 -3
  695. package/link-list/common/link-list-base.d.ts.map +1 -1
  696. package/link-list/common.js +72 -44
  697. package/link-list/link-list/link-list.d.ts +2 -2
  698. package/link-list/link-list/link-list.d.ts.map +1 -1
  699. package/link-list/link-list-anchor/link-list-anchor.d.ts.map +1 -1
  700. package/link-list/link-list-anchor.js +15 -16
  701. package/link-list/link-list.js +43 -24
  702. package/loading-indicator/loading-indicator.d.ts +3 -3
  703. package/loading-indicator/loading-indicator.d.ts.map +1 -1
  704. package/loading-indicator.js +61 -36
  705. package/logo/logo.d.ts +2 -2
  706. package/logo/logo.d.ts.map +1 -1
  707. package/logo.js +47 -27
  708. package/map-container/map-container.d.ts +2 -2
  709. package/map-container/map-container.d.ts.map +1 -1
  710. package/map-container.js +84 -65
  711. package/menu/common/menu-action-common.d.ts +2 -2
  712. package/menu/common/menu-action-common.d.ts.map +1 -1
  713. package/menu/common.js +37 -22
  714. package/menu/menu/menu.d.ts +1 -1
  715. package/menu/menu/menu.d.ts.map +1 -1
  716. package/menu/menu-button/menu-button.d.ts.map +1 -1
  717. package/menu/menu-button.js +14 -16
  718. package/menu/menu-link/menu-link.d.ts.map +1 -1
  719. package/menu/menu-link.js +15 -17
  720. package/menu/menu.js +175 -170
  721. package/message/message.d.ts +2 -2
  722. package/message/message.d.ts.map +1 -1
  723. package/message.js +47 -27
  724. package/navigation/common/navigation-action-common.d.ts +1 -1
  725. package/navigation/common/navigation-action-common.d.ts.map +1 -1
  726. package/navigation/common.js +38 -33
  727. package/navigation/navigation/navigation.d.ts +2 -2
  728. package/navigation/navigation/navigation.d.ts.map +1 -1
  729. package/navigation/navigation-button/navigation-button.d.ts.map +1 -1
  730. package/navigation/navigation-button.js +14 -16
  731. package/navigation/navigation-link/navigation-link.d.ts.map +1 -1
  732. package/navigation/navigation-link.js +14 -16
  733. package/navigation/navigation-list/navigation-list.d.ts +1 -1
  734. package/navigation/navigation-list/navigation-list.d.ts.map +1 -1
  735. package/navigation/navigation-list.js +48 -35
  736. package/navigation/navigation-marker/navigation-marker.d.ts +1 -1
  737. package/navigation/navigation-marker/navigation-marker.d.ts.map +1 -1
  738. package/navigation/navigation-marker.js +77 -69
  739. package/navigation/navigation-section/navigation-section.d.ts +3 -3
  740. package/navigation/navigation-section/navigation-section.d.ts.map +1 -1
  741. package/navigation/navigation-section.js +192 -171
  742. package/navigation/navigation.js +185 -181
  743. package/notification/notification.d.ts +6 -6
  744. package/notification/notification.d.ts.map +1 -1
  745. package/notification.js +147 -116
  746. package/option/optgroup/optgroup-base-element.d.ts +3 -3
  747. package/option/optgroup/optgroup-base-element.d.ts.map +1 -1
  748. package/option/optgroup/optgroup.d.ts.map +1 -1
  749. package/option/optgroup.js +131 -112
  750. package/option/option/option-base-element.d.ts +7 -7
  751. package/option/option/option-base-element.d.ts.map +1 -1
  752. package/option/option/option.d.ts.map +1 -1
  753. package/option/option.js +295 -252
  754. package/overlay/overlay-base-element.d.ts +1 -1
  755. package/overlay/overlay-base-element.d.ts.map +1 -1
  756. package/overlay/overlay.d.ts +4 -4
  757. package/overlay/overlay.d.ts.map +1 -1
  758. package/overlay.js +194 -165
  759. package/package.json +18 -2
  760. package/paginator/common/paginator-common.d.ts +26 -0
  761. package/paginator/common/paginator-common.d.ts.map +1 -0
  762. package/paginator/common.d.ts +2 -0
  763. package/paginator/common.d.ts.map +1 -0
  764. package/paginator/common.js +145 -0
  765. package/paginator/compact-paginator/compact-paginator.d.ts +20 -0
  766. package/paginator/compact-paginator/compact-paginator.d.ts.map +1 -0
  767. package/paginator/compact-paginator.d.ts +2 -0
  768. package/paginator/compact-paginator.d.ts.map +1 -0
  769. package/paginator/compact-paginator.js +40 -0
  770. package/paginator/paginator/paginator.d.ts +51 -0
  771. package/paginator/paginator/paginator.d.ts.map +1 -0
  772. package/paginator/paginator.d.ts +1 -90
  773. package/paginator/paginator.d.ts.map +1 -1
  774. package/paginator/paginator.js +171 -0
  775. package/paginator.d.ts +2 -0
  776. package/paginator.d.ts.map +1 -1
  777. package/paginator.js +3 -265
  778. package/popover/popover/popover.d.ts +6 -7
  779. package/popover/popover/popover.d.ts.map +1 -1
  780. package/popover/popover-trigger/popover-trigger.d.ts.map +1 -1
  781. package/popover/popover-trigger.js +26 -29
  782. package/popover/popover.js +230 -208
  783. package/radio-button/common/radio-button-common.d.ts +1 -1
  784. package/radio-button/common/radio-button-common.d.ts.map +1 -1
  785. package/radio-button/common.js +67 -43
  786. package/radio-button/radio-button/radio-button.d.ts +2 -6
  787. package/radio-button/radio-button/radio-button.d.ts.map +1 -1
  788. package/radio-button/radio-button-group/radio-button-group.d.ts +6 -6
  789. package/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  790. package/radio-button/radio-button-group.js +192 -156
  791. package/radio-button/radio-button-panel/radio-button-panel.d.ts +2 -6
  792. package/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -1
  793. package/radio-button/radio-button-panel.js +49 -45
  794. package/radio-button/radio-button.js +43 -37
  795. package/screen-reader-only/screen-reader-only.d.ts.map +1 -1
  796. package/screen-reader-only.js +17 -18
  797. package/select/select.d.ts +5 -4
  798. package/select/select.d.ts.map +1 -1
  799. package/select.js +377 -401
  800. package/selection-expansion-panel/selection-expansion-panel.d.ts +3 -3
  801. package/selection-expansion-panel/selection-expansion-panel.d.ts.map +1 -1
  802. package/selection-expansion-panel.js +157 -148
  803. package/signet/signet.d.ts +2 -2
  804. package/signet/signet.d.ts.map +1 -1
  805. package/signet.js +48 -28
  806. package/skiplink-list/skiplink-list.d.ts +2 -2
  807. package/skiplink-list/skiplink-list.d.ts.map +1 -1
  808. package/skiplink-list.js +54 -36
  809. package/slider/slider.d.ts +5 -4
  810. package/slider/slider.d.ts.map +1 -1
  811. package/slider.js +197 -158
  812. package/status/status.d.ts +3 -3
  813. package/status/status.d.ts.map +1 -1
  814. package/status.js +71 -46
  815. package/stepper/step/step.d.ts.map +1 -1
  816. package/stepper/step-label/step-label.d.ts.map +1 -1
  817. package/stepper/step-label.js +69 -75
  818. package/stepper/step.js +99 -104
  819. package/stepper/stepper/stepper.d.ts +3 -3
  820. package/stepper/stepper/stepper.d.ts.map +1 -1
  821. package/stepper/stepper.js +208 -188
  822. package/table/table-wrapper/table-wrapper.d.ts.map +1 -1
  823. package/table/table-wrapper.js +32 -36
  824. package/tabs/tab/tab.d.ts.map +1 -1
  825. package/tabs/tab-group/tab-group.d.ts +2 -2
  826. package/tabs/tab-group/tab-group.d.ts.map +1 -1
  827. package/tabs/tab-group.js +200 -193
  828. package/tabs/tab-label/tab-label.d.ts +3 -3
  829. package/tabs/tab-label/tab-label.d.ts.map +1 -1
  830. package/tabs/tab-label.js +65 -37
  831. package/tabs/tab.js +34 -35
  832. package/tag/tag/tag.d.ts +3 -5
  833. package/tag/tag/tag.d.ts.map +1 -1
  834. package/tag/tag-group/tag-group.d.ts +3 -3
  835. package/tag/tag-group/tag-group.d.ts.map +1 -1
  836. package/tag/tag-group.js +107 -75
  837. package/tag/tag.js +92 -73
  838. package/teaser/teaser.d.ts +4 -4
  839. package/teaser/teaser.d.ts.map +1 -1
  840. package/teaser-hero/teaser-hero.d.ts +3 -3
  841. package/teaser-hero/teaser-hero.d.ts.map +1 -1
  842. package/teaser-hero.js +66 -38
  843. package/teaser-product/common/teaser-product-common.d.ts +1 -1
  844. package/teaser-product/common/teaser-product-common.d.ts.map +1 -1
  845. package/teaser-product/common.js +36 -21
  846. package/teaser-product/teaser-product/teaser-product.d.ts.map +1 -1
  847. package/teaser-product/teaser-product-static/teaser-product-static.d.ts.map +1 -1
  848. package/teaser-product/teaser-product-static.js +14 -17
  849. package/teaser-product/teaser-product.js +14 -17
  850. package/teaser.js +69 -37
  851. package/time-input/time-input.d.ts +1 -1
  852. package/time-input/time-input.d.ts.map +1 -1
  853. package/time-input.js +160 -166
  854. package/timetable-occupancy/timetable-occupancy.d.ts +2 -2
  855. package/timetable-occupancy/timetable-occupancy.d.ts.map +1 -1
  856. package/timetable-occupancy-icon/timetable-occupancy-icon.d.ts +1 -1
  857. package/timetable-occupancy-icon/timetable-occupancy-icon.d.ts.map +1 -1
  858. package/timetable-occupancy-icon.js +60 -48
  859. package/timetable-occupancy.js +55 -38
  860. package/title/title-base.d.ts +3 -3
  861. package/title/title-base.d.ts.map +1 -1
  862. package/title/title.d.ts.map +1 -1
  863. package/title.js +81 -53
  864. package/toast/toast.d.ts +4 -4
  865. package/toast/toast.d.ts.map +1 -1
  866. package/toast.js +156 -123
  867. package/toggle/toggle/toggle.d.ts +3 -5
  868. package/toggle/toggle/toggle.d.ts.map +1 -1
  869. package/toggle/toggle-option/toggle-option.d.ts +2 -2
  870. package/toggle/toggle-option/toggle-option.d.ts.map +1 -1
  871. package/toggle/toggle-option.js +89 -72
  872. package/toggle/toggle.js +139 -122
  873. package/toggle-check/toggle-check.d.ts +4 -3
  874. package/toggle-check/toggle-check.d.ts.map +1 -1
  875. package/toggle-check.js +63 -41
  876. package/train/train/train.d.ts +5 -5
  877. package/train/train/train.d.ts.map +1 -1
  878. package/train/train-blocked-passage/train-blocked-passage.d.ts.map +1 -1
  879. package/train/train-blocked-passage.js +17 -18
  880. package/train/train-formation/train-formation.d.ts +2 -2
  881. package/train/train-formation/train-formation.d.ts.map +1 -1
  882. package/train/train-formation.js +96 -87
  883. package/train/train-wagon/train-wagon.d.ts +7 -9
  884. package/train/train-wagon/train-wagon.d.ts.map +1 -1
  885. package/train/train-wagon.js +150 -110
  886. package/train/train.js +108 -71
  887. package/visual-checkbox/visual-checkbox.d.ts +3 -3
  888. package/visual-checkbox/visual-checkbox.d.ts.map +1 -1
  889. package/visual-checkbox.js +59 -32
package/calendar.js CHANGED
@@ -1,494 +1,491 @@
1
- import { css as $, LitElement as M, isServer as x, html as o, nothing as h } from "lit";
2
- import { property as _, state as f, customElement as V } from "lit/decorators.js";
3
- import { classMap as p } from "lit/directives/class-map.js";
4
- import { sbbInputModalityDetector as k, isArrowKeyOrPageKeysPressed as F } from "./core/a11y.js";
5
- import { readConfig as z } from "./core/config.js";
6
- import { SbbConnectedAbortController as R, SbbLanguageController as C } from "./core/controllers.js";
7
- import { defaultDateAdapter as T, YEARS_PER_PAGE as d, DAYS_PER_ROW as y, MONTHS_PER_ROW as g, YEARS_PER_ROW as v } from "./core/datetime.js";
8
- import { isBreakpoint as A } from "./core/dom.js";
9
- import { EventEmitter as N } from "./core/eventing.js";
10
- import { i18nPreviousMonth as I, i18nNextMonth as O, i18nYearMonthSelection as S, i18nPreviousYear as W, i18nNextYear as E, i18nCalendarDateSelection as D, i18nPreviousYearRange as L, i18nNextYearRange as P } from "./core/i18n.js";
11
- import { SbbHydrationMixin as B } from "./core/mixins.js";
1
+ var he = (o) => {
2
+ throw TypeError(o);
3
+ };
4
+ var _e = (o, h, m) => h.has(o) || he("Cannot " + m);
5
+ var v = (o, h, m) => (_e(o, h, "read from private field"), m ? m.call(o) : h.get(o)), w = (o, h, m) => h.has(o) ? he("Cannot add the same private member more than once") : h instanceof WeakSet ? h.add(o) : h.set(o, m), u = (o, h, m, p) => (_e(o, h, "write to private field"), p ? p.call(o, m) : h.set(o, m), m);
6
+ import { __esDecorate as f, __runInitializers as c } from "tslib";
7
+ import { css as fe, LitElement as ge, isServer as ue, html as n, nothing as g } from "lit";
8
+ import { customElement as pe, property as A, state as F } from "lit/decorators.js";
9
+ import { classMap as R } from "lit/directives/class-map.js";
10
+ import { sbbInputModalityDetector as ve, isArrowKeyOrPageKeysPressed as we } from "./core/a11y.js";
11
+ import { readConfig as ye } from "./core/config.js";
12
+ import { SbbConnectedAbortController as Ae, SbbLanguageController as xe } from "./core/controllers.js";
13
+ import { defaultDateAdapter as De, YEARS_PER_PAGE as b, DAYS_PER_ROW as O, MONTHS_PER_ROW as I, YEARS_PER_ROW as C } from "./core/datetime.js";
14
+ import { forceType as $e } from "./core/decorators.js";
15
+ import { isBreakpoint as Ye } from "./core/dom.js";
16
+ import { EventEmitter as Me } from "./core/eventing.js";
17
+ import { i18nPreviousMonth as ke, i18nNextMonth as Ve, i18nYearMonthSelection as ze, i18nPreviousYear as Fe, i18nNextYear as Re, i18nCalendarDateSelection as me, i18nPreviousYearRange as Ie, i18nNextYearRange as Ce } from "./core/i18n.js";
18
+ import { SbbHydrationMixin as Se } from "./core/mixins.js";
12
19
  import "./button/secondary-button.js";
13
20
  import "./icon.js";
14
21
  import "./screen-reader-only.js";
15
- const q = $`*,:before,:after{box-sizing:border-box}: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-cell-disabled-color: var(--sbb-color-granite);--sbb-calendar-header-color: var(--sbb-color-granite);--sbb-calendar-cell-background-color: transparent;--sbb-calendar-cell-padding: .125rem;--sbb-calendar-cell-color: var(--sbb-color-charcoal);--sbb-calendar-cell-selected-color: var(--sbb-color-white);--sbb-calendar-cell-selected-background-color: var(--sbb-color-charcoal);--sbb-calendar-cell-disabled-height: .09375rem;--sbb-calendar-cell-disabled-width: 1.59375rem;--sbb-calendar-cell-transition-duration: var( --sbb-disable-animation-zero-time, 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-charcoal);--sbb-calendar-control-view-change-background: var(--sbb-color-white)}@media (min-width: 22.5rem){:host{--sbb-calendar-cell-size: 2.75rem;--sbb-calendar-wide-cell-size: 4.8125rem;--sbb-calendar-control-view-change-height: 3rem}}.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{-webkit-appearance:none;-moz-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-font-size-text-s);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-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: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-color: var(--sbb-calendar-cell-disabled-color);cursor:unset}.sbb-calendar__controls-change-date:focus-visible:not([data-focus-origin=mouse],[data-focus-origin=touch]){outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) 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-color-milk)}.sbb-calendar__table-month-view,.sbb-calendar__table-year-view{--sbb-calendar-table-column-spaces: 6}.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([data-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))}.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([data-wide])) .sbb-calendar__table{min-width:100%}.sbb-calendar__table-header{--sbb-text-font-size: var(--sbb-font-size-text-xs);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size);color:var(--sbb-calendar-header-color);width:var(--sbb-calendar-cell-size);padding:0;padding-block-end:var(--sbb-spacing-fixed-4x);text-align:center}.sbb-calendar__table-data{position:relative;padding:0;text-align:center}.sbb-calendar__cell{-webkit-appearance:none;-moz-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-font-size-text-s);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size);height:var(--sbb-calendar-cell-size);color:var(--sbb-calendar-cell-color);cursor:pointer;position:relative;z-index:0}.sbb-calendar__cell:before{content:"";position:absolute;inset:var(--sbb-calendar-cell-padding);background-color:var(--sbb-calendar-cell-background-color);border-radius:50%;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__cell:not(.sbb-calendar__selected,:active,:disabled):hover{--sbb-calendar-cell-background-color: var(--sbb-color-milk);padding-block-end:var(--sbb-calendar-hover-shift)}}@media (any-hover: hover) and (forced-colors: active){.sbb-calendar__cell:not(.sbb-calendar__selected,:active,:disabled):hover:before{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) solid var(--sbb-focus-outline-width)}}.sbb-calendar__cell:disabled{--sbb-calendar-cell-color: var(--sbb-calendar-cell-disabled-color);cursor:unset}.sbb-calendar__cell:focus-visible:before{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) solid var(--sbb-focus-outline-width)}.sbb-calendar__cell:not(.sbb-calendar__selected,:disabled):active{--sbb-calendar-cell-background-color: var(--sbb-color-cloud)}@media (forced-colors: active){.sbb-calendar__cell:not(.sbb-calendar__selected,:disabled):active:before{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) solid var(--sbb-focus-outline-width)}}.sbb-calendar__day{border-radius:50%;width:var(--sbb-calendar-cell-size)}.sbb-calendar__day:before{border-radius:50%}.sbb-calendar__pill{width:var(--sbb-calendar-wide-cell-size);border-radius:var(--sbb-border-radius-infinity)}.sbb-calendar__pill:before{border-radius:var(--sbb-border-radius-infinity)}.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-font-size-text-s);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size);font-weight:700}.sbb-calendar__selected{--sbb-calendar-cell-color: var(--sbb-calendar-cell-selected-color);--sbb-calendar-cell-background-color: var(--sbb-calendar-cell-selected-background-color)}@media (forced-colors: active){.sbb-calendar__selected{--sbb-calendar-cell-background-color: ButtonText !important}}@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))}}`;
16
- var K = Object.defineProperty, H = Object.getOwnPropertyDescriptor, b = (e, t, a, r) => {
17
- for (var s = r > 1 ? void 0 : r ? H(t, a) : t, i = e.length - 1, n; i >= 0; i--)
18
- (n = e[i]) && (s = (r ? n(t, a, s) : n(s)) || s);
19
- return r && s && K(t, a, s), s;
20
- };
21
- let l = class extends B(M) {
22
- constructor() {
23
- var e;
24
- super(), this.wide = !1, this.view = "day", this._now = null, this._dateAdapter = ((e = z().datetime) == null ? void 0 : e.dateAdapter) ?? T, this._dateSelected = new N(
25
- this,
26
- l.events.dateSelected
27
- ), this._activeDate = this.now, this._calendarView = "day", this._nextCalendarView = "day", this._weeks = [], this._monthNames = this._dateAdapter.getMonthNames("long"), this._resetFocus = !1, this._initialized = !1, this._abort = new R(this), this._language = new C(this).withHandler(() => {
28
- this._monthNames = this._dateAdapter.getMonthNames("long"), this._createMonthRows();
29
- }), this._createMonthRows(), this._setWeekdays();
30
- }
31
- set min(e) {
32
- this._min = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(e));
33
- }
34
- get min() {
35
- return this._min ?? null;
36
- }
37
- set max(e) {
38
- this._max = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(e));
39
- }
40
- get max() {
41
- return this._max ?? null;
42
- }
43
- set now(e) {
44
- this._now = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(e));
45
- }
46
- get now() {
47
- return this._now ?? this._dateAdapter.today();
48
- }
49
- set selected(e) {
50
- this._selectedDate = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(e)), this._selectedDate && (!this._isDayInRange(this._dateAdapter.toIso8601(this._selectedDate)) || this._dateFilter(this._selectedDate)) ? this._selected = this._dateAdapter.toIso8601(this._selectedDate) : this._selected = void 0;
51
- }
52
- get selected() {
53
- return this._selectedDate ?? null;
54
- }
55
- set _wide(e) {
56
- this.toggleAttribute("data-wide", e);
57
- }
58
- get _wide() {
59
- return this.hasAttribute("data-wide");
60
- }
61
- /** A list of buttons corresponding to days, months or years depending on the view. */
62
- get _cells() {
63
- return Array.from(
64
- this.shadowRoot.querySelectorAll(".sbb-calendar__cell") ?? []
65
- );
66
- }
67
- _dateFilter(e) {
68
- var t;
69
- return ((t = this.dateFilter) == null ? void 0 : t.call(this, e)) ?? !0;
70
- }
71
- /** Resets the active month according to the new state of the calendar. */
72
- resetPosition() {
73
- this._resetCalendarView(), this._init();
74
- }
75
- connectedCallback() {
76
- var e;
77
- super.connectedCallback(), this.resetPosition(), this.focus = () => {
78
- this._resetFocus = !0, this._focusCell();
79
- }, (e = globalThis.window) == null || e.addEventListener("resize", () => this._init(), {
80
- passive: !0,
81
- signal: this._abort.signal
82
- });
83
- }
84
- willUpdate(e) {
85
- super.willUpdate(e), this._initialized && (e.has("wide") && this.resetPosition(), e.has("view") && (this._setChosenYear(), this._chosenMonth = void 0, this._nextCalendarView = this._calendarView = this.view));
86
- }
87
- updated(e) {
88
- super.updated(e), this._setTabIndex(), k.mostRecentModality === "keyboard" && this._focusCell();
89
- }
90
- /** Initializes the component. */
91
- _init(e) {
92
- if (!x) {
93
- if (this.hydrationRequired) {
94
- this.hydrationComplete.then(() => this._init());
95
- return;
22
+ const Te = fe`*,:before,:after{box-sizing:border-box}: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-cell-disabled-color: var(--sbb-color-granite);--sbb-calendar-header-color: var(--sbb-color-granite);--sbb-calendar-cell-background-color: transparent;--sbb-calendar-cell-padding: .125rem;--sbb-calendar-cell-color: var(--sbb-color-charcoal);--sbb-calendar-cell-selected-color: var(--sbb-color-white);--sbb-calendar-cell-selected-background-color: var(--sbb-color-charcoal);--sbb-calendar-cell-disabled-height: .09375rem;--sbb-calendar-cell-disabled-width: 1.59375rem;--sbb-calendar-cell-transition-duration: var( --sbb-disable-animation-zero-time, 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-charcoal);--sbb-calendar-control-view-change-background: var(--sbb-color-white)}@media (min-width: 22.5rem){:host{--sbb-calendar-cell-size: 2.75rem;--sbb-calendar-wide-cell-size: 4.8125rem;--sbb-calendar-control-view-change-height: 3rem}}.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{-webkit-appearance:none;-moz-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-font-size-text-s);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-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: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-color: var(--sbb-calendar-cell-disabled-color);cursor:unset}.sbb-calendar__controls-change-date:focus-visible:not([data-focus-origin=mouse],[data-focus-origin=touch]){outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) 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-color-milk)}.sbb-calendar__table-month-view,.sbb-calendar__table-year-view{--sbb-calendar-table-column-spaces: 6}.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([data-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))}.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([data-wide])) .sbb-calendar__table{min-width:100%}.sbb-calendar__table-header{--sbb-text-font-size: var(--sbb-font-size-text-xs);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size);color:var(--sbb-calendar-header-color);width:var(--sbb-calendar-cell-size);padding:0;padding-block-end:var(--sbb-spacing-fixed-4x);text-align:center}.sbb-calendar__table-data{position:relative;padding:0;text-align:center}.sbb-calendar__cell{-webkit-appearance:none;-moz-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-font-size-text-s);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size);height:var(--sbb-calendar-cell-size);color:var(--sbb-calendar-cell-color);cursor:pointer;position:relative;z-index:0}.sbb-calendar__cell:before{content:"";position:absolute;inset:var(--sbb-calendar-cell-padding);background-color:var(--sbb-calendar-cell-background-color);border-radius:50%;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__cell:not(.sbb-calendar__selected,:active,:disabled):hover{--sbb-calendar-cell-background-color: var(--sbb-color-milk);padding-block-end:var(--sbb-calendar-hover-shift)}}@media (any-hover: hover) and (forced-colors: active){.sbb-calendar__cell:not(.sbb-calendar__selected,:active,:disabled):hover:before{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) solid var(--sbb-focus-outline-width)}}.sbb-calendar__cell:disabled{--sbb-calendar-cell-color: var(--sbb-calendar-cell-disabled-color);cursor:unset}.sbb-calendar__cell:focus-visible:before{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) solid var(--sbb-focus-outline-width)}.sbb-calendar__cell:not(.sbb-calendar__selected,:disabled):active{--sbb-calendar-cell-background-color: var(--sbb-color-cloud)}@media (forced-colors: active){.sbb-calendar__cell:not(.sbb-calendar__selected,:disabled):active:before{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) solid var(--sbb-focus-outline-width)}}.sbb-calendar__day{border-radius:50%;width:var(--sbb-calendar-cell-size)}.sbb-calendar__day:before{border-radius:50%}.sbb-calendar__pill{width:var(--sbb-calendar-wide-cell-size);border-radius:var(--sbb-border-radius-infinity)}.sbb-calendar__pill:before{border-radius:var(--sbb-border-radius-infinity)}.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-font-size-text-s);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size);font-weight:700}.sbb-calendar__selected{--sbb-calendar-cell-color: var(--sbb-calendar-cell-selected-color);--sbb-calendar-cell-background-color: var(--sbb-calendar-cell-selected-background-color)}@media (forced-colors: active){.sbb-calendar__selected{--sbb-calendar-cell-background-color: ButtonText !important}}@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))}}`;
23
+ let tt = (() => {
24
+ var D, $, Y, M, k, V, z, l;
25
+ let o = [pe("sbb-calendar")], h, m = [], p, E = Se(ge), x = [], W, L = [], P = [], B, q = [], K = [], H, U, j, G, J, Q = [], X = [], Z, ee = [], te = [], ae, se = [], ie = [], re, ne, le = [], de = [], oe, ce = [], be = [];
26
+ var S = (l = class extends E {
27
+ constructor() {
28
+ var e;
29
+ super();
30
+ w(this, D);
31
+ w(this, $);
32
+ w(this, Y);
33
+ w(this, M);
34
+ w(this, k);
35
+ w(this, V);
36
+ w(this, z);
37
+ u(this, D, (c(this, x), c(this, L, !1))), u(this, $, (c(this, P), c(this, q, "day"))), this._min = c(this, K), this._now = null, u(this, Y, c(this, Q, null)), this._dateAdapter = (c(this, X), ((e = ye().datetime) == null ? void 0 : e.dateAdapter) ?? De), this._dateSelected = new Me(this, S.events.dateSelected), u(this, M, c(this, ee, this.now)), u(this, k, (c(this, te), c(this, se, void 0))), u(this, V, (c(this, ie), c(this, le, "day"))), this._nextCalendarView = (c(this, de), "day"), this._weeks = [], this._monthNames = this._dateAdapter.getMonthNames("long"), this._resetFocus = !1, u(this, z, c(this, ce, !1)), this._abort = (c(this, be), new Ae(this)), this._language = new xe(this).withHandler(() => {
38
+ this._monthNames = this._dateAdapter.getMonthNames("long"), this._createMonthRows();
39
+ }), this._createMonthRows(), this._setWeekdays();
40
+ }
41
+ /** If set to true, two months are displayed */
42
+ get wide() {
43
+ return v(this, D);
44
+ }
45
+ set wide(e) {
46
+ u(this, D, e);
47
+ }
48
+ /** The initial view of the calendar which should be displayed on opening. */
49
+ get view() {
50
+ return v(this, $);
51
+ }
52
+ set view(e) {
53
+ u(this, $, e);
54
+ }
55
+ /** The minimum valid date. Takes T Object, ISOString, and Unix Timestamp (number of seconds since Jan 1, 1970). */
56
+ set min(e) {
57
+ this._min = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(e));
58
+ }
59
+ get min() {
60
+ return this._min ?? null;
61
+ }
62
+ /** The maximum valid date. Takes T Object, ISOString, and Unix Timestamp (number of seconds since Jan 1, 1970). */
63
+ set max(e) {
64
+ this._max = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(e));
65
+ }
66
+ get max() {
67
+ return this._max ?? null;
68
+ }
69
+ /** A configured date which acts as the current date instead of the real current date. Recommended for testing purposes. */
70
+ set now(e) {
71
+ this._now = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(e));
72
+ }
73
+ get now() {
74
+ return this._now ?? this._dateAdapter.today();
75
+ }
76
+ /** The selected date. Takes T Object, ISOString, and Unix Timestamp (number of seconds since Jan 1, 1970). */
77
+ set selected(e) {
78
+ this._selectedDate = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(e)), this._selectedDate && (!this._isDayInRange(this._dateAdapter.toIso8601(this._selectedDate)) || this._dateFilter(this._selectedDate)) ? this._selected = this._dateAdapter.toIso8601(this._selectedDate) : this._selected = void 0;
79
+ }
80
+ get selected() {
81
+ return this._selectedDate ?? null;
82
+ }
83
+ /** A function used to filter out dates. */
84
+ get dateFilter() {
85
+ return v(this, Y);
86
+ }
87
+ set dateFilter(e) {
88
+ u(this, Y, e);
89
+ }
90
+ /** The currently active date. */
91
+ get _activeDate() {
92
+ return v(this, M);
93
+ }
94
+ set _activeDate(e) {
95
+ u(this, M, e);
96
+ }
97
+ /** The selected date as ISOString. */
98
+ get _selected() {
99
+ return v(this, k);
100
+ }
101
+ set _selected(e) {
102
+ u(this, k, e);
103
+ }
104
+ /** The current wide property considering property value and breakpoints. From zero to small `wide` has always to be false. */
105
+ set _wide(e) {
106
+ this.toggleAttribute("data-wide", e);
107
+ }
108
+ get _wide() {
109
+ return this.hasAttribute("data-wide");
110
+ }
111
+ get _calendarView() {
112
+ return v(this, V);
113
+ }
114
+ set _calendarView(e) {
115
+ u(this, V, e);
116
+ }
117
+ /** A list of buttons corresponding to days, months or years depending on the view. */
118
+ get _cells() {
119
+ return Array.from(this.shadowRoot.querySelectorAll(".sbb-calendar__cell") ?? []);
120
+ }
121
+ get _initialized() {
122
+ return v(this, z);
123
+ }
124
+ set _initialized(e) {
125
+ u(this, z, e);
126
+ }
127
+ _dateFilter(e) {
128
+ var t;
129
+ return ((t = this.dateFilter) == null ? void 0 : t.call(this, e)) ?? !0;
130
+ }
131
+ /** Resets the active month according to the new state of the calendar. */
132
+ resetPosition() {
133
+ this._resetCalendarView(), this._init();
134
+ }
135
+ connectedCallback() {
136
+ var e;
137
+ super.connectedCallback(), this.resetPosition(), this.focus = () => {
138
+ this._resetFocus = !0, this._focusCell();
139
+ }, (e = globalThis.window) == null || e.addEventListener("resize", () => this._init(), {
140
+ passive: !0,
141
+ signal: this._abort.signal
142
+ });
143
+ }
144
+ willUpdate(e) {
145
+ super.willUpdate(e), this._initialized && (e.has("wide") && this.resetPosition(), e.has("view") && (this._setChosenYear(), this._chosenMonth = void 0, this._nextCalendarView = this._calendarView = this.view));
146
+ }
147
+ updated(e) {
148
+ super.updated(e), this._setTabIndex(), ve.mostRecentModality === "keyboard" && this._focusCell();
149
+ }
150
+ /** Initializes the component. */
151
+ _init(e) {
152
+ if (!ue) {
153
+ if (this.hydrationRequired) {
154
+ this.hydrationComplete.then(() => this._init());
155
+ return;
156
+ }
157
+ if (e && this._assignActiveDate(e), this._wide = Ye("medium") && this.wide, this._weeks = this._createWeekRows(this._activeDate), this._years = this._createYearRows(), this._nextMonthWeeks = [[]], this._nextMonthYears = [[]], this._wide) {
158
+ const t = this._dateAdapter.addCalendarMonths(this._activeDate, 1);
159
+ this._nextMonthWeeks = this._createWeekRows(t), this._nextMonthYears = this._createYearRows(b);
160
+ }
161
+ this._initialized = !0;
96
162
  }
97
- if (e && this._assignActiveDate(e), this._wide = A("medium") && this.wide, this._weeks = this._createWeekRows(this._activeDate), this._years = this._createYearRows(), this._nextMonthWeeks = [[]], this._nextMonthYears = [[]], this._wide) {
98
- const t = this._dateAdapter.addCalendarMonths(this._activeDate, 1);
99
- this._nextMonthWeeks = this._createWeekRows(t), this._nextMonthYears = this._createYearRows(d);
163
+ }
164
+ /** Focuses on a day cell prioritizing the selected day, the current day, and lastly, the first selectable day. */
165
+ _focusCell() {
166
+ var e;
167
+ this._resetFocus && ((e = this._getFirstFocusable()) == null || e.focus(), this._resetFocus = !1);
168
+ }
169
+ /** Creates the array of weekdays. */
170
+ _setWeekdays() {
171
+ const e = this._dateAdapter.getDayOfWeekNames("narrow"), a = this._dateAdapter.getDayOfWeekNames("long").map((i, r) => ({
172
+ long: i,
173
+ narrow: e[r]
174
+ })), s = this._dateAdapter.getFirstDayOfWeek();
175
+ this._weekdays = a.slice(s).concat(a.slice(0, s));
176
+ }
177
+ /** Creates the rows for each week. */
178
+ _createWeekRows(e) {
179
+ const t = this._dateAdapter.getNumDaysInMonth(e), a = this._dateAdapter.getDateNames(), s = [[]], i = this._dateAdapter.getFirstWeekOffset(e);
180
+ for (let r = 0, d = i; r < t; r++, d++) {
181
+ d === O && (s.push([]), d = 0);
182
+ const _ = this._dateAdapter.createDate(this._dateAdapter.getYear(e), this._dateAdapter.getMonth(e), r + 1);
183
+ s[s.length - 1].push({
184
+ value: this._dateAdapter.toIso8601(_),
185
+ dayValue: a[r],
186
+ monthValue: String(this._dateAdapter.getMonth(_)),
187
+ yearValue: String(this._dateAdapter.getYear(_))
188
+ });
100
189
  }
101
- this._initialized = !0;
102
- }
103
- }
104
- /** Focuses on a day cell prioritizing the selected day, the current day, and lastly, the first selectable day. */
105
- _focusCell() {
106
- var e;
107
- this._resetFocus && ((e = this._getFirstFocusable()) == null || e.focus(), this._resetFocus = !1);
108
- }
109
- /** Creates the array of weekdays. */
110
- _setWeekdays() {
111
- const e = this._dateAdapter.getDayOfWeekNames("narrow"), a = this._dateAdapter.getDayOfWeekNames("long").map((s, i) => ({
112
- long: s,
113
- narrow: e[i]
114
- })), r = this._dateAdapter.getFirstDayOfWeek();
115
- this._weekdays = a.slice(r).concat(a.slice(0, r));
116
- }
117
- /** Creates the rows for each week. */
118
- _createWeekRows(e) {
119
- const t = this._dateAdapter.getNumDaysInMonth(e), a = this._dateAdapter.getDateNames(), r = [[]], s = this._dateAdapter.getFirstWeekOffset(e);
120
- for (let i = 0, n = s; i < t; i++, n++) {
121
- n === y && (r.push([]), n = 0);
122
- const c = this._dateAdapter.createDate(
123
- this._dateAdapter.getYear(e),
124
- this._dateAdapter.getMonth(e),
125
- i + 1
126
- );
127
- r[r.length - 1].push({
128
- value: this._dateAdapter.toIso8601(c),
129
- dayValue: a[i],
130
- monthValue: String(this._dateAdapter.getMonth(c)),
131
- yearValue: String(this._dateAdapter.getYear(c))
132
- });
190
+ return s;
191
+ }
192
+ /** Creates the rows for the month selection view. */
193
+ _createMonthRows() {
194
+ const e = this._dateAdapter.getMonthNames("short"), t = new Array(12).fill(null).map((i, r) => ({
195
+ value: e[r],
196
+ longValue: this._monthNames[r],
197
+ monthValue: r + 1
198
+ })), a = 12 / I, s = [];
199
+ for (let i = 0; i < a; i++)
200
+ s.push(t.slice(I * i, I * (i + 1)));
201
+ this._months = s;
202
+ }
203
+ /** Creates the rows for the year selection view. */
204
+ _createYearRows(e = 0) {
205
+ const t = this._getStartValueYearView(), a = new Array(b).fill(0).map((r, d) => t + e + d), s = b / C, i = [];
206
+ for (let r = 0; r < s; r++)
207
+ i.push(a.slice(C * r, C * (r + 1)));
208
+ return i;
209
+ }
210
+ /**
211
+ * Calculates the first year that will be shown in the year selection panel.
212
+ * If `minDate` and `maxDate` are both null, the starting year is calculated as
213
+ * the multiple of YEARS_PER_PAGE closest to and less than activeDate,
214
+ * e.g., with `YEARS_PER_PAGE` = 24 and `activeDate` = 2020, the function will return 2016 (24 * 83),
215
+ * while with `activeDate` = 2000, the function will return 1992 (24 * 82).
216
+ * If `minDate` is not null, it returns the corresponding year; if `maxDate` is not null,
217
+ * it returns the corresponding year minus `YEARS_PER_PAGE`, so that the `maxDate` is the last rendered year.
218
+ * If both are not null, `maxDate` has priority over `minDate`.
219
+ */
220
+ _getStartValueYearView() {
221
+ let e = 0;
222
+ this.max ? e = this._dateAdapter.getYear(this.max) - b + 1 : this.min && (e = this._dateAdapter.getYear(this.min));
223
+ const t = this._dateAdapter.getYear(this._activeDate);
224
+ return t - ((t - e) % b + b) % b;
133
225
  }
134
- return r;
135
- }
136
- /** Creates the rows for the month selection view. */
137
- _createMonthRows() {
138
- const e = this._dateAdapter.getMonthNames("short"), t = new Array(12).fill(null).map(
139
- (s, i) => ({
140
- value: e[i],
141
- longValue: this._monthNames[i],
142
- monthValue: i + 1
143
- })
144
- ), a = 12 / g, r = [];
145
- for (let s = 0; s < a; s++)
146
- r.push(t.slice(g * s, g * (s + 1)));
147
- this._months = r;
148
- }
149
- /** Creates the rows for the year selection view. */
150
- _createYearRows(e = 0) {
151
- const t = this._getStartValueYearView(), a = new Array(d).fill(0).map((i, n) => t + e + n), r = d / v, s = [];
152
- for (let i = 0; i < r; i++)
153
- s.push(a.slice(v * i, v * (i + 1)));
154
- return s;
155
- }
156
- /**
157
- * Calculates the first year that will be shown in the year selection panel.
158
- * If `minDate` and `maxDate` are both null, the starting year is calculated as
159
- * the multiple of YEARS_PER_PAGE closest to and less than activeDate,
160
- * e.g., with `YEARS_PER_PAGE` = 24 and `activeDate` = 2020, the function will return 2016 (24 * 83),
161
- * while with `activeDate` = 2000, the function will return 1992 (24 * 82).
162
- * If `minDate` is not null, it returns the corresponding year; if `maxDate` is not null,
163
- * it returns the corresponding year minus `YEARS_PER_PAGE`, so that the `maxDate` is the last rendered year.
164
- * If both are not null, `maxDate` has priority over `minDate`.
165
- */
166
- _getStartValueYearView() {
167
- let e = 0;
168
- this.max ? e = this._dateAdapter.getYear(this.max) - d + 1 : this.min && (e = this._dateAdapter.getYear(this.min));
169
- const t = this._dateAdapter.getYear(this._activeDate);
170
- return t - ((t - e) % d + d) % d;
171
- }
172
- /** Checks if date is within the min-max range. */
173
- _isDayInRange(e) {
174
- if (!this._min && !this._max)
175
- return !0;
176
- const t = this._dateAdapter.isValid(this._min) && this._dateAdapter.compareDate(this._min, this._dateAdapter.deserialize(e)) > 0, a = this._dateAdapter.isValid(this._max) && this._dateAdapter.compareDate(this._max, this._dateAdapter.deserialize(e)) < 0;
177
- return !(t || a);
178
- }
179
- _isMonthInRange(e) {
180
- if (!this._min && !this._max)
181
- return !0;
182
- const t = this._dateAdapter.isValid(this._min) && this._dateAdapter.getYear(this._min) >= this._chosenYear && this._dateAdapter.getMonth(this._min) > e, a = this._dateAdapter.isValid(this._max) && this._dateAdapter.getYear(this._max) <= this._chosenYear && this._dateAdapter.getMonth(this._max) < e;
183
- return !(t || a);
184
- }
185
- _isYearInRange(e) {
186
- if (!this._min && !this._max)
187
- return !0;
188
- 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;
189
- return !(t || a);
190
- }
191
- // Implementation adapted from https://github.com/angular/components/blob/main/src/material/datepicker/year-view.ts#L366
192
- _isMonthFilteredOut(e) {
193
- if (!this.dateFilter)
194
- return !0;
195
- const t = this._dateAdapter.createDate(this._chosenYear, e, 1);
196
- for (let a = t; this._dateAdapter.getMonth(a) == e; a = this._dateAdapter.addCalendarDays(a, 1))
197
- if (this.dateFilter(a))
226
+ /** Checks if date is within the min-max range. */
227
+ _isDayInRange(e) {
228
+ if (!this.min && !this.max)
198
229
  return !0;
199
- return !1;
200
- }
201
- // Implementation adapted from https://github.com/angular/components/blob/main/src/material/datepicker/multi-year-view.ts#L351
202
- _isYearFilteredOut(e) {
203
- if (!this.dateFilter)
204
- return !0;
205
- const t = this._dateAdapter.createDate(e, 1, 1);
206
- for (let a = t; this._dateAdapter.getYear(a) == e; a = this._dateAdapter.addCalendarDays(a, 1))
207
- if (this.dateFilter(a))
230
+ const t = this._dateAdapter.isValid(this.min) && this._dateAdapter.compareDate(this.min, this._dateAdapter.deserialize(e)) > 0, a = this._dateAdapter.isValid(this.max) && this._dateAdapter.compareDate(this.max, this._dateAdapter.deserialize(e)) < 0;
231
+ return !(t || a);
232
+ }
233
+ _isMonthInRange(e, t) {
234
+ if (!this.min && !this.max)
235
+ return !0;
236
+ 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));
237
+ return !(a || s);
238
+ }
239
+ _isYearInRange(e) {
240
+ if (!this.min && !this.max)
241
+ return !0;
242
+ 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;
243
+ return !(t || a);
244
+ }
245
+ // Implementation adapted from https://github.com/angular/components/blob/main/src/material/datepicker/year-view.ts#L366
246
+ _isMonthFilteredOut(e, t) {
247
+ if (!this.dateFilter)
248
+ return !0;
249
+ const a = this._dateAdapter.createDate(t, e, 1);
250
+ for (let s = a; this._dateAdapter.getMonth(s) == e; s = this._dateAdapter.addCalendarDays(s, 1))
251
+ if (this.dateFilter(s))
252
+ return !0;
253
+ return !1;
254
+ }
255
+ // Implementation adapted from https://github.com/angular/components/blob/main/src/material/datepicker/multi-year-view.ts#L351
256
+ _isYearFilteredOut(e) {
257
+ if (!this.dateFilter)
208
258
  return !0;
209
- return !1;
210
- }
211
- /** Emits the selected date and sets it internally. */
212
- _selectDate(e) {
213
- this._chosenMonth = void 0, this._setChosenYear(), this._selected !== e && (this._selected = e, this._dateSelected.emit(this._dateAdapter.deserialize(e)));
214
- }
215
- _setChosenYear() {
216
- this.view === "month" ? this._chosenYear = this._dateAdapter.getYear(
217
- this._dateAdapter.deserialize(this._selected) ?? this.selected ?? this.now
218
- ) : this._chosenYear = void 0;
219
- }
220
- _assignActiveDate(e) {
221
- if (this._min && this._dateAdapter.compareDate(this._min, e) > 0) {
222
- this._activeDate = this._min;
223
- return;
224
- }
225
- if (this._max && this._dateAdapter.compareDate(this._max, e) < 0) {
226
- this._activeDate = this._max;
227
- return;
228
- }
229
- this._activeDate = e;
230
- }
231
- /** Goes to the month identified by the shift. */
232
- _goToDifferentMonth(e) {
233
- this._init(this._dateAdapter.addCalendarMonths(this._activeDate, e));
234
- }
235
- _goToDifferentYear(e) {
236
- this._chosenYear += e, this._activeDate = this._dateAdapter.createDate(
237
- this._chosenYear,
238
- this._dateAdapter.getMonth(this._activeDate),
239
- this._dateAdapter.getDate(this._activeDate)
240
- ), this._init();
241
- }
242
- _goToDifferentYearRange(e) {
243
- this._init(this._dateAdapter.addCalendarYears(this._activeDate, e));
244
- }
245
- _prevDisabled(e) {
246
- return this._min ? this._dateAdapter.compareDate(e, this._min) < 0 : !1;
247
- }
248
- _nextDisabled(e) {
249
- return this._max ? this._dateAdapter.compareDate(e, this._max) > 0 : !1;
250
- }
251
- /** Checks if the "previous month" button should be disabled. */
252
- _previousMonthDisabled() {
253
- const e = this._dateAdapter.addCalendarDays(
254
- this._activeDate,
255
- this._dateAdapter.getDate(this._activeDate) * -1
256
- );
257
- return this._prevDisabled(e);
258
- }
259
- /** Checks if the "next month" button should be disabled. */
260
- _nextMonthDisabled() {
261
- let e = this._dateAdapter.addCalendarMonths(this._activeDate, this._wide ? 2 : 1);
262
- return e = this._dateAdapter.createDate(
263
- this._dateAdapter.getYear(e),
264
- this._dateAdapter.getMonth(e),
265
- 1
266
- ), this._nextDisabled(e);
267
- }
268
- _previousYearDisabled() {
269
- const e = this._dateAdapter.createDate(
270
- this._dateAdapter.getYear(this._activeDate) - 1,
271
- 12,
272
- 31
273
- );
274
- return this._prevDisabled(e);
275
- }
276
- _nextYearDisabled() {
277
- const e = this._dateAdapter.createDate(
278
- this._dateAdapter.getYear(this._activeDate) + 1,
279
- 1,
280
- 1
281
- );
282
- return this._nextDisabled(e);
283
- }
284
- _previousYearRangeDisabled() {
285
- const e = this._dateAdapter.createDate(this._years[0][0] - 1, 12, 31);
286
- return this._prevDisabled(e);
287
- }
288
- _nextYearRangeDisabled() {
289
- const e = A("medium") && this.wide ? this._nextMonthYears : this._years, t = e[e.length - 1], a = t[t.length - 1], r = this._dateAdapter.createDate(a + 1, 1, 1);
290
- return this._nextDisabled(r);
291
- }
292
- _handleTableBlur(e) {
293
- (e == null ? void 0 : e.localName) !== "button" && this._setTabIndex();
294
- }
295
- _setTabIndex() {
296
- Array.from(
297
- this.shadowRoot.querySelectorAll('.sbb-calendar__cell[tabindex="0"]') ?? []
298
- ).forEach((t) => t.tabIndex = -1);
299
- const e = this._getFirstFocusable();
300
- e && (e.tabIndex = 0);
301
- }
302
- _getFirstFocusable() {
303
- const e = this._selected ? this._dateAdapter.deserialize(this._selected) : this.now;
304
- let t = this.shadowRoot.querySelector(".sbb-calendar__selected") ?? this.shadowRoot.querySelector(
305
- `[data-day="${this._dateAdapter.getDate(e)} ${this._dateAdapter.getMonth(
306
- e
307
- )} ${this._dateAdapter.getYear(e)}"]`
308
- ) ?? this.shadowRoot.querySelector(`[data-month="${this._dateAdapter.getMonth(e)}"]`) ?? this.shadowRoot.querySelector(`[data-year="${this._dateAdapter.getYear(e)}"]`);
309
- return (!t || t != null && t.disabled) && (t = this.shadowRoot.querySelector(".sbb-calendar__cell:not([disabled])")), t || null;
310
- }
311
- _handleKeyboardEvent(e, t) {
312
- F(e) && e.preventDefault();
313
- const a = this._cells, r = a.findIndex((n) => n === e.target), s = this._navigateByKeyboard(e, r, a, t), i = this.shadowRoot.activeElement;
314
- s !== i && (s.tabIndex = 0, s == null || s.focus(), i.tabIndex = -1);
315
- }
316
- /**
317
- * Gets the index of the element to move to, based on a list of elements (which can be potentially disabled),
318
- * the keyboard input and the position of the current element in the list.
319
- * In the day view, the `day?: Day` parameter is mandatory for calculation,
320
- * while in month and year view it's not due to the fixed amount of rendered cells.
321
- */
322
- _navigateByKeyboard(e, t, a, r) {
323
- const {
324
- elementIndexForWideMode: s,
325
- offsetForWideMode: i,
326
- lastElementIndexForWideMode: n,
327
- verticalOffset: c
328
- } = this._calculateParametersForKeyboardNavigation(
329
- a,
330
- t,
331
- r
332
- );
333
- switch (e.key) {
334
- case "ArrowUp":
335
- return this._findNext(a, t, -c);
336
- case "ArrowDown":
337
- return this._findNext(a, t, c);
338
- case "ArrowLeft":
339
- return this._findNext(a, t, -1);
340
- case "ArrowRight":
341
- return this._findNext(a, t, 1);
342
- case "Home":
343
- return this._findFirst(a, i);
344
- case "PageUp":
345
- return this._findFirstOnColumn(
346
- a,
347
- s,
348
- i,
349
- c
350
- );
351
- case "PageDown":
352
- return this._findLastOnColumn(a, t, n, c);
353
- case "End":
354
- return this._findLast(a, n - 1);
355
- default:
356
- return a[t];
357
- }
358
- }
359
- /**
360
- * Calculates the parameter needed in keyboard navigation.
361
- * Since three views are now available, the function creates and returns the correct parameters for each of them
362
- * by considering the number of cells per each row and the correction for the wide mode.
363
- * @param cells The array of rendered table cells; they are buttons that can represent days, months or years.
364
- * @param index The starting element's index in the cell array.
365
- * @param day (optional) Only in the day view, the day represented by the starting cell.
366
- */
367
- _calculateParametersForKeyboardNavigation(e, t, a) {
368
- switch (this._calendarView) {
369
- case "day": {
370
- const r = +a.dayValue - 1;
371
- return {
372
- verticalOffset: y,
373
- elementIndexForWideMode: r,
374
- offsetForWideMode: t - r,
375
- lastElementIndexForWideMode: t === r ? this._dateAdapter.getNumDaysInMonth(
376
- this._dateAdapter.addCalendarMonths(
377
- this._dateAdapter.deserialize(a.value),
378
- -1
379
- )
380
- ) : e.length
381
- };
259
+ const t = this._dateAdapter.createDate(e, 1, 1);
260
+ for (let a = t; this._dateAdapter.getYear(a) == e; a = this._dateAdapter.addCalendarDays(a, 1))
261
+ if (this.dateFilter(a))
262
+ return !0;
263
+ return !1;
264
+ }
265
+ /** Emits the selected date and sets it internally. */
266
+ _selectDate(e) {
267
+ this._chosenMonth = void 0, this._setChosenYear(), this._selected !== e && (this._selected = e, this._dateSelected.emit(this._dateAdapter.deserialize(e)));
268
+ }
269
+ _setChosenYear() {
270
+ this.view === "month" ? this._chosenYear = this._dateAdapter.getYear(this._dateAdapter.deserialize(this._selected) ?? this.selected ?? this.now) : this._chosenYear = void 0;
271
+ }
272
+ _assignActiveDate(e) {
273
+ if (this.min && this._dateAdapter.compareDate(this.min, e) > 0) {
274
+ this._activeDate = this.min;
275
+ return;
382
276
  }
383
- case "month":
384
- return {
385
- verticalOffset: g,
386
- elementIndexForWideMode: t,
387
- offsetForWideMode: 0,
388
- lastElementIndexForWideMode: 12
389
- };
390
- case "year": {
391
- const r = Math.trunc(t / d) * d, s = r === 0 ? t : t - d;
392
- return {
393
- verticalOffset: v,
394
- elementIndexForWideMode: s,
395
- offsetForWideMode: t - s,
396
- lastElementIndexForWideMode: r === 0 ? d : d * 2
397
- };
277
+ if (this.max && this._dateAdapter.compareDate(this.max, e) < 0) {
278
+ this._activeDate = this.max;
279
+ return;
398
280
  }
281
+ this._activeDate = e;
282
+ }
283
+ /** Goes to the month identified by the shift. */
284
+ _goToDifferentMonth(e) {
285
+ this._init(this._dateAdapter.addCalendarMonths(this._activeDate, e));
286
+ }
287
+ _goToDifferentYear(e) {
288
+ this._chosenYear += e, this._activeDate = this._dateAdapter.createDate(this._chosenYear, this._dateAdapter.getMonth(this._activeDate), this._dateAdapter.getDate(this._activeDate)), this._init();
399
289
  }
400
- }
401
- /**
402
- * Gets the next element of the provided array starting from `index` by adding `delta`.
403
- * If the found element is disabled, it continues adding `delta` until it finds an enabled one in the array bounds.
404
- */
405
- _findNext(e, t, a) {
406
- var s;
407
- let r = t + a;
408
- for (; r < e.length && ((s = e[r]) != null && s.disabled); )
409
- r += a;
410
- return e[r] ?? e[t];
411
- }
412
- /** Find the first enabled element in the provided array. */
413
- _findFirst(e, t) {
414
- return e[t].disabled ? this._findNext(e, t, 1) : e[t];
415
- }
416
- /** Find the last enabled element in the provided array. */
417
- _findLast(e, t) {
418
- return e[t].disabled ? this._findNext(e, t, -1) : e[t];
419
- }
420
- /** Find the first enabled element in the same column of the provided array. */
421
- _findFirstOnColumn(e, t, a, r) {
422
- const s = t % r + a;
423
- return e[s].disabled ? this._findNext(e, s, r) : e[s];
424
- }
425
- /** Find the last enabled element in the same column of the provided array. */
426
- _findLastOnColumn(e, t, a, r) {
427
- const s = t + Math.trunc((a - t - 1) / r) * r;
428
- return e[s].disabled ? this._findNext(e, s, -r) : e[s];
429
- }
430
- _resetCalendarView(e = !1) {
431
- this._resetFocus = !0, this._activeDate = this.selected ?? this.now, this._setChosenYear(), this._chosenMonth = void 0, this._nextCalendarView = this._calendarView = this.view, e && this._startTableTransition();
432
- }
433
- /** Render the view for the day selection. */
434
- _renderDayView() {
435
- const e = this._wide ? this._dateAdapter.addCalendarMonths(this._activeDate, 1) : void 0;
436
- return o`
290
+ _goToDifferentYearRange(e) {
291
+ this._init(this._dateAdapter.addCalendarYears(this._activeDate, e));
292
+ }
293
+ _prevDisabled(e) {
294
+ return this.min ? this._dateAdapter.compareDate(e, this.min) < 0 : !1;
295
+ }
296
+ _nextDisabled(e) {
297
+ return this.max ? this._dateAdapter.compareDate(e, this.max) > 0 : !1;
298
+ }
299
+ /** Checks if the "previous month" button should be disabled. */
300
+ _previousMonthDisabled() {
301
+ const e = this._dateAdapter.addCalendarDays(this._activeDate, this._dateAdapter.getDate(this._activeDate) * -1);
302
+ return this._prevDisabled(e);
303
+ }
304
+ /** Checks if the "next month" button should be disabled. */
305
+ _nextMonthDisabled() {
306
+ let e = this._dateAdapter.addCalendarMonths(this._activeDate, this._wide ? 2 : 1);
307
+ return e = this._dateAdapter.createDate(this._dateAdapter.getYear(e), this._dateAdapter.getMonth(e), 1), this._nextDisabled(e);
308
+ }
309
+ _previousYearDisabled() {
310
+ const e = this._dateAdapter.createDate(this._dateAdapter.getYear(this._activeDate) - 1, 12, 31);
311
+ return this._prevDisabled(e);
312
+ }
313
+ _nextYearDisabled() {
314
+ const e = this._dateAdapter.createDate(this._dateAdapter.getYear(this._activeDate) + (this._wide ? 2 : 1), 1, 1);
315
+ return this._nextDisabled(e);
316
+ }
317
+ _previousYearRangeDisabled() {
318
+ const e = this._dateAdapter.createDate(this._years[0][0] - 1, 12, 31);
319
+ return this._prevDisabled(e);
320
+ }
321
+ _nextYearRangeDisabled() {
322
+ 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);
323
+ return this._nextDisabled(s);
324
+ }
325
+ _handleTableBlur(e) {
326
+ (e == null ? void 0 : e.localName) !== "button" && this._setTabIndex();
327
+ }
328
+ _setTabIndex() {
329
+ Array.from(this.shadowRoot.querySelectorAll('.sbb-calendar__cell[tabindex="0"]') ?? []).forEach((t) => t.tabIndex = -1);
330
+ const e = this._getFirstFocusable();
331
+ e && (e.tabIndex = 0);
332
+ }
333
+ _getFirstFocusable() {
334
+ const e = this._selected ? this._dateAdapter.deserialize(this._selected) : this.now;
335
+ let t = this.shadowRoot.querySelector(".sbb-calendar__selected") ?? this.shadowRoot.querySelector(`[data-day="${this._dateAdapter.getDate(e)} ${this._dateAdapter.getMonth(e)} ${this._dateAdapter.getYear(e)}"]`) ?? this.shadowRoot.querySelector(`[data-month="${this._dateAdapter.getMonth(e)}"]`) ?? this.shadowRoot.querySelector(`[data-year="${this._dateAdapter.getYear(e)}"]`);
336
+ return (!t || t != null && t.disabled) && (t = this.shadowRoot.querySelector(".sbb-calendar__cell:not([disabled])")), t || null;
337
+ }
338
+ _handleKeyboardEvent(e, t) {
339
+ we(e) && e.preventDefault();
340
+ const a = this._cells, s = a.findIndex((d) => d === e.target), i = this._navigateByKeyboard(e, s, a, t), r = this.shadowRoot.activeElement;
341
+ i !== r && (i.tabIndex = 0, i == null || i.focus(), r.tabIndex = -1);
342
+ }
343
+ /**
344
+ * Gets the index of the element to move to, based on a list of elements (which can be potentially disabled),
345
+ * the keyboard input and the position of the current element in the list.
346
+ * In the day view, the `day?: Day` parameter is mandatory for calculation,
347
+ * while in month and year view it's not due to the fixed amount of rendered cells.
348
+ */
349
+ _navigateByKeyboard(e, t, a, s) {
350
+ const { elementIndexForWideMode: i, offsetForWideMode: r, lastElementIndexForWideMode: d, verticalOffset: _ } = this._calculateParametersForKeyboardNavigation(a, t, s);
351
+ switch (e.key) {
352
+ case "ArrowUp":
353
+ return this._findNext(a, t, -_);
354
+ case "ArrowDown":
355
+ return this._findNext(a, t, _);
356
+ case "ArrowLeft":
357
+ return this._findNext(a, t, -1);
358
+ case "ArrowRight":
359
+ return this._findNext(a, t, 1);
360
+ case "Home":
361
+ return this._findFirst(a, r);
362
+ case "PageUp":
363
+ return this._findFirstOnColumn(a, i, r, _);
364
+ case "PageDown":
365
+ return this._findLastOnColumn(a, t, d, _);
366
+ case "End":
367
+ return this._findLast(a, d - 1);
368
+ default:
369
+ return a[t];
370
+ }
371
+ }
372
+ /**
373
+ * Calculates the parameter needed in keyboard navigation.
374
+ * Since three views are now available, the function creates and returns the correct parameters for each of them
375
+ * by considering the number of cells per each row and the correction for the wide mode.
376
+ * @param cells The array of rendered table cells; they are buttons that can represent days, months or years.
377
+ * @param index The starting element's index in the cell array.
378
+ * @param day (optional) Only in the day view, the day represented by the starting cell.
379
+ */
380
+ _calculateParametersForKeyboardNavigation(e, t, a) {
381
+ switch (this._calendarView) {
382
+ case "day": {
383
+ const s = +a.dayValue - 1;
384
+ return {
385
+ verticalOffset: O,
386
+ elementIndexForWideMode: s,
387
+ offsetForWideMode: t - s,
388
+ lastElementIndexForWideMode: t === s ? this._dateAdapter.getNumDaysInMonth(this._dateAdapter.addCalendarMonths(this._dateAdapter.deserialize(a.value), -1)) : e.length
389
+ };
390
+ }
391
+ case "month":
392
+ return {
393
+ verticalOffset: I,
394
+ elementIndexForWideMode: t,
395
+ offsetForWideMode: 0,
396
+ lastElementIndexForWideMode: 12
397
+ };
398
+ case "year": {
399
+ const s = Math.trunc(t / b) * b, i = s === 0 ? t : t - b;
400
+ return {
401
+ verticalOffset: C,
402
+ elementIndexForWideMode: i,
403
+ offsetForWideMode: t - i,
404
+ lastElementIndexForWideMode: s === 0 ? b : b * 2
405
+ };
406
+ }
407
+ }
408
+ }
409
+ /**
410
+ * Gets the next element of the provided array starting from `index` by adding `delta`.
411
+ * If the found element is disabled, it continues adding `delta` until it finds an enabled one in the array bounds.
412
+ */
413
+ _findNext(e, t, a) {
414
+ var i;
415
+ let s = t + a;
416
+ for (; s < e.length && ((i = e[s]) != null && i.disabled); )
417
+ s += a;
418
+ return e[s] ?? e[t];
419
+ }
420
+ /** Find the first enabled element in the provided array. */
421
+ _findFirst(e, t) {
422
+ return e[t].disabled ? this._findNext(e, t, 1) : e[t];
423
+ }
424
+ /** Find the last enabled element in the provided array. */
425
+ _findLast(e, t) {
426
+ return e[t].disabled ? this._findNext(e, t, -1) : e[t];
427
+ }
428
+ /** Find the first enabled element in the same column of the provided array. */
429
+ _findFirstOnColumn(e, t, a, s) {
430
+ const i = t % s + a;
431
+ return e[i].disabled ? this._findNext(e, i, s) : e[i];
432
+ }
433
+ /** Find the last enabled element in the same column of the provided array. */
434
+ _findLastOnColumn(e, t, a, s) {
435
+ const i = t + Math.trunc((a - t - 1) / s) * s;
436
+ return e[i].disabled ? this._findNext(e, i, -s) : e[i];
437
+ }
438
+ _resetCalendarView(e = !1) {
439
+ this._resetFocus = !0, this._activeDate = this.selected ?? this.now, this._setChosenYear(), this._chosenMonth = void 0, this._nextCalendarView = this._calendarView = this.view, e && this._startTableTransition();
440
+ }
441
+ /** Render the view for the day selection. */
442
+ _renderDayView() {
443
+ const e = this._wide ? this._dateAdapter.addCalendarMonths(this._activeDate, 1) : void 0;
444
+ return n`
437
445
  <div class="sbb-calendar__controls">
438
- ${this._getArrow(
439
- "left",
440
- () => this._goToDifferentMonth(-1),
441
- I[this._language.current],
442
- this._previousMonthDisabled()
443
- )}
446
+ ${this._getArrow("left", () => this._goToDifferentMonth(-1), ke[this._language.current], this._previousMonthDisabled())}
444
447
  <div class="sbb-calendar__controls-month">
445
448
  ${this._createLabelForDayView(this._activeDate)}
446
- ${this._wide ? this._createLabelForDayView(e) : h}
449
+ ${this._wide ? this._createLabelForDayView(e) : g}
447
450
  <sbb-screen-reader-only role="status">
448
451
  ${this._createAriaLabelForDayView(this._activeDate, e)}
449
452
  </sbb-screen-reader-only>
450
453
  </div>
451
- ${this._getArrow(
452
- "right",
453
- () => this._goToDifferentMonth(1),
454
- O[this._language.current],
455
- this._nextMonthDisabled()
456
- )}
454
+ ${this._getArrow("right", () => this._goToDifferentMonth(1), Ve[this._language.current], this._nextMonthDisabled())}
457
455
  </div>
458
456
  <div class="sbb-calendar__table-container sbb-calendar__table-day-view">
459
457
  ${this._createDayTable(this._weeks)}
460
- ${this._wide ? this._createDayTable(this._nextMonthWeeks) : h}
458
+ ${this._wide ? this._createDayTable(this._nextMonthWeeks) : g}
461
459
  </div>
462
460
  `;
463
- }
464
- /** Creates the label with the month for the daily view. */
465
- _createLabelForDayView(e) {
466
- const t = `${this._monthNames[this._dateAdapter.getMonth(e) - 1]} ${this._dateAdapter.getYear(e)}`;
467
- return o`
461
+ }
462
+ /** Creates the label with the month for the daily view. */
463
+ _createLabelForDayView(e) {
464
+ const t = `${this._monthNames[this._dateAdapter.getMonth(e) - 1]} ${this._dateAdapter.getYear(e)}`;
465
+ return n`
468
466
  <button
469
467
  type="button"
470
- id="sbb-calendar__date-selection"
471
- class="sbb-calendar__controls-change-date"
472
- aria-label="${S[this._language.current]} ${t}"
468
+ class="sbb-calendar__date-selection sbb-calendar__controls-change-date"
469
+ aria-label="${ze[this._language.current]} ${t}"
473
470
  @click=${() => {
474
- this._resetFocus = !0, this._nextCalendarView = "year", this._startTableTransition();
475
- }}
471
+ this._resetFocus = !0, this._nextCalendarView = "year", this._startTableTransition();
472
+ }}
476
473
  >
477
474
  ${t}
478
475
  <sbb-icon name="chevron-small-down-small"></sbb-icon>
479
476
  </button>
480
477
  `;
481
- }
482
- /** Creates the aria-label for the daily view. */
483
- _createAriaLabelForDayView(...e) {
484
- let t = "";
485
- for (const a of e)
486
- a && (t += `${this._monthNames[this._dateAdapter.getMonth(a) - 1]} ${this._dateAdapter.getYear(a)} `);
487
- return t;
488
- }
489
- /** Creates the calendar table for the daily view. */
490
- _createDayTable(e) {
491
- return o`
478
+ }
479
+ /** Creates the aria-label for the daily view. */
480
+ _createAriaLabelForDayView(...e) {
481
+ let t = "";
482
+ for (const a of e)
483
+ a && (t += `${this._monthNames[this._dateAdapter.getMonth(a) - 1]} ${this._dateAdapter.getYear(a)} `);
484
+ return t;
485
+ }
486
+ /** Creates the calendar table for the daily view. */
487
+ _createDayTable(e) {
488
+ return n`
492
489
  <table
493
490
  class="sbb-calendar__table"
494
491
  @focusout=${(t) => this._handleTableBlur(t.relatedTarget)}
@@ -504,343 +501,291 @@ let l = class extends B(M) {
504
501
  </tbody>
505
502
  </table>
506
503
  `;
507
- }
508
- /** Creates the table header with the month header cells. */
509
- _createDayTableHeader() {
510
- return this._weekdays.map(
511
- (e) => o`
504
+ }
505
+ /** Creates the table header with the month header cells. */
506
+ _createDayTableHeader() {
507
+ return this._weekdays.map((e) => n`
512
508
  <th class="sbb-calendar__table-header">
513
509
  <sbb-screen-reader-only>${e.long}</sbb-screen-reader-only>
514
510
  <span aria-hidden="true">${e.narrow}</span>
515
511
  </th>
516
- `
517
- );
518
- }
519
- /** Creates the table body with the day cells. For the first row, it also considers the possible day's offset. */
520
- _createDayTableBody(e) {
521
- const t = this._dateAdapter.toIso8601(this.now);
522
- return e.map((a, r) => {
523
- const s = y - a.length;
524
- return r === 0 && s ? o`
512
+ `);
513
+ }
514
+ /** Creates the table body with the day cells. For the first row, it also considers the possible day's offset. */
515
+ _createDayTableBody(e) {
516
+ const t = this._dateAdapter.toIso8601(this.now);
517
+ return e.map((a, s) => {
518
+ const i = O - a.length;
519
+ return s === 0 && i ? n`
525
520
  <tr>
526
- ${[...Array(s).keys()].map(
527
- () => o`<td
521
+ ${[...Array(i).keys()].map(() => n`<td
528
522
  class="sbb-calendar__table-data"
529
523
  data-day=${`0 ${a[0].monthValue} ${a[0].yearValue}`}
530
- ></td>`
531
- )}
524
+ ></td>`)}
532
525
  ${this._createDayCells(a, t)}
533
526
  </tr>
534
- ` : o`<tr>
527
+ ` : n`<tr>
535
528
  ${this._createDayCells(a, t)}
536
529
  </tr>`;
537
- });
538
- }
539
- /** Creates the cells for the daily view. */
540
- _createDayCells(e, t) {
541
- return e.map((a) => {
542
- const r = !this._isDayInRange(a.value), s = !this._dateFilter(this._dateAdapter.deserialize(a.value)), i = !!this._selected && a.value === this._selected, n = `${a.dayValue} ${a.monthValue} ${a.yearValue}`, c = a.value === t;
543
- return o`
530
+ });
531
+ }
532
+ /** Creates the cells for the daily view. */
533
+ _createDayCells(e, t) {
534
+ return e.map((a) => {
535
+ const s = !this._isDayInRange(a.value), i = !this._dateFilter(this._dateAdapter.deserialize(a.value)), r = !!this._selected && a.value === this._selected, d = `${a.dayValue} ${a.monthValue} ${a.yearValue}`, _ = a.value === t;
536
+ return n`
544
537
  <td
545
- class=${p({
546
- "sbb-calendar__table-data": !0,
547
- "sbb-calendar__table-data-selected": i
548
- })}
538
+ class=${R({
539
+ "sbb-calendar__table-data": !0,
540
+ "sbb-calendar__table-data-selected": r
541
+ })}
549
542
  >
550
543
  <button
551
- class=${p({
552
- "sbb-calendar__cell": !0,
553
- "sbb-calendar__day": !0,
554
- "sbb-calendar__cell-current": c,
555
- "sbb-calendar__selected": i,
556
- "sbb-calendar__crossed-out": !r && s
557
- })}
544
+ class=${R({
545
+ "sbb-calendar__cell": !0,
546
+ "sbb-calendar__day": !0,
547
+ "sbb-calendar__cell-current": _,
548
+ "sbb-calendar__selected": r,
549
+ "sbb-calendar__crossed-out": !s && i
550
+ })}
558
551
  @click=${() => this._selectDate(a.value)}
559
- ?disabled=${r || s}
552
+ ?disabled=${s || i}
560
553
  aria-label=${this._dateAdapter.getAccessibilityFormatDate(a.value)}
561
- aria-pressed=${i}
562
- aria-disabled=${r || s}
563
- aria-current=${c ? "date" : h}
564
- data-day=${n || h}
554
+ aria-pressed=${r}
555
+ aria-disabled=${s || i}
556
+ aria-current=${_ ? "date" : g}
557
+ data-day=${d || g}
565
558
  tabindex="-1"
566
- @keydown=${(u) => this._handleKeyboardEvent(u, a)}
559
+ @keydown=${(y) => this._handleKeyboardEvent(y, a)}
567
560
  sbb-popover-close
568
561
  >
569
562
  ${a.dayValue}
570
563
  </button>
571
564
  </td>
572
565
  `;
573
- });
574
- }
575
- /** Render the view for the month selection. */
576
- _renderMonthView() {
577
- return o`
566
+ });
567
+ }
568
+ /** Render the view for the month selection. */
569
+ _renderMonthView() {
570
+ return n`
578
571
  <div class="sbb-calendar__controls">
579
- ${this._getArrow(
580
- "left",
581
- () => this._goToDifferentYear(-1),
582
- W[this._language.current],
583
- this._previousYearDisabled()
584
- )}
572
+ ${this._getArrow("left", () => this._goToDifferentYear(-1), Fe[this._language.current], this._previousYearDisabled())}
585
573
  <div class="sbb-calendar__controls-month">${this._createLabelForMonthView()}</div>
586
- ${this._getArrow(
587
- "right",
588
- () => this._goToDifferentYear(1),
589
- E[this._language.current],
590
- this._nextYearDisabled()
591
- )}
574
+ ${this._getArrow("right", () => this._goToDifferentYear(1), Re[this._language.current], this._nextYearDisabled())}
592
575
  </div>
593
576
  <div class="sbb-calendar__table-container sbb-calendar__table-month-view">
594
577
  ${this._createMonthTable(this._months, this._chosenYear)}
595
- ${this._wide ? this._createMonthTable(this._months, this._chosenYear + 1, !0) : h}
578
+ ${this._wide ? this._createMonthTable(this._months, this._chosenYear + 1) : g}
596
579
  </div>
597
580
  `;
598
- }
599
- /** Creates the label with the year for the monthly view. */
600
- _createLabelForMonthView() {
601
- return o` <button
581
+ }
582
+ /** Creates the label with the year for the monthly view. */
583
+ _createLabelForMonthView() {
584
+ return n` <button
602
585
  type="button"
603
586
  id="sbb-calendar__month-selection"
604
587
  class="sbb-calendar__controls-change-date"
605
- aria-label=${`${D[this._language.current]} ${this._chosenYear}`}
588
+ aria-label=${`${me[this._language.current]} ${this._chosenYear}`}
606
589
  @click=${() => this._resetCalendarView(!0)}
607
590
  >
608
- ${this._chosenYear} ${this._wide ? ` - ${this._chosenYear + 1}` : h}
591
+ ${this._chosenYear} ${this._wide ? ` - ${this._chosenYear + 1}` : g}
609
592
  <sbb-icon name="chevron-small-up-small"></sbb-icon>
610
593
  </button>
611
594
  <sbb-screen-reader-only role="status"> ${this._chosenYear} </sbb-screen-reader-only>`;
612
- }
613
- /** Creates the table for the month selection view. */
614
- _createMonthTable(e, t, a = !1) {
615
- return o`
595
+ }
596
+ /** Creates the table for the month selection view. */
597
+ _createMonthTable(e, t) {
598
+ return n`
616
599
  <table
617
600
  class="sbb-calendar__table"
618
- @animationend=${(r) => this._tableAnimationEnd(r)}
601
+ @animationend=${(a) => this._tableAnimationEnd(a)}
619
602
  >
620
- ${this._wide ? o`<thead class="sbb-calendar__table-header" aria-hidden="true">
603
+ ${this._wide ? n`<thead class="sbb-calendar__table-header" aria-hidden="true">
621
604
  <tr class="sbb-calendar__table-header-row">
622
- <th class="sbb-calendar__table-header" colspan=${g}>${t}</th>
605
+ <th class="sbb-calendar__table-header" colspan=${I}>${t}</th>
623
606
  </tr>
624
- </thead>` : h}
607
+ </thead>` : g}
625
608
  <tbody class="sbb-calendar__table-body">
626
- ${e.map(
627
- (r) => o`
609
+ ${e.map((a) => n`
628
610
  <tr>
629
- ${r.map((s) => {
630
- const i = !this._isMonthInRange(s.monthValue), n = !this._isMonthFilteredOut(s.monthValue), c = this._selected ? this._dateAdapter.getMonth(this._dateAdapter.deserialize(this._selected)) : void 0, u = this._selected ? this._dateAdapter.getYear(this._dateAdapter.deserialize(this._selected)) : void 0, m = !!this._selected && t === u && s.monthValue === c, w = t === this._dateAdapter.getYear(this.now) && this._dateAdapter.getMonth(this.now) === s.monthValue;
631
- return o` <td
632
- class=${p({
611
+ ${a.map((s) => {
612
+ const i = !this._isMonthInRange(s.monthValue, t), r = !this._isMonthFilteredOut(s.monthValue, t), d = this._selected ? this._dateAdapter.getMonth(this._dateAdapter.deserialize(this._selected)) : void 0, _ = this._selected ? this._dateAdapter.getYear(this._dateAdapter.deserialize(this._selected)) : void 0, y = !!this._selected && t === _ && s.monthValue === d, T = t === this._dateAdapter.getYear(this.now) && this._dateAdapter.getMonth(this.now) === s.monthValue;
613
+ return n` <td
614
+ class=${R({
633
615
  "sbb-calendar__table-data": !0,
634
616
  "sbb-calendar__table-month": !0
635
617
  })}
636
618
  >
637
619
  <button
638
- class=${p({
620
+ class=${R({
639
621
  "sbb-calendar__cell": !0,
640
622
  "sbb-calendar__pill": !0,
641
- "sbb-calendar__cell-current": w,
642
- "sbb-calendar__crossed-out": !i && n,
643
- "sbb-calendar__selected": m
623
+ "sbb-calendar__cell-current": T,
624
+ "sbb-calendar__crossed-out": !i && r,
625
+ "sbb-calendar__selected": y
644
626
  })}
645
- @click=${() => this._onMonthSelection(s.monthValue, t, a)}
646
- ?disabled=${i || n}
647
- aria-label=${`${s.longValue} ${this._chosenYear}`}
648
- aria-pressed=${m}
649
- aria-disabled=${String(i || n)}
627
+ @click=${() => this._onMonthSelection(s.monthValue, t)}
628
+ ?disabled=${i || r}
629
+ aria-label=${`${s.longValue} ${t}`}
630
+ aria-pressed=${y}
631
+ aria-disabled=${String(i || r)}
650
632
  tabindex="-1"
651
- data-month=${s.monthValue || h}
652
- @keydown=${(Y) => this._handleKeyboardEvent(Y)}
633
+ data-month=${s.monthValue || g}
634
+ @keydown=${(N) => this._handleKeyboardEvent(N)}
653
635
  >
654
636
  ${s.value}
655
637
  </button>
656
638
  </td>`;
657
639
  })}
658
640
  </tr>
659
- `
660
- )}
641
+ `)}
661
642
  </tbody>
662
643
  </table>
663
644
  `;
664
- }
665
- /** Select the month and change the view to day selection. */
666
- _onMonthSelection(e, t, a) {
667
- this._chosenMonth = a ? e + 1 : e, this._nextCalendarView = "day", this._init(
668
- this._dateAdapter.createDate(
669
- t,
670
- this._chosenMonth,
671
- this._dateAdapter.getDate(this._activeDate)
672
- )
673
- ), this._startTableTransition();
674
- }
675
- /** Render the view for the year selection. */
676
- _renderYearView() {
677
- return o`
645
+ }
646
+ /** Select the month and change the view to day selection. */
647
+ _onMonthSelection(e, t) {
648
+ this._chosenMonth = e, this._nextCalendarView = "day", this._init(this._dateAdapter.createDate(t, this._chosenMonth, this._dateAdapter.getDate(this._activeDate))), this._startTableTransition();
649
+ }
650
+ /** Render the view for the year selection. */
651
+ _renderYearView() {
652
+ return n`
678
653
  <div class="sbb-calendar__controls">
679
- ${this._getArrow(
680
- "left",
681
- () => this._goToDifferentYearRange(-d),
682
- L(d)[this._language.current],
683
- this._previousYearRangeDisabled()
684
- )}
654
+ ${this._getArrow("left", () => this._goToDifferentYearRange(-b), Ie(b)[this._language.current], this._previousYearRangeDisabled())}
685
655
  <div class="sbb-calendar__controls-month">${this._createLabelForYearView()}</div>
686
- ${this._getArrow(
687
- "right",
688
- () => this._goToDifferentYearRange(d),
689
- P(d)[this._language.current],
690
- this._nextYearRangeDisabled()
691
- )}
656
+ ${this._getArrow("right", () => this._goToDifferentYearRange(b), Ce(b)[this._language.current], this._nextYearRangeDisabled())}
692
657
  </div>
693
658
  <div class="sbb-calendar__table-container sbb-calendar__table-year-view">
694
659
  ${this._createYearTable(this._years)}
695
- ${this._wide ? this._createYearTable(this._nextMonthYears, !0) : h}
660
+ ${this._wide ? this._createYearTable(this._nextMonthYears, !0) : g}
696
661
  </div>
697
662
  `;
698
- }
699
- /** Creates the button arrow for all the views. */
700
- _getArrow(e, t, a, r) {
701
- return o`<sbb-secondary-button
663
+ }
664
+ /** Creates the button arrow for all the views. */
665
+ _getArrow(e, t, a, s) {
666
+ return n`<sbb-secondary-button
702
667
  size="m"
703
668
  icon-name="chevron-small-${e}-small"
704
669
  aria-label=${a}
705
670
  @click=${t}
706
- ?disabled=${r}
671
+ ?disabled=${s}
707
672
  id="sbb-calendar__controls-${e === "left" ? "previous" : "next"}"
708
673
  ></sbb-secondary-button>`;
709
- }
710
- /** Creates the label with the year range for the yearly view. */
711
- _createLabelForYearView() {
712
- const e = this._years.flat()[0], t = (A("medium") && this.wide ? this._nextMonthYears : this._years).flat(), a = t[t.length - 1], r = `${e} - ${a}`;
713
- return o`
674
+ }
675
+ /** Creates the label with the year range for the yearly view. */
676
+ _createLabelForYearView() {
677
+ const e = this._years.flat()[0], t = (this._wide ? this._nextMonthYears : this._years).flat(), a = t[t.length - 1], s = `${e} - ${a}`;
678
+ return n`
714
679
  <button
715
680
  type="button"
716
681
  id="sbb-calendar__year-selection"
717
682
  class="sbb-calendar__controls-change-date"
718
- aria-label="${D[this._language.current]} ${r}"
683
+ aria-label="${me[this._language.current]} ${s}"
719
684
  @click=${() => this._resetCalendarView(!0)}
720
685
  >
721
- ${r}
686
+ ${s}
722
687
  <sbb-icon name="chevron-small-up-small"></sbb-icon>
723
688
  </button>
724
- <sbb-screen-reader-only role="status"> ${r} </sbb-screen-reader-only>
689
+ <sbb-screen-reader-only role="status"> ${s} </sbb-screen-reader-only>
725
690
  `;
726
- }
727
- /** Creates the table for the year selection view. */
728
- _createYearTable(e, t = !1) {
729
- const a = this.now;
730
- return o` <table
691
+ }
692
+ /** Creates the table for the year selection view. */
693
+ _createYearTable(e, t = !1) {
694
+ const a = this.now;
695
+ return n` <table
731
696
  class="sbb-calendar__table"
732
- @animationend=${(r) => this._tableAnimationEnd(r)}
697
+ @animationend=${(s) => this._tableAnimationEnd(s)}
733
698
  >
734
699
  <tbody class="sbb-calendar__table-body">
735
- ${e.map(
736
- (r) => o` <tr>
737
- ${r.map((s) => {
738
- const i = !this._isYearInRange(s), n = !this._isYearFilteredOut(s), c = this._selected ? this._dateAdapter.getYear(this._dateAdapter.deserialize(this._selected)) : void 0, u = !!this._selected && s === c, m = this._dateAdapter.getYear(a) === s;
739
- return o` <td class="sbb-calendar__table-data sbb-calendar__table-year">
700
+ ${e.map((s) => n` <tr>
701
+ ${s.map((i) => {
702
+ const r = !this._isYearInRange(i), d = !this._isYearFilteredOut(i), _ = this._selected ? this._dateAdapter.getYear(this._dateAdapter.deserialize(this._selected)) : void 0, y = !!this._selected && i === _, T = this._dateAdapter.getYear(a) === i;
703
+ return n` <td class="sbb-calendar__table-data sbb-calendar__table-year">
740
704
  <button
741
- class=${p({
705
+ class=${R({
742
706
  "sbb-calendar__cell": !0,
743
707
  "sbb-calendar__pill": !0,
744
- "sbb-calendar__cell-current": m,
745
- "sbb-calendar__crossed-out": !i && n,
746
- "sbb-calendar__selected": u
708
+ "sbb-calendar__cell-current": T,
709
+ "sbb-calendar__crossed-out": !r && d,
710
+ "sbb-calendar__selected": y
747
711
  })}
748
- @click=${() => this._onYearSelection(s, t)}
749
- ?disabled=${i || n}
750
- aria-label=${s}
751
- aria-pressed=${u}
752
- aria-disabled=${String(i || n)}
712
+ @click=${() => this._onYearSelection(i, t)}
713
+ ?disabled=${r || d}
714
+ aria-label=${i}
715
+ aria-pressed=${y}
716
+ aria-disabled=${String(r || d)}
753
717
  tabindex="-1"
754
- data-year=${s || h}
755
- @keydown=${(w) => this._handleKeyboardEvent(w)}
718
+ data-year=${i || g}
719
+ @keydown=${(N) => this._handleKeyboardEvent(N)}
756
720
  >
757
- ${s}
721
+ ${i}
758
722
  </button>
759
723
  </td>`;
760
724
  })}
761
- </tr>`
762
- )}
725
+ </tr>`)}
763
726
  </tbody>
764
727
  </table>`;
765
- }
766
- /** Select the year and change the view to month selection. */
767
- _onYearSelection(e, t) {
768
- this._chosenYear = t ? e - 1 : e, this._nextCalendarView = "month", this._assignActiveDate(
769
- this._dateAdapter.createDate(
770
- this._chosenYear,
771
- this._dateAdapter.getMonth(this._activeDate),
772
- this._dateAdapter.getDate(this._activeDate)
773
- )
774
- ), this._startTableTransition();
775
- }
776
- _getView() {
777
- if (x || this.hydrationRequired)
778
- return o`${h}`;
779
- switch (this._calendarView) {
780
- case "year":
781
- return this._renderYearView();
782
- case "month":
783
- return this._renderMonthView();
784
- case "day":
785
- default:
786
- return this._renderDayView();
787
- }
788
- }
789
- _tableAnimationEnd(e) {
790
- const t = e.target;
791
- e.animationName === "hide" ? (t.classList.remove("sbb-calendar__table-hide"), this._resetFocus = !0, this._calendarView = this._nextCalendarView) : e.animationName === "show" && this.removeAttribute("data-transition");
792
- }
793
- _startTableTransition() {
794
- var e, t;
795
- this.toggleAttribute("data-transition", !0), (t = (e = this.shadowRoot) == null ? void 0 : e.querySelectorAll("table")) == null || t.forEach((a) => a.classList.toggle("sbb-calendar__table-hide"));
796
- }
797
- render() {
798
- return o`<div class="sbb-calendar__wrapper">${this._getView()}</div>`;
799
- }
800
- };
801
- l.styles = q;
802
- l.events = {
803
- dateSelected: "dateSelected"
804
- };
805
- b([
806
- _({ type: Boolean })
807
- ], l.prototype, "wide", 2);
808
- b([
809
- _()
810
- ], l.prototype, "view", 2);
811
- b([
812
- _()
813
- ], l.prototype, "min", 1);
814
- b([
815
- _()
816
- ], l.prototype, "max", 1);
817
- b([
818
- _()
819
- ], l.prototype, "now", 1);
820
- b([
821
- _()
822
- ], l.prototype, "selected", 1);
823
- b([
824
- _({ attribute: "date-filter" })
825
- ], l.prototype, "dateFilter", 2);
826
- b([
827
- f()
828
- ], l.prototype, "_activeDate", 2);
829
- b([
830
- f()
831
- ], l.prototype, "_selected", 2);
832
- b([
833
- f()
834
- ], l.prototype, "_wide", 1);
835
- b([
836
- f()
837
- ], l.prototype, "_calendarView", 2);
838
- b([
839
- f()
840
- ], l.prototype, "_initialized", 2);
841
- l = b([
842
- V("sbb-calendar")
843
- ], l);
728
+ }
729
+ /** Select the year and change the view to month selection. */
730
+ _onYearSelection(e, t) {
731
+ 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();
732
+ }
733
+ _getView() {
734
+ if (ue || this.hydrationRequired)
735
+ return n`${g}`;
736
+ switch (this._calendarView) {
737
+ case "year":
738
+ return this._renderYearView();
739
+ case "month":
740
+ return this._renderMonthView();
741
+ case "day":
742
+ default:
743
+ return this._renderDayView();
744
+ }
745
+ }
746
+ _tableAnimationEnd(e) {
747
+ const t = e.target;
748
+ e.animationName === "hide" ? (t.classList.remove("sbb-calendar__table-hide"), this._resetFocus = !0, this._calendarView = this._nextCalendarView) : e.animationName === "show" && this.removeAttribute("data-transition");
749
+ }
750
+ _startTableTransition() {
751
+ var e, t;
752
+ this.toggleAttribute("data-transition", !0), (t = (e = this.shadowRoot) == null ? void 0 : e.querySelectorAll("table")) == null || t.forEach((a) => a.classList.toggle("sbb-calendar__table-hide"));
753
+ }
754
+ render() {
755
+ return n`<div class="sbb-calendar__wrapper">${this._getView()}</div>`;
756
+ }
757
+ }, D = new WeakMap(), $ = new WeakMap(), Y = new WeakMap(), M = new WeakMap(), k = new WeakMap(), V = new WeakMap(), z = new WeakMap(), p = l, (() => {
758
+ const e = typeof Symbol == "function" && Symbol.metadata ? Object.create(E[Symbol.metadata] ?? null) : void 0;
759
+ W = [$e(), A({ type: Boolean })], B = [A()], H = [A()], U = [A()], j = [A()], G = [A()], J = [A({ attribute: "date-filter" })], Z = [F()], ae = [F()], re = [F()], ne = [F()], oe = [F()], f(l, null, W, { kind: "accessor", name: "wide", static: !1, private: !1, access: { has: (t) => "wide" in t, get: (t) => t.wide, set: (t, a) => {
760
+ t.wide = a;
761
+ } }, metadata: e }, L, P), f(l, null, B, { kind: "accessor", name: "view", static: !1, private: !1, access: { has: (t) => "view" in t, get: (t) => t.view, set: (t, a) => {
762
+ t.view = a;
763
+ } }, metadata: e }, q, K), f(l, null, H, { kind: "setter", name: "min", static: !1, private: !1, access: { has: (t) => "min" in t, set: (t, a) => {
764
+ t.min = a;
765
+ } }, metadata: e }, null, x), f(l, null, U, { kind: "setter", name: "max", static: !1, private: !1, access: { has: (t) => "max" in t, set: (t, a) => {
766
+ t.max = a;
767
+ } }, metadata: e }, null, x), f(l, null, j, { kind: "setter", name: "now", static: !1, private: !1, access: { has: (t) => "now" in t, set: (t, a) => {
768
+ t.now = a;
769
+ } }, metadata: e }, null, x), f(l, null, G, { kind: "setter", name: "selected", static: !1, private: !1, access: { has: (t) => "selected" in t, set: (t, a) => {
770
+ t.selected = a;
771
+ } }, metadata: e }, null, x), f(l, null, J, { kind: "accessor", name: "dateFilter", static: !1, private: !1, access: { has: (t) => "dateFilter" in t, get: (t) => t.dateFilter, set: (t, a) => {
772
+ t.dateFilter = a;
773
+ } }, metadata: e }, Q, X), f(l, null, Z, { kind: "accessor", name: "_activeDate", static: !1, private: !1, access: { has: (t) => "_activeDate" in t, get: (t) => t._activeDate, set: (t, a) => {
774
+ t._activeDate = a;
775
+ } }, metadata: e }, ee, te), f(l, null, ae, { kind: "accessor", name: "_selected", static: !1, private: !1, access: { has: (t) => "_selected" in t, get: (t) => t._selected, set: (t, a) => {
776
+ t._selected = a;
777
+ } }, metadata: e }, se, ie), f(l, null, re, { kind: "setter", name: "_wide", static: !1, private: !1, access: { has: (t) => "_wide" in t, set: (t, a) => {
778
+ t._wide = a;
779
+ } }, metadata: e }, null, x), f(l, null, ne, { kind: "accessor", name: "_calendarView", static: !1, private: !1, access: { has: (t) => "_calendarView" in t, get: (t) => t._calendarView, set: (t, a) => {
780
+ t._calendarView = a;
781
+ } }, metadata: e }, le, de), f(l, null, oe, { kind: "accessor", name: "_initialized", static: !1, private: !1, access: { has: (t) => "_initialized" in t, get: (t) => t._initialized, set: (t, a) => {
782
+ t._initialized = a;
783
+ } }, metadata: e }, ce, be), f(null, h = { value: p }, o, { kind: "class", name: p.name, metadata: e }, null, m), S = p = h.value, e && Object.defineProperty(p, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: e });
784
+ })(), l.styles = Te, l.events = {
785
+ dateSelected: "dateSelected"
786
+ }, c(p, m), l);
787
+ return S = p;
788
+ })();
844
789
  export {
845
- l as SbbCalendarElement
790
+ tt as SbbCalendarElement
846
791
  };