@sbb-esta/lyne-elements 2.2.0 → 2.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (392) hide show
  1. package/accordion.js +6 -6
  2. package/alert/alert-group.js +4 -4
  3. package/alert/alert.js +9 -9
  4. package/autocomplete/autocomplete-base-element.d.ts +1 -0
  5. package/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  6. package/autocomplete/autocomplete.d.ts.map +1 -1
  7. package/autocomplete-grid/autocomplete-grid/autocomplete-grid.d.ts.map +1 -1
  8. package/autocomplete-grid/autocomplete-grid-button.js +4 -4
  9. package/autocomplete-grid/autocomplete-grid-optgroup.js +4 -4
  10. package/autocomplete-grid/autocomplete-grid-row.js +4 -4
  11. package/autocomplete-grid/autocomplete-grid.js +0 -1
  12. package/autocomplete.js +29 -29
  13. package/badge.css +31 -0
  14. package/breadcrumb/breadcrumb-group.js +4 -4
  15. package/breadcrumb/breadcrumb.js +19 -19
  16. package/button/accent-button-link.js +9 -9
  17. package/button/accent-button-static.js +6 -6
  18. package/button/accent-button.js +6 -6
  19. package/button/button-link.js +7 -7
  20. package/button/button-static.js +7 -7
  21. package/button/button.js +8 -8
  22. package/button/common/button-common.d.ts.map +1 -1
  23. package/button/common.js +1 -1
  24. package/button/mini-button-group.js +8 -8
  25. package/button/secondary-button-link.js +7 -7
  26. package/button/secondary-button-static.js +7 -7
  27. package/button/secondary-button.js +3 -3
  28. package/button/transparent-button-link.js +6 -6
  29. package/button/transparent-button-static.js +5 -5
  30. package/button/transparent-button.js +6 -6
  31. package/calendar/calendar.d.ts +55 -11
  32. package/calendar/calendar.d.ts.map +1 -1
  33. package/calendar.js +374 -224
  34. package/card/card-badge.js +9 -9
  35. package/card/card-button.js +5 -5
  36. package/card/card-link.js +7 -7
  37. package/card/card.js +1 -1
  38. package/card/common/card-action-common.d.ts.map +1 -1
  39. package/checkbox/checkbox-group/checkbox-group.d.ts.map +1 -1
  40. package/checkbox/checkbox-group.js +1 -1
  41. package/checkbox/checkbox-panel.js +16 -16
  42. package/checkbox/checkbox.js +15 -15
  43. package/checkbox/common/checkbox-common.d.ts.map +1 -1
  44. package/checkbox/common.js +3 -3
  45. package/clock.js +8 -8
  46. package/container/container.js +4 -4
  47. package/core/base-elements.js +10 -10
  48. package/core/controllers/escapable-overlay-controller.d.ts +11 -0
  49. package/core/controllers/escapable-overlay-controller.d.ts.map +1 -0
  50. package/core/controllers.d.ts +1 -0
  51. package/core/controllers.d.ts.map +1 -1
  52. package/core/controllers.js +73 -47
  53. package/core/datetime/date-adapter.d.ts +4 -2
  54. package/core/datetime/date-adapter.d.ts.map +1 -1
  55. package/core/datetime/native-date-adapter.d.ts +1 -1
  56. package/core/datetime/native-date-adapter.d.ts.map +1 -1
  57. package/core/datetime.js +51 -43
  58. package/core/decorators/date-converter.d.ts +8 -0
  59. package/core/decorators/date-converter.d.ts.map +1 -0
  60. package/core/decorators/date-only-type.d.ts +8 -0
  61. package/core/decorators/date-only-type.d.ts.map +1 -0
  62. package/core/decorators/get-override.d.ts.map +1 -1
  63. package/core/decorators/handle-distinct-change.d.ts.map +1 -1
  64. package/core/decorators/host-attributes.d.ts.map +1 -1
  65. package/core/decorators/slot-state.d.ts.map +1 -1
  66. package/core/decorators.d.ts +2 -0
  67. package/core/decorators.d.ts.map +1 -1
  68. package/core/decorators.js +52 -31
  69. package/core/dom/input-element.d.ts +1 -1
  70. package/core/dom/input-element.d.ts.map +1 -1
  71. package/core/dom.js +5 -5
  72. package/core/eventing/throttle.d.ts.map +1 -1
  73. package/core/eventing.js +4 -4
  74. package/core/i18n/i18n.d.ts +6 -0
  75. package/core/i18n/i18n.d.ts.map +1 -1
  76. package/core/i18n.js +106 -70
  77. package/core/mixins/disabled-mixin.d.ts.map +1 -1
  78. package/core/mixins/form-associated-checkbox-mixin.d.ts.map +1 -1
  79. package/core/mixins/form-associated-input-mixin.d.ts +25 -0
  80. package/core/mixins/form-associated-input-mixin.d.ts.map +1 -0
  81. package/core/mixins/form-associated-mixin.d.ts +16 -0
  82. package/core/mixins/form-associated-mixin.d.ts.map +1 -1
  83. package/core/mixins/form-associated-radio-button-mixin.d.ts.map +1 -1
  84. package/core/mixins/hydration-mixin.d.ts.map +1 -1
  85. package/core/mixins/named-slot-list-mixin.d.ts.map +1 -1
  86. package/core/mixins/negative-mixin.d.ts.map +1 -1
  87. package/core/mixins/panel-mixin.d.ts.map +1 -1
  88. package/core/mixins/required-mixin.d.ts.map +1 -1
  89. package/core/mixins/update-scheduler-mixin.d.ts.map +1 -1
  90. package/core/mixins.d.ts +1 -0
  91. package/core/mixins.d.ts.map +1 -1
  92. package/core/mixins.js +574 -295
  93. package/core/styles/badge.scss +3 -0
  94. package/core/styles/core.scss +3 -1
  95. package/core/styles/mixins/badge.scss +26 -1
  96. package/core/styles/mixins/font-face.scss +12 -12
  97. package/core/styles/mixins/link.scss +32 -8
  98. package/core/styles/standard-theme.scss +1 -0
  99. package/core/testing/mocha-extensions.d.ts.map +1 -1
  100. package/core/testing/wait-for-render.d.ts.map +1 -1
  101. package/core/testing.js +14 -14
  102. package/core.css +5 -5
  103. package/custom-elements.json +28284 -17221
  104. package/date-input/date-input.d.ts +67 -0
  105. package/date-input/date-input.d.ts.map +1 -0
  106. package/date-input.d.ts +2 -0
  107. package/date-input.d.ts.map +1 -0
  108. package/date-input.js +149 -0
  109. package/datepicker/common/datepicker-button.d.ts.map +1 -1
  110. package/datepicker/common.js +49 -45
  111. package/datepicker/datepicker/datepicker.d.ts +16 -6
  112. package/datepicker/datepicker/datepicker.d.ts.map +1 -1
  113. package/datepicker/datepicker-toggle/datepicker-toggle.d.ts.map +1 -1
  114. package/datepicker/datepicker-toggle.js +43 -40
  115. package/datepicker/datepicker.js +94 -76
  116. package/development/alert/alert-group.js +1 -1
  117. package/development/alert/alert.js +1 -1
  118. package/development/autocomplete/autocomplete-base-element.d.ts +1 -0
  119. package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  120. package/development/autocomplete/autocomplete.d.ts.map +1 -1
  121. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.d.ts.map +1 -1
  122. package/development/autocomplete-grid/autocomplete-grid.js +1 -2
  123. package/development/autocomplete.js +10 -5
  124. package/development/breadcrumb/breadcrumb.js +5 -2
  125. package/development/button/common/button-common.d.ts.map +1 -1
  126. package/development/button/common.js +18 -14
  127. package/development/calendar/calendar.d.ts +55 -11
  128. package/development/calendar/calendar.d.ts.map +1 -1
  129. package/development/calendar.js +302 -88
  130. package/development/card/card.js +1 -1
  131. package/development/card/common/card-action-common.d.ts.map +1 -1
  132. package/development/checkbox/checkbox-group/checkbox-group.d.ts.map +1 -1
  133. package/development/checkbox/checkbox-group.js +2 -2
  134. package/development/checkbox/checkbox-panel.js +1 -1
  135. package/development/checkbox/common/checkbox-common.d.ts.map +1 -1
  136. package/development/core/controllers/escapable-overlay-controller.d.ts +11 -0
  137. package/development/core/controllers/escapable-overlay-controller.d.ts.map +1 -0
  138. package/development/core/controllers.d.ts +1 -0
  139. package/development/core/controllers.d.ts.map +1 -1
  140. package/development/core/controllers.js +36 -1
  141. package/development/core/datetime/date-adapter.d.ts +4 -2
  142. package/development/core/datetime/date-adapter.d.ts.map +1 -1
  143. package/development/core/datetime/native-date-adapter.d.ts +1 -1
  144. package/development/core/datetime/native-date-adapter.d.ts.map +1 -1
  145. package/development/core/datetime.js +14 -2
  146. package/development/core/decorators/date-converter.d.ts +8 -0
  147. package/development/core/decorators/date-converter.d.ts.map +1 -0
  148. package/development/core/decorators/date-only-type.d.ts +8 -0
  149. package/development/core/decorators/date-only-type.d.ts.map +1 -0
  150. package/development/core/decorators/get-override.d.ts.map +1 -1
  151. package/development/core/decorators/handle-distinct-change.d.ts.map +1 -1
  152. package/development/core/decorators/host-attributes.d.ts.map +1 -1
  153. package/development/core/decorators/slot-state.d.ts.map +1 -1
  154. package/development/core/decorators.d.ts +2 -0
  155. package/development/core/decorators.d.ts.map +1 -1
  156. package/development/core/decorators.js +23 -2
  157. package/development/core/dom/input-element.d.ts +1 -1
  158. package/development/core/dom/input-element.d.ts.map +1 -1
  159. package/development/core/dom.js +3 -3
  160. package/development/core/eventing/throttle.d.ts.map +1 -1
  161. package/development/core/i18n/i18n.d.ts +6 -0
  162. package/development/core/i18n/i18n.d.ts.map +1 -1
  163. package/development/core/i18n.js +43 -1
  164. package/development/core/mixins/disabled-mixin.d.ts.map +1 -1
  165. package/development/core/mixins/form-associated-checkbox-mixin.d.ts.map +1 -1
  166. package/development/core/mixins/form-associated-input-mixin.d.ts +25 -0
  167. package/development/core/mixins/form-associated-input-mixin.d.ts.map +1 -0
  168. package/development/core/mixins/form-associated-mixin.d.ts +16 -0
  169. package/development/core/mixins/form-associated-mixin.d.ts.map +1 -1
  170. package/development/core/mixins/form-associated-radio-button-mixin.d.ts.map +1 -1
  171. package/development/core/mixins/hydration-mixin.d.ts.map +1 -1
  172. package/development/core/mixins/named-slot-list-mixin.d.ts.map +1 -1
  173. package/development/core/mixins/negative-mixin.d.ts.map +1 -1
  174. package/development/core/mixins/panel-mixin.d.ts.map +1 -1
  175. package/development/core/mixins/required-mixin.d.ts.map +1 -1
  176. package/development/core/mixins/update-scheduler-mixin.d.ts.map +1 -1
  177. package/development/core/mixins.d.ts +1 -0
  178. package/development/core/mixins.d.ts.map +1 -1
  179. package/development/core/mixins.js +460 -32
  180. package/development/core/testing/mocha-extensions.d.ts.map +1 -1
  181. package/development/core/testing/wait-for-render.d.ts.map +1 -1
  182. package/development/date-input/date-input.d.ts +67 -0
  183. package/development/date-input/date-input.d.ts.map +1 -0
  184. package/development/date-input.d.ts +2 -0
  185. package/development/date-input.d.ts.map +1 -0
  186. package/development/date-input.js +259 -0
  187. package/development/datepicker/common/datepicker-button.d.ts.map +1 -1
  188. package/development/datepicker/common.js +11 -2
  189. package/development/datepicker/datepicker/datepicker.d.ts +16 -6
  190. package/development/datepicker/datepicker/datepicker.d.ts.map +1 -1
  191. package/development/datepicker/datepicker-toggle/datepicker-toggle.d.ts.map +1 -1
  192. package/development/datepicker/datepicker-toggle.js +13 -4
  193. package/development/datepicker/datepicker.js +65 -39
  194. package/development/dialog/dialog/dialog.d.ts.map +1 -1
  195. package/development/dialog/dialog-title.js +1 -1
  196. package/development/dialog/dialog.js +3 -1
  197. package/development/expansion-panel/expansion-panel/expansion-panel.d.ts.map +1 -1
  198. package/development/expansion-panel/expansion-panel-header.js +1 -1
  199. package/development/expansion-panel/expansion-panel.js +3 -3
  200. package/development/file-selector/common/file-selector-common.d.ts.map +1 -1
  201. package/development/file-selector/common.js +1 -1
  202. package/development/footer.js +1 -1
  203. package/development/form-field/form-field/form-field.d.ts +1 -1
  204. package/development/form-field/form-field/form-field.d.ts.map +1 -1
  205. package/development/form-field/form-field.js +23 -14
  206. package/development/header/common/header-action-common.d.ts.map +1 -1
  207. package/development/icon/icon-name-mixin.d.ts.map +1 -1
  208. package/development/icon/icon-request.d.ts.map +1 -1
  209. package/development/icon/icon-validate.d.ts.map +1 -1
  210. package/development/image.js +1 -1
  211. package/development/journey-header.js +1 -1
  212. package/development/link/common/block-link-common.d.ts.map +1 -1
  213. package/development/link/common/inline-link-common.d.ts.map +1 -1
  214. package/development/link/common/link-common.d.ts.map +1 -1
  215. package/development/link/common.js +19 -7
  216. package/development/link-list/common.js +1 -1
  217. package/development/map-container.js +1 -1
  218. package/development/menu/common/menu-action-common.d.ts +3 -0
  219. package/development/menu/common/menu-action-common.d.ts.map +1 -1
  220. package/development/menu/common.js +35 -12
  221. package/development/menu/menu/menu.d.ts +1 -1
  222. package/development/menu/menu/menu.d.ts.map +1 -1
  223. package/development/menu/menu.js +5 -15
  224. package/development/navigation/common/navigation-action-common.d.ts.map +1 -1
  225. package/development/navigation/navigation/navigation.d.ts +1 -3
  226. package/development/navigation/navigation/navigation.d.ts.map +1 -1
  227. package/development/navigation/navigation-section.js +1 -1
  228. package/development/navigation/navigation.js +8 -21
  229. package/development/notification.js +1 -1
  230. package/development/overlay/overlay-base-element.d.ts +2 -2
  231. package/development/overlay/overlay-base-element.d.ts.map +1 -1
  232. package/development/overlay/overlay.d.ts.map +1 -1
  233. package/development/overlay.js +7 -14
  234. package/development/paginator/common/paginator-common.d.ts.map +1 -1
  235. package/development/popover/popover/popover.d.ts +1 -1
  236. package/development/popover/popover/popover.d.ts.map +1 -1
  237. package/development/popover/popover.js +5 -15
  238. package/development/radio-button/common/radio-button-common.d.ts.map +1 -1
  239. package/development/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  240. package/development/radio-button/radio-button-group.js +2 -2
  241. package/development/radio-button/radio-button-panel.js +1 -1
  242. package/development/select/select.d.ts +6 -1
  243. package/development/select/select.d.ts.map +1 -1
  244. package/development/select.js +28 -6
  245. package/development/selection-expansion-panel/selection-expansion-panel.d.ts.map +1 -1
  246. package/development/selection-expansion-panel.js +2 -2
  247. package/development/skiplink-list.js +1 -1
  248. package/development/slider.js +1 -1
  249. package/development/stepper/step/step.d.ts +0 -2
  250. package/development/stepper/step/step.d.ts.map +1 -1
  251. package/development/stepper/step.js +1 -16
  252. package/development/stepper/stepper/stepper.d.ts +11 -0
  253. package/development/stepper/stepper/stepper.d.ts.map +1 -1
  254. package/development/stepper/stepper.js +30 -3
  255. package/development/tabs/tab-label.js +1 -1
  256. package/development/tag/tag/tag.d.ts +11 -0
  257. package/development/tag/tag/tag.d.ts.map +1 -1
  258. package/development/tag/tag-group/tag-group.d.ts +1 -1
  259. package/development/tag/tag-group/tag-group.d.ts.map +1 -1
  260. package/development/tag/tag-group.js +9 -3
  261. package/development/tag/tag.js +37 -10
  262. package/development/teaser-product/common/teaser-product-common.d.ts.map +1 -1
  263. package/development/timetable-occupancy.js +1 -1
  264. package/development/toast.js +1 -1
  265. package/development/toggle/toggle/toggle.d.ts +25 -6
  266. package/development/toggle/toggle/toggle.d.ts.map +1 -1
  267. package/development/toggle/toggle-option/toggle-option.d.ts +2 -6
  268. package/development/toggle/toggle-option/toggle-option.d.ts.map +1 -1
  269. package/development/toggle/toggle-option.js +21 -39
  270. package/development/toggle/toggle.js +57 -39
  271. package/development/train/train-formation.js +1 -1
  272. package/development/train/train.js +1 -1
  273. package/development/visual-checkbox.js +1 -1
  274. package/dialog/dialog/dialog.d.ts.map +1 -1
  275. package/dialog/dialog-content.js +3 -3
  276. package/dialog/dialog-title.js +8 -8
  277. package/dialog/dialog.js +2 -2
  278. package/divider.js +12 -12
  279. package/expansion-panel/expansion-panel/expansion-panel.d.ts.map +1 -1
  280. package/expansion-panel/expansion-panel-header.js +1 -1
  281. package/expansion-panel/expansion-panel.js +2 -2
  282. package/file-selector/common/file-selector-common.d.ts.map +1 -1
  283. package/file-selector/common.js +9 -9
  284. package/file-selector/file-selector-dropzone.js +5 -5
  285. package/file-selector/file-selector.js +6 -6
  286. package/flip-card/flip-card-details.js +4 -4
  287. package/flip-card/flip-card-summary.js +9 -9
  288. package/font-characters-extension.css +3 -3
  289. package/footer.js +4 -4
  290. package/form-field/form-field/form-field.d.ts +1 -1
  291. package/form-field/form-field/form-field.d.ts.map +1 -1
  292. package/form-field/form-field.js +32 -24
  293. package/header/common/header-action-common.d.ts.map +1 -1
  294. package/header/header-button.js +5 -5
  295. package/header/header-link.js +5 -5
  296. package/icon/icon-name-mixin.d.ts.map +1 -1
  297. package/icon/icon-request.d.ts.map +1 -1
  298. package/icon/icon-validate.d.ts.map +1 -1
  299. package/icon.js +36 -36
  300. package/image.js +1 -1
  301. package/index.d.ts +2 -0
  302. package/index.js +2 -0
  303. package/journey-header.js +5 -5
  304. package/link/block-link-button.js +4 -4
  305. package/link/block-link-static.js +9 -9
  306. package/link/block-link.js +4 -4
  307. package/link/common/block-link-common.d.ts.map +1 -1
  308. package/link/common/inline-link-common.d.ts.map +1 -1
  309. package/link/common/link-common.d.ts.map +1 -1
  310. package/link/common.js +28 -28
  311. package/link/link-button.js +7 -7
  312. package/link/link-static.js +7 -7
  313. package/link/link.js +4 -4
  314. package/link-list/common.js +15 -15
  315. package/loading-indicator-circle.js +11 -11
  316. package/map-container.js +5 -5
  317. package/menu/common/menu-action-common.d.ts +3 -0
  318. package/menu/common/menu-action-common.d.ts.map +1 -1
  319. package/menu/common.js +34 -30
  320. package/menu/menu/menu.d.ts +1 -1
  321. package/menu/menu/menu.d.ts.map +1 -1
  322. package/menu/menu-button.js +8 -8
  323. package/menu/menu-link.js +6 -6
  324. package/menu/menu.js +29 -38
  325. package/navigation/common/navigation-action-common.d.ts.map +1 -1
  326. package/navigation/navigation/navigation.d.ts +1 -3
  327. package/navigation/navigation/navigation.d.ts.map +1 -1
  328. package/navigation/navigation-button.js +4 -4
  329. package/navigation/navigation-link.js +7 -7
  330. package/navigation/navigation-list.js +4 -4
  331. package/navigation/navigation-marker.js +3 -3
  332. package/navigation/navigation-section.js +1 -1
  333. package/navigation/navigation.js +45 -54
  334. package/notification.js +18 -18
  335. package/option/optgroup.js +11 -11
  336. package/overlay/overlay-base-element.d.ts +2 -2
  337. package/overlay/overlay-base-element.d.ts.map +1 -1
  338. package/overlay/overlay.d.ts.map +1 -1
  339. package/overlay.js +57 -63
  340. package/package.json +11 -2
  341. package/paginator/common/paginator-common.d.ts.map +1 -1
  342. package/paginator/common.js +6 -6
  343. package/popover/popover/popover.d.ts +1 -1
  344. package/popover/popover/popover.d.ts.map +1 -1
  345. package/popover/popover.js +105 -114
  346. package/radio-button/common/radio-button-common.d.ts.map +1 -1
  347. package/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  348. package/radio-button/radio-button-group.js +1 -1
  349. package/radio-button/radio-button-panel.js +6 -6
  350. package/screen-reader-only.js +5 -5
  351. package/select/select.d.ts +6 -1
  352. package/select/select.d.ts.map +1 -1
  353. package/select.js +52 -43
  354. package/selection-expansion-panel/selection-expansion-panel.d.ts.map +1 -1
  355. package/selection-expansion-panel.js +1 -1
  356. package/skiplink-list.js +3 -3
  357. package/slider.js +13 -13
  358. package/standard-theme.css +37 -5
  359. package/status.js +3 -3
  360. package/stepper/step/step.d.ts +0 -2
  361. package/stepper/step/step.d.ts.map +1 -1
  362. package/stepper/step-label.js +4 -4
  363. package/stepper/step.js +24 -36
  364. package/stepper/stepper/stepper.d.ts +11 -0
  365. package/stepper/stepper/stepper.d.ts.map +1 -1
  366. package/stepper/stepper.js +59 -41
  367. package/table/table-wrapper.js +4 -4
  368. package/tabs/tab-group.js +24 -24
  369. package/tabs/tab-label.js +1 -1
  370. package/tabs/tab.js +4 -4
  371. package/tag/tag/tag.d.ts +11 -0
  372. package/tag/tag/tag.d.ts.map +1 -1
  373. package/tag/tag-group/tag-group.d.ts +1 -1
  374. package/tag/tag-group/tag-group.d.ts.map +1 -1
  375. package/tag/tag-group.js +34 -31
  376. package/tag/tag.js +60 -41
  377. package/teaser-product/common/teaser-product-common.d.ts.map +1 -1
  378. package/teaser-product/common.js +5 -5
  379. package/teaser-product/teaser-product-static.js +2 -2
  380. package/timetable-occupancy-icon.js +3 -3
  381. package/timetable-occupancy.js +6 -6
  382. package/toast.js +5 -5
  383. package/toggle/toggle/toggle.d.ts +25 -6
  384. package/toggle/toggle/toggle.d.ts.map +1 -1
  385. package/toggle/toggle-option/toggle-option.d.ts +2 -6
  386. package/toggle/toggle-option/toggle-option.d.ts.map +1 -1
  387. package/toggle/toggle-option.js +44 -52
  388. package/toggle/toggle.js +103 -83
  389. package/toggle-check.js +5 -5
  390. package/train/train-formation.js +1 -1
  391. package/train/train.js +29 -29
  392. package/visual-checkbox.js +1 -1
@@ -12,7 +12,7 @@ import { SbbNamedSlotListMixin as C } from "../core/mixins.js";
12
12
  const M = _`*,:before,:after{box-sizing:border-box}:host{--sbb-navigation-action-gap: var(--sbb-spacing-responsive-xs);--sbb-navigation-marker-position-x: var(--sbb-spacing-fixed-1x);--sbb-navigation-marker-position-y: unset;--sbb-navigation-marker-width: 1.0625rem;--sbb-navigation-marker-border: var(--sbb-border-width-1x);--sbb-navigation-marker-padding-inline-start: var(--sbb-spacing-fixed-6x);--sbb-navigation-marker-typo-line-height: var(--sbb-typo-line-height-titles);--sbb-navigation-margin-inline-start: var(--sbb-spacing-fixed-3x);--sbb-navigation-marker-margin-block: calc( 1em * var(--sbb-navigation-marker-typo-line-height) / 2 - var(--sbb-navigation-marker-border) / 2 );display:block}:host([size=s]){--sbb-navigation-action-gap: var(--sbb-spacing-fixed-2x);--sbb-navigation-marker-width: .5rem;--sbb-navigation-marker-typo-line-height: var(--sbb-typo-line-height-body-text);--sbb-navigation-margin-inline-start: var(--sbb-spacing-fixed-2x);--sbb-navigation-marker-position-x: calc( var(--sbb-navigation-marker-padding-inline-start) - var(--sbb-spacing-fixed-2x) );--sbb-navigation-marker-padding-inline-start: calc( var(--sbb-spacing-fixed-6x) + var(--sbb-spacing-fixed-1x) )}.sbb-navigation-marker{list-style:none;padding:0;font-size:inherit;--sbb-title-line-height: var(--sbb-typo-line-height-titles);--sbb-title-margin-block-start: 0;--sbb-title-margin-block-end: 0;margin:0;margin-block:var(--sbb-title-margin-block-start) var(--sbb-title-margin-block-end);font-family:var(--sbb-typo-font-family);font-weight:700;line-height:var(--sbb-title-line-height);letter-spacing:var(--sbb-typo-letter-spacing-titles);font-size:var(--sbb-title-font-size);--sbb-title-font-size: var(--sbb-font-size-title-4);position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:var(--sbb-navigation-action-gap);padding-inline-start:var(--sbb-navigation-marker-padding-inline-start)}.sbb-navigation-marker:before{content:"";position:absolute;opacity:0;inset-inline-start:var(--sbb-navigation-marker-position-x);inset-block-start:var(--sbb-navigation-marker-position-y);width:var(--sbb-navigation-marker-width);border-block-start:var(--sbb-navigation-marker-border) solid var(--sbb-color-storm);margin-block:var(--sbb-navigation-marker-margin-block);transition-duration:var(--sbb-disable-animation-duration, var(--sbb-animation-duration-6x));transition-timing-function:ease;transition-property:opacity,inset-block-start}:host([data-has-active-action]) .sbb-navigation-marker:before{opacity:1}@media (forced-colors: active){.sbb-navigation-marker:before{border-color:CanvasText}}:host([size=s]) .sbb-navigation-marker{--sbb-text-font-size: var(--sbb-font-size-text-xxs);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}::slotted(:is(sbb-navigation-button,sbb-navigation-link)){margin-inline-start:var(--sbb-navigation-margin-inline-start)}`;
13
13
  let O = (() => {
14
14
  var o, n;
15
- let i = [z("sbb-navigation-marker")], e, a = [], s, v = C(A), g, d = [], m = [];
15
+ let i = [z("sbb-navigation-marker")], e, a = [], s, v = C(A), g, m = [], d = [];
16
16
  return n = class extends v {
17
17
  constructor() {
18
18
  super();
@@ -20,7 +20,7 @@ let O = (() => {
20
20
  this.listChildLocalNames = [
21
21
  "sbb-navigation-button",
22
22
  "sbb-navigation-link"
23
- ], l(this, o, c(this, d, S() ? "s" : "l")), this._currentActiveAction = c(this, m), new y(this, {
23
+ ], l(this, o, c(this, m, S() ? "s" : "l")), this._currentActiveAction = c(this, d), new y(this, {
24
24
  skipInitial: !0,
25
25
  callback: () => this._setMarkerPosition()
26
26
  });
@@ -74,7 +74,7 @@ let O = (() => {
74
74
  const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(v[Symbol.metadata] ?? null) : void 0;
75
75
  g = [w({ reflect: !0 })], x(n, null, g, { kind: "accessor", name: "size", static: !1, private: !1, access: { has: (r) => "size" in r, get: (r) => r.size, set: (r, b) => {
76
76
  r.size = b;
77
- } }, metadata: t }, d, m), x(null, e = { value: s }, i, { kind: "class", name: s.name, metadata: t }, null, a), s = e.value, t && Object.defineProperty(s, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
77
+ } }, metadata: t }, m, d), x(null, e = { value: s }, i, { kind: "class", name: s.name, metadata: t }, null, a), s = e.value, t && Object.defineProperty(s, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
78
78
  })(), n.styles = M, c(s, a), s;
79
79
  })();
80
80
  export {
@@ -4,7 +4,7 @@ var D = (e) => {
4
4
  var R = (e, a, s) => a.has(e) || D("Cannot " + s);
5
5
  var m = (e, a, s) => (R(e, a, "read from private field"), s ? s.call(e) : a.get(e)), _ = (e, a, s) => a.has(e) ? D("Cannot add the same private member more than once") : a instanceof WeakSet ? a.add(e) : a.set(e, s), c = (e, a, s, r) => (R(e, a, "write to private field"), r ? r.call(e, s) : a.set(e, s), s);
6
6
  import { __esDecorate as h, __runInitializers as b } from "tslib";
7
- import { css as K, LitElement as M, html as j, nothing as Z } from "lit";
7
+ import { css as K, LitElement as M, nothing as Z, html as j } from "lit";
8
8
  import { customElement as G, property as p } from "lit/decorators.js";
9
9
  import { ref as $ } from "lit/directives/ref.js";
10
10
  import { setModalityOnNextFocus as P, getFirstFocusableElement as H, getFocusableElements as U } from "../core/a11y.js";
@@ -1,9 +1,9 @@
1
- var A = (e) => {
2
- throw TypeError(e);
1
+ var O = (n) => {
2
+ throw TypeError(n);
3
3
  };
4
- var O = (e, o, s) => o.has(e) || A("Cannot " + s);
5
- var h = (e, o, s) => (O(e, o, "read from private field"), s ? s.call(e) : o.get(e)), m = (e, o, s) => o.has(e) ? A("Cannot add the same private member more than once") : o instanceof WeakSet ? o.add(e) : o.set(e, s), d = (e, o, s, r) => (O(e, o, "write to private field"), r ? r.call(e, s) : o.set(e, s), s);
6
- import { __esDecorate as g, __runInitializers as v } from "tslib";
4
+ var A = (n, e, s) => e.has(n) || O("Cannot " + s);
5
+ var h = (n, e, s) => (A(n, e, "read from private field"), s ? s.call(n) : e.get(n)), m = (n, e, s) => e.has(n) ? O("Cannot add the same private member more than once") : e instanceof WeakSet ? e.add(n) : e.set(n, s), g = (n, e, s, r) => (A(n, e, "write to private field"), r ? r.call(n, s) : e.set(n, s), s);
6
+ import { __esDecorate as d, __runInitializers as v } from "tslib";
7
7
  import { MutationController as D } from "@lit-labs/observers/mutation-controller.js";
8
8
  import { ResizeController as H } from "@lit-labs/observers/resize-controller.js";
9
9
  import { css as B, html as z } from "lit";
@@ -11,43 +11,43 @@ import { customElement as F, property as L, state as P } from "lit/decorators.js
11
11
  import { ref as T } from "lit/directives/ref.js";
12
12
  import { SbbFocusHandler as R, setModalityOnNextFocus as I } from "../core/a11y.js";
13
13
  import { SbbOpenCloseBaseElement as q } from "../core/base-elements.js";
14
- import { SbbLanguageController as M, SbbInertController as U } from "../core/controllers.js";
15
- import { hostAttributes as $, forceType as X } from "../core/decorators.js";
16
- import { SbbScrollHandler as Z, isZeroAnimationDuration as j, findReferencedElement as V } from "../core/dom.js";
17
- import { i18nCloseNavigation as G } from "../core/i18n.js";
14
+ import { SbbLanguageController as M, SbbInertController as U, SbbEscapableOverlayController as $ } from "../core/controllers.js";
15
+ import { hostAttributes as X, forceType as Z } from "../core/decorators.js";
16
+ import { SbbScrollHandler as j, isZeroAnimationDuration as V, findReferencedElement as G } from "../core/dom.js";
17
+ import { i18nCloseNavigation as J } from "../core/i18n.js";
18
18
  import { SbbUpdateSchedulerMixin as K } from "../core/mixins.js";
19
- import { isEventOnElement as u, removeAriaOverlayTriggerAttributes as W, setAriaOverlayTriggerAttributes as J } from "../core/overlay.js";
19
+ import { isEventOnElement as u, removeAriaOverlayTriggerAttributes as Q, setAriaOverlayTriggerAttributes as W } from "../core/overlay.js";
20
20
  import "../button/transparent-button.js";
21
- const Q = B`*,:before,:after{box-sizing:border-box}:host{--sbb-navigation-grid-column: 1 / 5;--sbb-navigation-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-3x) );--sbb-navigation-animation-easing: ease-in;--sbb-navigation-padding-inline: var(--sbb-layout-base-offset-responsive);--sbb-navigation-padding-block-start: var(--sbb-spacing-responsive-l);--sbb-navigation-padding-block-end: var(--sbb-spacing-responsive-xl);--sbb-navigation-backdrop-visibility: hidden;--sbb-navigation-backdrop-pointer-events: none;--sbb-navigation-backdrop-color: transparent;--sbb-navigation-list-margin-block-start: var(--sbb-spacing-responsive-xxl);--sbb-navigation-inline-start: 0;--sbb-navigation-expanded-width: 100%;--sbb-navigation-inset: 0 auto auto 0;--sbb-navigation-transform: translateX(-100%);--sbb-navigation-content-transform: translateX(0);--sbb-navigation-width: 100%;--sbb-navigation-height: 100dvh;--sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);display:none;position:fixed;inset:var(--sbb-navigation-inset);z-index:var(--sbb-navigation-z-index, var(--sbb-overlay-default-z-index));overflow:hidden}@media (min-width: 52.5rem){:host{--sbb-navigation-grid-column: 1 / 9}}@media (min-width: 64rem){:host{--sbb-navigation-grid-column: 1 / 5;--sbb-navigation-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-6x) );--sbb-navigation-padding-block-start: var(--sbb-spacing-responsive-xl);--sbb-navigation-padding-inline: var(--sbb-layout-base-offset-responsive) 0;--sbb-navigation-list-margin-block-start: var(--sbb-spacing-fixed-1x);--sbb-navigation-inline-start: calc(var(--sbb-layout-base-offset-responsive) * -1);--sbb-navigation-width: calc(100% + var(--sbb-layout-base-offset-responsive))}}@media (min-width: 90rem){:host{--sbb-navigation-grid-column: 1 / 6;--sbb-navigation-padding-block-start: var(--sbb-spacing-responsive-xxl)}}:host([data-state]:not([data-state=closed])){display:block}:host([data-state=opened]){--sbb-navigation-animation-easing: ease-out}:host(:is([data-state=opened],[data-state=opening])){--sbb-navigation-backdrop-visibility: visible;--sbb-navigation-backdrop-pointer-events: all;--sbb-navigation-backdrop-color: var(--sbb-color-black-alpha-70)}:host(:not([data-state=closed])){--sbb-navigation-inset: 0;--sbb-navigation-transform: translateX(0)}:host([data-has-navigation-section]){--sbb-navigation-content-transform: translateX(-100%)}@media (min-width: 64rem){:host([data-has-navigation-section]){--sbb-navigation-expanded-width: 100dvw;--sbb-navigation-content-transform: translateX(0%)}}:host([data-resize-disable-animation]){--sbb-disable-animation-duration: 0s}.sbb-navigation__container{display:grid;gap:var(--sbb-grid-base-gutter-responsive);grid-template-columns:repeat(var(--sbb-grid-base-columns),1fr);padding-inline:0;pointer-events:none;transform:var(--sbb-navigation-transform)}@media (min-width: 64rem){.sbb-navigation__container{padding-inline:var(--sbb-layout-base-offset-responsive)}.sbb-navigation__container:before{transition-duration:var(--sbb-navigation-animation-duration);transition-timing-function:var(--sbb-navigation-animation-easing);transition-property:background-color,visibility;content:"";visibility:var(--sbb-navigation-backdrop-visibility);pointer-events:var(--sbb-navigation-backdrop-pointer-events);position:fixed;inset:var(--sbb-navigation-inset);background-color:var(--sbb-navigation-backdrop-color)}}.sbb-navigation{transition-duration:var(--sbb-navigation-animation-duration);transition-timing-function:var(--sbb-navigation-animation-easing);transition-property:width;display:none;width:var(--sbb-navigation-width);grid-column:var(--sbb-navigation-grid-column);padding:0;margin:0;position:relative;inset-inline-start:var(--sbb-navigation-inline-start);inset-block-start:0;border:none;pointer-events:none;height:var(--sbb-navigation-height);color:var(--sbb-color-white);background-color:var(--sbb-color-midnight)}.sbb-navigation:before{transition-duration:var(--sbb-navigation-animation-duration);transition-timing-function:var(--sbb-navigation-animation-easing);transition-property:width;content:"";position:absolute;width:var(--sbb-navigation-expanded-width);height:var(--sbb-navigation-height);background:var(--sbb-color-midnight)}:host([data-state]:not([data-state=closed])) .sbb-navigation{display:block;pointer-events:all;animation-name:open;animation-duration:var(--sbb-navigation-animation-duration);animation-timing-function:var(--sbb-navigation-animation-easing)}:host([data-state][data-state=closing]) .sbb-navigation{pointer-events:none;animation-name:close}@media (forced-colors: active){.sbb-navigation{outline:var(--sbb-border-width-1x) solid CanvasText}}.sbb-navigation__wrapper{outline:none}.sbb-navigation__header{transition-duration:var(--sbb-navigation-animation-duration);transition-timing-function:var(--sbb-navigation-animation-easing);transition-property:width;display:flex;justify-content:flex-end;position:absolute;width:var(--sbb-navigation-expanded-width);pointer-events:none;padding:var(--sbb-spacing-responsive-xs);z-index:calc(var(--sbb-navigation-z-index, var(--sbb-overlay-default-z-index)) + 1)}.sbb-navigation__close{pointer-events:all}.sbb-navigation__content{transition-duration:var(--sbb-navigation-animation-duration);transition-timing-function:var(--sbb-navigation-animation-easing);transition-property:transform;--sbb-scrollbar-thumb-width: .125rem;--sbb-scrollbar-thumb-width-hover: .25rem;--sbb-scrollbar-width-firefox: thin;--sbb-scrollbar-color: var(--sbb-color-white-alpha-30);--sbb-scrollbar-color-hover: var(--sbb-color-white-alpha-60);--sbb-scrollbar-track-color: transparent;--sbb-scrollbar-width: var(--sbb-spacing-fixed-3x)}.sbb-navigation__content::-webkit-scrollbar{width:var(--sbb-scrollbar-width);height:var(--sbb-scrollbar-width);background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-navigation__content::-webkit-scrollbar-corner{background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-navigation__content::-webkit-scrollbar-thumb{background-color:var(--sbb-scrollbar-color, currentcolor);border:calc(.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width))) solid transparent;border-radius:var(--sbb-border-radius-4x);background-clip:padding-box}.sbb-navigation__content::-webkit-scrollbar-thumb:hover{background-color:var(--sbb-scrollbar-color-hover, currentcolor);border-width:calc(.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width-hover)))}.sbb-navigation__content::-webkit-scrollbar-button,.sbb-navigation__content::-webkit-scrollbar-corner{display:none}@supports not selector(::-webkit-scrollbar){.sbb-navigation__content{scrollbar-width:var(--sbb-scrollbar-width-firefox);scrollbar-color:var(--sbb-scrollbar-color, currentcolor) var(--sbb-scrollbar-track-color, transparent)}}.sbb-navigation__content{display:flex;flex-direction:column;gap:var(--sbb-spacing-responsive-xxl);position:relative;height:var(--sbb-navigation-height);padding-inline:var(--sbb-navigation-padding-inline);padding-block:var(--sbb-navigation-padding-block-start) var(--sbb-navigation-padding-block-end);overflow-y:auto;transform:var(--sbb-navigation-content-transform)}::slotted(:first-child){margin-block-start:var(--sbb-navigation-list-margin-block-start)}@keyframes open{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes close{0%{transform:translate(0)}to{transform:translate(-100%)}}`, Y = {
21
+ const Y = B`*,:before,:after{box-sizing:border-box}:host{--sbb-navigation-grid-column: 1 / 5;--sbb-navigation-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-3x) );--sbb-navigation-animation-easing: ease-in;--sbb-navigation-padding-inline: var(--sbb-layout-base-offset-responsive);--sbb-navigation-padding-block-start: var(--sbb-spacing-responsive-l);--sbb-navigation-padding-block-end: var(--sbb-spacing-responsive-xl);--sbb-navigation-backdrop-visibility: hidden;--sbb-navigation-backdrop-pointer-events: none;--sbb-navigation-backdrop-color: transparent;--sbb-navigation-list-margin-block-start: var(--sbb-spacing-responsive-xxl);--sbb-navigation-inline-start: 0;--sbb-navigation-expanded-width: 100%;--sbb-navigation-inset: 0 auto auto 0;--sbb-navigation-transform: translateX(-100%);--sbb-navigation-content-transform: translateX(0);--sbb-navigation-width: 100%;--sbb-navigation-height: 100dvh;--sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);display:none;position:fixed;inset:var(--sbb-navigation-inset);z-index:var(--sbb-navigation-z-index, var(--sbb-overlay-default-z-index));overflow:hidden}@media (min-width: 52.5rem){:host{--sbb-navigation-grid-column: 1 / 9}}@media (min-width: 64rem){:host{--sbb-navigation-grid-column: 1 / 5;--sbb-navigation-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-6x) );--sbb-navigation-padding-block-start: var(--sbb-spacing-responsive-xl);--sbb-navigation-padding-inline: var(--sbb-layout-base-offset-responsive) 0;--sbb-navigation-list-margin-block-start: var(--sbb-spacing-fixed-1x);--sbb-navigation-inline-start: calc(var(--sbb-layout-base-offset-responsive) * -1);--sbb-navigation-width: calc(100% + var(--sbb-layout-base-offset-responsive))}}@media (min-width: 90rem){:host{--sbb-navigation-grid-column: 1 / 6;--sbb-navigation-padding-block-start: var(--sbb-spacing-responsive-xxl)}}:host([data-state]:not([data-state=closed])){display:block}:host([data-state=opened]){--sbb-navigation-animation-easing: ease-out}:host(:is([data-state=opened],[data-state=opening])){--sbb-navigation-backdrop-visibility: visible;--sbb-navigation-backdrop-pointer-events: all;--sbb-navigation-backdrop-color: var(--sbb-color-black-alpha-70)}:host(:not([data-state=closed])){--sbb-navigation-inset: 0;--sbb-navigation-transform: translateX(0)}:host([data-has-navigation-section]){--sbb-navigation-content-transform: translateX(-100%)}@media (min-width: 64rem){:host([data-has-navigation-section]){--sbb-navigation-expanded-width: 100dvw;--sbb-navigation-content-transform: translateX(0%)}}:host([data-resize-disable-animation]){--sbb-disable-animation-duration: 0s}.sbb-navigation__container{display:grid;gap:var(--sbb-grid-base-gutter-responsive);grid-template-columns:repeat(var(--sbb-grid-base-columns),1fr);padding-inline:0;pointer-events:none;transform:var(--sbb-navigation-transform)}@media (min-width: 64rem){.sbb-navigation__container{padding-inline:var(--sbb-layout-base-offset-responsive)}.sbb-navigation__container:before{transition-duration:var(--sbb-navigation-animation-duration);transition-timing-function:var(--sbb-navigation-animation-easing);transition-property:background-color,visibility;content:"";visibility:var(--sbb-navigation-backdrop-visibility);pointer-events:var(--sbb-navigation-backdrop-pointer-events);position:fixed;inset:var(--sbb-navigation-inset);background-color:var(--sbb-navigation-backdrop-color)}}.sbb-navigation{transition-duration:var(--sbb-navigation-animation-duration);transition-timing-function:var(--sbb-navigation-animation-easing);transition-property:width;display:none;width:var(--sbb-navigation-width);grid-column:var(--sbb-navigation-grid-column);padding:0;margin:0;position:relative;inset-inline-start:var(--sbb-navigation-inline-start);inset-block-start:0;border:none;pointer-events:none;height:var(--sbb-navigation-height);color:var(--sbb-color-white);background-color:var(--sbb-color-midnight)}.sbb-navigation:before{transition-duration:var(--sbb-navigation-animation-duration);transition-timing-function:var(--sbb-navigation-animation-easing);transition-property:width;content:"";position:absolute;width:var(--sbb-navigation-expanded-width);height:var(--sbb-navigation-height);background:var(--sbb-color-midnight)}:host([data-state]:not([data-state=closed])) .sbb-navigation{display:block;pointer-events:all;animation-name:open;animation-duration:var(--sbb-navigation-animation-duration);animation-timing-function:var(--sbb-navigation-animation-easing)}:host([data-state][data-state=closing]) .sbb-navigation{pointer-events:none;animation-name:close}@media (forced-colors: active){.sbb-navigation{outline:var(--sbb-border-width-1x) solid CanvasText}}.sbb-navigation__wrapper{outline:none}.sbb-navigation__header{transition-duration:var(--sbb-navigation-animation-duration);transition-timing-function:var(--sbb-navigation-animation-easing);transition-property:width;display:flex;justify-content:flex-end;position:absolute;width:var(--sbb-navigation-expanded-width);pointer-events:none;padding:var(--sbb-spacing-responsive-xs);z-index:calc(var(--sbb-navigation-z-index, var(--sbb-overlay-default-z-index)) + 1)}.sbb-navigation__close{pointer-events:all}.sbb-navigation__content{transition-duration:var(--sbb-navigation-animation-duration);transition-timing-function:var(--sbb-navigation-animation-easing);transition-property:transform;--sbb-scrollbar-thumb-width: .125rem;--sbb-scrollbar-thumb-width-hover: .25rem;--sbb-scrollbar-width-firefox: thin;--sbb-scrollbar-color: var(--sbb-color-white-alpha-30);--sbb-scrollbar-color-hover: var(--sbb-color-white-alpha-60);--sbb-scrollbar-track-color: transparent;--sbb-scrollbar-width: var(--sbb-spacing-fixed-3x)}.sbb-navigation__content::-webkit-scrollbar{width:var(--sbb-scrollbar-width);height:var(--sbb-scrollbar-width);background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-navigation__content::-webkit-scrollbar-corner{background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-navigation__content::-webkit-scrollbar-thumb{background-color:var(--sbb-scrollbar-color, currentcolor);border:calc(.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width))) solid transparent;border-radius:var(--sbb-border-radius-4x);background-clip:padding-box}.sbb-navigation__content::-webkit-scrollbar-thumb:hover{background-color:var(--sbb-scrollbar-color-hover, currentcolor);border-width:calc(.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width-hover)))}.sbb-navigation__content::-webkit-scrollbar-button,.sbb-navigation__content::-webkit-scrollbar-corner{display:none}@supports not selector(::-webkit-scrollbar){.sbb-navigation__content{scrollbar-width:var(--sbb-scrollbar-width-firefox);scrollbar-color:var(--sbb-scrollbar-color, currentcolor) var(--sbb-scrollbar-track-color, transparent)}}.sbb-navigation__content{display:flex;flex-direction:column;gap:var(--sbb-spacing-responsive-xxl);position:relative;height:var(--sbb-navigation-height);padding-inline:var(--sbb-navigation-padding-inline);padding-block:var(--sbb-navigation-padding-block-start) var(--sbb-navigation-padding-block-end);overflow-y:auto;transform:var(--sbb-navigation-content-transform)}::slotted(:first-child){margin-block-start:var(--sbb-navigation-list-margin-block-start)}@keyframes open{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes close{0%{transform:translate(0)}to{transform:translate(-100%)}}`, tt = {
22
22
  subtree: !0,
23
23
  attributeFilter: ["data-state"]
24
24
  };
25
- let tt = 0;
26
- const it = 150;
27
- let ft = (() => {
25
+ let it = 0;
26
+ const at = 150;
27
+ let kt = (() => {
28
28
  var l, c, b;
29
- let e = [F("sbb-navigation"), $({
29
+ let n = [F("sbb-navigation"), X({
30
30
  role: "navigation",
31
31
  popover: "manual"
32
- })], o, s = [], r, p = K(q), _ = [], f, w, k = [], y = [], C, E = [], x = [];
32
+ })], e, s = [], r, p = K(q), _ = [], f, k, w = [], y = [], C, x = [], S = [];
33
33
  return b = class extends p {
34
34
  constructor() {
35
35
  var t, i, a;
36
36
  super();
37
37
  m(this, l);
38
38
  m(this, c);
39
- this._trigger = (v(this, _), null), d(this, l, v(this, k, "")), d(this, c, (v(this, y), v(this, E, null))), this._navigation = v(this, x), this._triggerElement = null, this._language = new M(this), this._inertController = new U(this), this._focusHandler = new R(), this._scrollHandler = new Z(), this._isPointerDownEventOnNavigation = !1, this._resizeObserverTimeout = null, this._navigationResizeObserver = new H(this, {
39
+ this._trigger = (v(this, _), null), g(this, l, v(this, w, "")), g(this, c, (v(this, y), v(this, x, null))), this._navigation = v(this, S), this._triggerElement = null, this._language = new M(this), this._inertController = new U(this), this._sbbEscapableOverlayController = new $(this), this._focusHandler = new R(), this._scrollHandler = new j(), this._isPointerDownEventOnNavigation = !1, this._resizeObserverTimeout = null, this._navigationResizeObserver = new H(this, {
40
40
  skipInitial: !0,
41
41
  callback: () => this._onNavigationResize()
42
- }), this._trapFocusFilter = (n) => n.nodeName !== "SBB-NAVIGATION-SECTION" || n.getAttribute("data-state") === "opened", this._pointerDownListener = (n) => {
43
- var S, N;
44
- this._isPointerDownEventOnNavigation = u(this._navigation, n) || u((N = (S = this.querySelector('sbb-navigation-section[data-state="opened"]')) == null ? void 0 : S.shadowRoot) == null ? void 0 : N.querySelector("nav.sbb-navigation-section"), n);
45
- }, this._closeOnBackdropClick = (n) => {
46
- !this._isPointerDownEventOnNavigation && !u(this._navigation, n) && this.close();
47
- }, (t = this.addEventListener) == null || t.call(this, "click", (n) => this._handleNavigationClose(n)), (i = this.addEventListener) == null || i.call(this, "pointerup", (n) => this._closeOnBackdropClick(n)), (a = this.addEventListener) == null || a.call(this, "pointerdown", (n) => this._pointerDownListener(n)), new D(this, {
42
+ }), this._trapFocusFilter = (o) => o.nodeName !== "SBB-NAVIGATION-SECTION" || o.getAttribute("data-state") === "opened", this._pointerDownListener = (o) => {
43
+ var E, N;
44
+ this._isPointerDownEventOnNavigation = u(this._navigation, o) || u((N = (E = this.querySelector('sbb-navigation-section[data-state="opened"]')) == null ? void 0 : E.shadowRoot) == null ? void 0 : N.querySelector("nav.sbb-navigation-section"), o);
45
+ }, this._closeOnBackdropClick = (o) => {
46
+ !this._isPointerDownEventOnNavigation && !u(this._navigation, o) && this.close();
47
+ }, (t = this.addEventListener) == null || t.call(this, "click", (o) => this._handleNavigationClose(o)), (i = this.addEventListener) == null || i.call(this, "pointerup", (o) => this._closeOnBackdropClick(o)), (a = this.addEventListener) == null || a.call(this, "pointerdown", (o) => this._pointerDownListener(o)), new D(this, {
48
48
  skipInitial: !0,
49
- config: Y,
50
- callback: (n) => this._onNavigationSectionChange(n)
49
+ config: tt,
50
+ callback: (o) => this._onNavigationSectionChange(o)
51
51
  });
52
52
  }
53
53
  /**
@@ -68,7 +68,7 @@ let ft = (() => {
68
68
  return h(this, l);
69
69
  }
70
70
  set accessibilityCloseLabel(t) {
71
- d(this, l, t);
71
+ g(this, l, t);
72
72
  }
73
73
  /**
74
74
  * Whether a navigation section is displayed.
@@ -77,7 +77,7 @@ let ft = (() => {
77
77
  return h(this, c);
78
78
  }
79
79
  set _activeNavigationSection(t) {
80
- d(this, c, t);
80
+ g(this, c, t);
81
81
  }
82
82
  get activeNavigationSection() {
83
83
  return this._activeNavigationSection;
@@ -109,24 +109,24 @@ let ft = (() => {
109
109
  this.state === "opened" && this.willClose.emit() && (this.state = "closing", this.startUpdate(), (t = this._triggerElement) == null || t.setAttribute("aria-expanded", "false"), this._isZeroAnimationDuration() && this._handleClosing());
110
110
  }
111
111
  _isZeroAnimationDuration() {
112
- return j(this, "--sbb-navigation-animation-duration");
112
+ return V(this, "--sbb-navigation-animation-duration");
113
113
  }
114
114
  _handleClosing() {
115
- var t, i, a;
116
- this.state = "closed", (t = this.hidePopover) == null || t.call(this), this._navigationContentElement.scrollTo(0, 0), I(this._triggerElement), this._inertController.deactivate(), (i = this._triggerElement) == null || i.focus(), this.didClose.emit(), this._navigationResizeObserver.unobserve(this), this._resetMarkers(), (a = this._windowEventsController) == null || a.abort(), this._focusHandler.disconnect(), this._scrollHandler.enableScroll(), this.completeUpdate();
115
+ var t, i;
116
+ this.state = "closed", (t = this.hidePopover) == null || t.call(this), this._navigationContentElement.scrollTo(0, 0), I(this._triggerElement), this._inertController.deactivate(), (i = this._triggerElement) == null || i.focus(), this._sbbEscapableOverlayController.disconnect(), this.didClose.emit(), this._navigationResizeObserver.unobserve(this), this._resetMarkers(), this._focusHandler.disconnect(), this._scrollHandler.enableScroll(), this.completeUpdate();
117
117
  }
118
118
  _handleOpening() {
119
- this.state = "opened", this._navigationResizeObserver.observe(this), this._inertController.activate(), this._focusHandler.trap(this, { filter: this._trapFocusFilter }), this._attachWindowEvents(), this._setNavigationFocus(), this.completeUpdate(), this.didOpen.emit();
119
+ this.state = "opened", this._navigationResizeObserver.observe(this), this._inertController.activate(), this._sbbEscapableOverlayController.connect(), this._focusHandler.trap(this, { filter: this._trapFocusFilter }), this._setNavigationFocus(), this.completeUpdate(), this.didOpen.emit();
120
120
  }
121
121
  // Removes trigger click listener on trigger change.
122
122
  _removeTriggerClickListener(t, i) {
123
- var a, n;
124
- t !== i && ((a = this._navigationController) == null || a.abort(), (n = this._windowEventsController) == null || n.abort(), this._configure(this.trigger));
123
+ var a;
124
+ t !== i && ((a = this._navigationController) == null || a.abort(), this._configure(this.trigger));
125
125
  }
126
126
  // Check if the trigger is valid and attach click event listeners.
127
127
  _configure(t) {
128
128
  var i;
129
- W(this._triggerElement), t && (this._triggerElement = V(t), this._triggerElement && (J(this._triggerElement, "menu", this.id, this.state), (i = this._navigationController) == null || i.abort(), this._navigationController = new AbortController(), this._triggerElement.addEventListener("click", () => this.open(), {
129
+ Q(this._triggerElement), t && (this._triggerElement = G(t), this._triggerElement && (W(this._triggerElement, "menu", this.id, this.state), (i = this._navigationController) == null || i.abort(), this._navigationController = new AbortController(), this._triggerElement.addEventListener("click", () => this.open(), {
130
130
  signal: this._navigationController.signal
131
131
  })));
132
132
  }
@@ -142,21 +142,12 @@ let ft = (() => {
142
142
  return (a = i.marker) == null ? void 0 : a.reset();
143
143
  });
144
144
  }
145
- _attachWindowEvents() {
146
- this._windowEventsController = new AbortController(), window.addEventListener("keydown", (t) => this._onKeydownEvent(t), {
147
- signal: this._windowEventsController.signal
148
- });
149
- }
150
145
  _handleNavigationClose(t) {
151
146
  t.composedPath().filter((a) => a instanceof window.HTMLElement).some((a) => this._isCloseElement(a)) && this.close();
152
147
  }
153
148
  _isCloseElement(t) {
154
149
  return t.nodeName === "A" || t.hasAttribute("sbb-navigation-close") && !t.hasAttribute("disabled");
155
150
  }
156
- // Closes the navigation on "Esc" key pressed.
157
- _onKeydownEvent(t) {
158
- this.state === "opened" && t.key === "Escape" && this.close();
159
- }
160
151
  // Set focus on the first focusable element.
161
152
  _setNavigationFocus() {
162
153
  const t = this.shadowRoot.querySelector("#sbb-navigation-close-button");
@@ -168,21 +159,21 @@ let ft = (() => {
168
159
  i.target.nodeName === "SBB-NAVIGATION-SECTION" && (this._activeNavigationSection = this.querySelector('sbb-navigation-section[data-state="opening"], sbb-navigation-section[data-state="opened"]'), this.toggleAttribute("data-has-navigation-section", !!this._activeNavigationSection));
169
160
  }
170
161
  _onNavigationResize() {
171
- this.state === "opened" && (this._resizeObserverTimeout && clearTimeout(this._resizeObserverTimeout), this.toggleAttribute("data-resize-disable-animation", !0), this._resizeObserverTimeout = setTimeout(() => this.removeAttribute("data-resize-disable-animation"), it));
162
+ this.state === "opened" && (this._resizeObserverTimeout && clearTimeout(this._resizeObserverTimeout), this.toggleAttribute("data-resize-disable-animation", !0), this._resizeObserverTimeout = setTimeout(() => this.removeAttribute("data-resize-disable-animation"), at));
172
163
  }
173
164
  connectedCallback() {
174
- super.connectedCallback(), this.id || (this.id = `sbb-navigation-${tt++}`), this._configure(this.trigger);
165
+ super.connectedCallback(), this.id || (this.id = `sbb-navigation-${it++}`), this._configure(this.trigger);
175
166
  }
176
167
  disconnectedCallback() {
177
- var t, i;
178
- super.disconnectedCallback(), (t = this._navigationController) == null || t.abort(), (i = this._windowEventsController) == null || i.abort(), this._focusHandler.disconnect(), this._scrollHandler.enableScroll();
168
+ var t;
169
+ super.disconnectedCallback(), (t = this._navigationController) == null || t.abort(), this._focusHandler.disconnect(), this._scrollHandler.enableScroll();
179
170
  }
180
171
  render() {
181
172
  const t = z`
182
173
  <sbb-transparent-button
183
174
  id="sbb-navigation-close-button"
184
175
  class="sbb-navigation__close"
185
- aria-label=${this.accessibilityCloseLabel || G[this._language.current]}
176
+ aria-label=${this.accessibilityCloseLabel || J[this._language.current]}
186
177
  aria-controls="sbb-navigation-overlay"
187
178
  negative
188
179
  size="m"
@@ -215,15 +206,15 @@ let ft = (() => {
215
206
  }
216
207
  }, l = new WeakMap(), c = new WeakMap(), r = b, (() => {
217
208
  const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(p[Symbol.metadata] ?? null) : void 0;
218
- f = [L()], w = [X(), L({ attribute: "accessibility-close-label" })], C = [P()], g(b, null, f, { kind: "setter", name: "trigger", static: !1, private: !1, access: { has: (i) => "trigger" in i, set: (i, a) => {
209
+ f = [L()], k = [Z(), L({ attribute: "accessibility-close-label" })], C = [P()], d(b, null, f, { kind: "setter", name: "trigger", static: !1, private: !1, access: { has: (i) => "trigger" in i, set: (i, a) => {
219
210
  i.trigger = a;
220
- } }, metadata: t }, null, _), g(b, null, w, { kind: "accessor", name: "accessibilityCloseLabel", static: !1, private: !1, access: { has: (i) => "accessibilityCloseLabel" in i, get: (i) => i.accessibilityCloseLabel, set: (i, a) => {
211
+ } }, metadata: t }, null, _), d(b, null, k, { kind: "accessor", name: "accessibilityCloseLabel", static: !1, private: !1, access: { has: (i) => "accessibilityCloseLabel" in i, get: (i) => i.accessibilityCloseLabel, set: (i, a) => {
221
212
  i.accessibilityCloseLabel = a;
222
- } }, metadata: t }, k, y), g(b, null, C, { kind: "accessor", name: "_activeNavigationSection", static: !1, private: !1, access: { has: (i) => "_activeNavigationSection" in i, get: (i) => i._activeNavigationSection, set: (i, a) => {
213
+ } }, metadata: t }, w, y), d(b, null, C, { kind: "accessor", name: "_activeNavigationSection", static: !1, private: !1, access: { has: (i) => "_activeNavigationSection" in i, get: (i) => i._activeNavigationSection, set: (i, a) => {
223
214
  i._activeNavigationSection = a;
224
- } }, metadata: t }, E, x), g(null, o = { value: r }, e, { kind: "class", name: r.name, metadata: t }, null, s), r = o.value, t && Object.defineProperty(r, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
225
- })(), b.styles = Q, v(r, s), r;
215
+ } }, metadata: t }, x, S), d(null, e = { value: r }, n, { kind: "class", name: r.name, metadata: t }, null, s), r = e.value, t && Object.defineProperty(r, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
216
+ })(), b.styles = Y, v(r, s), r;
226
217
  })();
227
218
  export {
228
- ft as SbbNavigationElement
219
+ kt as SbbNavigationElement
229
220
  };
package/notification.js CHANGED
@@ -1,11 +1,11 @@
1
1
  var B = (e) => {
2
2
  throw TypeError(e);
3
3
  };
4
- var M = (e, a, o) => a.has(e) || B("Cannot " + o);
5
- var c = (e, a, o) => (M(e, a, "read from private field"), o ? o.call(e) : a.get(e)), d = (e, a, o) => a.has(e) ? B("Cannot add the same private member more than once") : a instanceof WeakSet ? a.add(e) : a.set(e, o), s = (e, a, o, l) => (M(e, a, "write to private field"), l ? l.call(e, o) : a.set(e, o), o);
4
+ var M = (e, a, n) => a.has(e) || B("Cannot " + n);
5
+ var c = (e, a, n) => (M(e, a, "read from private field"), n ? n.call(e) : a.get(e)), d = (e, a, n) => a.has(e) ? B("Cannot add the same private member more than once") : a instanceof WeakSet ? a.add(e) : a.set(e, n), s = (e, a, n, l) => (M(e, a, "write to private field"), l ? l.call(e, n) : a.set(e, n), n);
6
6
  import { __runInitializers as r, __esDecorate as f } from "tslib";
7
7
  import { ResizeController as F } from "@lit-labs/observers/resize-controller.js";
8
- import { css as G, LitElement as J, html as P, nothing as K } from "lit";
8
+ import { css as G, LitElement as J, nothing as K, html as P } from "lit";
9
9
  import { customElement as Q, property as y } from "lit/decorators.js";
10
10
  import { SbbLanguageController as V } from "./core/controllers.js";
11
11
  import { slotState as W, forceType as q, omitEmptyConverter as X } from "./core/decorators.js";
@@ -21,11 +21,11 @@ const ei = G`*,:before,:after{box-sizing:border-box}:host{--sbb-notification-mar
21
21
  ["success", "circle-tick-small"],
22
22
  ["warn", "circle-exclamation-point-small"],
23
23
  ["error", "circle-cross-small"]
24
- ]), ni = 150;
24
+ ]), oi = 150;
25
25
  let yi = (() => {
26
- var m, p, v, _, g, u, n;
27
- let e = [Q("sbb-notification"), W()], a, o = [], l, w = J, z, k = [], C = [], O, E = [], L = [], N, T = [], A = [], I, S = [], $ = [], D, R = [], H = [], Z, U = [], j = [];
28
- var h = (n = class extends w {
26
+ var m, p, v, _, g, u, o;
27
+ let e = [Q("sbb-notification"), W()], a, n = [], l, w = J, z, k = [], C = [], O, E = [], L = [], N, T = [], A = [], I, S = [], $ = [], D, R = [], H = [], Z, U = [], j = [];
28
+ var h = (o = class extends w {
29
29
  constructor() {
30
30
  super(...arguments);
31
31
  d(this, m);
@@ -119,7 +119,7 @@ let yi = (() => {
119
119
  this.style.setProperty("--sbb-notification-height", t);
120
120
  }
121
121
  _onNotificationResize() {
122
- this._state === "opened" && (this._resizeObserverTimeout && clearTimeout(this._resizeObserverTimeout), this.toggleAttribute("data-resize-disable-animation", !0), this._resizeObserverTimeout = setTimeout(() => this.removeAttribute("data-resize-disable-animation"), ni), setTimeout(() => this._setNotificationHeight()));
122
+ this._state === "opened" && (this._resizeObserverTimeout && clearTimeout(this._resizeObserverTimeout), this.toggleAttribute("data-resize-disable-animation", !0), this._resizeObserverTimeout = setTimeout(() => this.removeAttribute("data-resize-disable-animation"), oi), setTimeout(() => this._setNotificationHeight()));
123
123
  }
124
124
  _onNotificationAnimationEnd(t) {
125
125
  this._state === "opening" && t.animationName === "open" && this._handleOpening(), this._state === "closing" && t.animationName === "close-height" && this._handleClosing();
@@ -164,27 +164,27 @@ let yi = (() => {
164
164
  </div>
165
165
  `;
166
166
  }
167
- }, m = new WeakMap(), p = new WeakMap(), v = new WeakMap(), _ = new WeakMap(), g = new WeakMap(), u = new WeakMap(), l = n, (() => {
167
+ }, m = new WeakMap(), p = new WeakMap(), v = new WeakMap(), _ = new WeakMap(), g = new WeakMap(), u = new WeakMap(), l = o, (() => {
168
168
  const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(w[Symbol.metadata] ?? null) : void 0;
169
- z = [y({ reflect: !0 })], O = [q(), y({ attribute: "title-content", reflect: !0, converter: X })], N = [y({ attribute: "title-level" })], I = [q(), y({ reflect: !0, type: Boolean })], D = [y({ reflect: !0 })], Z = [y({ reflect: !0 })], f(n, null, z, { kind: "accessor", name: "type", static: !1, private: !1, access: { has: (i) => "type" in i, get: (i) => i.type, set: (i, b) => {
169
+ z = [y({ reflect: !0 })], O = [q(), y({ attribute: "title-content", reflect: !0, converter: X })], N = [y({ attribute: "title-level" })], I = [q(), y({ reflect: !0, type: Boolean })], D = [y({ reflect: !0 })], Z = [y({ reflect: !0 })], f(o, null, z, { kind: "accessor", name: "type", static: !1, private: !1, access: { has: (i) => "type" in i, get: (i) => i.type, set: (i, b) => {
170
170
  i.type = b;
171
- } }, metadata: t }, k, C), f(n, null, O, { kind: "accessor", name: "titleContent", static: !1, private: !1, access: { has: (i) => "titleContent" in i, get: (i) => i.titleContent, set: (i, b) => {
171
+ } }, metadata: t }, k, C), f(o, null, O, { kind: "accessor", name: "titleContent", static: !1, private: !1, access: { has: (i) => "titleContent" in i, get: (i) => i.titleContent, set: (i, b) => {
172
172
  i.titleContent = b;
173
- } }, metadata: t }, E, L), f(n, null, N, { kind: "accessor", name: "titleLevel", static: !1, private: !1, access: { has: (i) => "titleLevel" in i, get: (i) => i.titleLevel, set: (i, b) => {
173
+ } }, metadata: t }, E, L), f(o, null, N, { kind: "accessor", name: "titleLevel", static: !1, private: !1, access: { has: (i) => "titleLevel" in i, get: (i) => i.titleLevel, set: (i, b) => {
174
174
  i.titleLevel = b;
175
- } }, metadata: t }, T, A), f(n, null, I, { kind: "accessor", name: "readonly", static: !1, private: !1, access: { has: (i) => "readonly" in i, get: (i) => i.readonly, set: (i, b) => {
175
+ } }, metadata: t }, T, A), f(o, null, I, { kind: "accessor", name: "readonly", static: !1, private: !1, access: { has: (i) => "readonly" in i, get: (i) => i.readonly, set: (i, b) => {
176
176
  i.readonly = b;
177
- } }, metadata: t }, S, $), f(n, null, D, { kind: "accessor", name: "size", static: !1, private: !1, access: { has: (i) => "size" in i, get: (i) => i.size, set: (i, b) => {
177
+ } }, metadata: t }, S, $), f(o, null, D, { kind: "accessor", name: "size", static: !1, private: !1, access: { has: (i) => "size" in i, get: (i) => i.size, set: (i, b) => {
178
178
  i.size = b;
179
- } }, metadata: t }, R, H), f(n, null, Z, { kind: "accessor", name: "animation", static: !1, private: !1, access: { has: (i) => "animation" in i, get: (i) => i.animation, set: (i, b) => {
179
+ } }, metadata: t }, R, H), f(o, null, Z, { kind: "accessor", name: "animation", static: !1, private: !1, access: { has: (i) => "animation" in i, get: (i) => i.animation, set: (i, b) => {
180
180
  i.animation = b;
181
- } }, metadata: t }, U, j), f(null, a = { value: l }, e, { kind: "class", name: l.name, metadata: t }, null, o), h = l = a.value, t && Object.defineProperty(l, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
182
- })(), n.styles = ei, n.events = {
181
+ } }, metadata: t }, U, j), f(null, a = { value: l }, e, { kind: "class", name: l.name, metadata: t }, null, n), h = l = a.value, t && Object.defineProperty(l, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
182
+ })(), o.styles = ei, o.events = {
183
183
  willOpen: "willOpen",
184
184
  didOpen: "didOpen",
185
185
  willClose: "willClose",
186
186
  didClose: "didClose"
187
- }, r(l, o), n);
187
+ }, r(l, n), o);
188
188
  return h = l;
189
189
  })();
190
190
  export {
@@ -13,9 +13,9 @@ import { SbbDisabledMixin as M, SbbHydrationMixin as $ } from "../core/mixins.js
13
13
  import "../divider.js";
14
14
  const N = L`*,:before,:after{box-sizing:border-box}:host{--sbb-optgroup-divider-display: block;--sbb-optgroup-divider-spacing: 0;--sbb-optgroup-label-padding-start: var(--sbb-spacing-fixed-4x);--sbb-optgroup-label-padding-inline: var(--sbb-spacing-fixed-4x);--sbb-optgroup-label-font-size: var(--sbb-typo-scale-0-75x);--sbb-optgroup-label-color: var(--sbb-color-metal);display:block}:host(:first-child){--sbb-optgroup-divider-display: none;--sbb-optgroup-label-padding-start: var(--sbb-spacing-fixed-2x)}:host([data-variant=select]){--sbb-optgroup-divider-spacing: var(--sbb-spacing-fixed-4x);--sbb-optgroup-label-padding-inline: var(--sbb-spacing-responsive-xxxs);--sbb-optgroup-label-padding-start: 0;--sbb-optgroup-label-font-size: inherit}:host([data-variant=select]:first-child){--sbb-optgroup-label-padding-start: var(--sbb-spacing-fixed-4x)}:host([data-negative]){--sbb-optgroup-label-color: var(--sbb-color-smoke)}.sbb-optgroup{margin-block:var(--sbb-spacing-fixed-4x);margin-inline:var(--sbb-spacing-fixed-4x)}.sbb-optgroup__label{--sbb-text-font-size: var(--sbb-font-size-text-xxs);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;column-gap:var(--sbb-spacing-responsive-xxxs);color:var(--sbb-optgroup-label-color);-webkit-text-fill-color:var(--sbb-optgroup-label-color);padding-inline:var(--sbb-optgroup-label-padding-inline);padding-block:var(--sbb-optgroup-label-padding-start) var(--sbb-spacing-fixed-2x)}:host([data-variant=select][data-multiple]) .sbb-optgroup__label{--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);padding-inline-start:calc(var(--sbb-spacing-responsive-xxxs) + var(--sbb-spacing-fixed-8x))}.sbb-optgroup__divider{display:var(--sbb-optgroup-divider-display);padding-block:var(--sbb-optgroup-divider-spacing)}.sbb-optgroup__icon-space{display:var(--sbb-option-icon-container-display, none);min-width:var(--sbb-size-icon-ui-small)}`, x = B;
15
15
  let R = (() => {
16
- var u, g, h, n;
17
- let i = [P({ role: x ? null : "group" })], a, l = [], s, c = M($(j)), b, y = [], r = [], d, A = [], z = [], G, S = [], k = [];
18
- return n = class extends c {
16
+ var u, g, h, b;
17
+ let i = [P({ role: x ? null : "group" })], a, l = [], s, c = M($(j)), n, y = [], r = [], d, A = [], z = [], G, S = [], k = [];
18
+ return b = class extends c {
19
19
  constructor() {
20
20
  super();
21
21
  m(this, u, p(this, y, ""));
@@ -99,20 +99,20 @@ let R = (() => {
99
99
  <slot @slotchange=${this._handleSlotchange}></slot>
100
100
  `;
101
101
  }
102
- }, u = new WeakMap(), g = new WeakMap(), h = new WeakMap(), s = n, (() => {
102
+ }, u = new WeakMap(), g = new WeakMap(), h = new WeakMap(), s = b, (() => {
103
103
  const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(c[Symbol.metadata] ?? null) : void 0;
104
- b = [U(), D()], d = [T()], G = [T()], v(n, null, b, { kind: "accessor", name: "label", static: !1, private: !1, access: { has: (e) => "label" in e, get: (e) => e.label, set: (e, o) => {
104
+ n = [U(), D()], d = [T()], G = [T()], v(b, null, n, { kind: "accessor", name: "label", static: !1, private: !1, access: { has: (e) => "label" in e, get: (e) => e.label, set: (e, o) => {
105
105
  e.label = o;
106
- } }, metadata: t }, y, r), v(n, null, d, { kind: "accessor", name: "negative", static: !1, private: !1, access: { has: (e) => "negative" in e, get: (e) => e.negative, set: (e, o) => {
106
+ } }, metadata: t }, y, r), v(b, null, d, { kind: "accessor", name: "negative", static: !1, private: !1, access: { has: (e) => "negative" in e, get: (e) => e.negative, set: (e, o) => {
107
107
  e.negative = o;
108
- } }, metadata: t }, A, z), v(n, null, G, { kind: "accessor", name: "_inertAriaGroups", static: !1, private: !1, access: { has: (e) => "_inertAriaGroups" in e, get: (e) => e._inertAriaGroups, set: (e, o) => {
108
+ } }, metadata: t }, A, z), v(b, null, G, { kind: "accessor", name: "_inertAriaGroups", static: !1, private: !1, access: { has: (e) => "_inertAriaGroups" in e, get: (e) => e._inertAriaGroups, set: (e, o) => {
109
109
  e._inertAriaGroups = o;
110
110
  } }, metadata: t }, S, k), v(null, a = { value: s }, i, { kind: "class", name: s.name, metadata: t }, null, l), s = a.value, t && Object.defineProperty(s, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
111
- })(), n.styles = N, p(s, l), s;
111
+ })(), b.styles = N, p(s, l), s;
112
112
  })(), et = (() => {
113
- var b;
113
+ var n;
114
114
  let i = [E("sbb-optgroup")], a, l = [], s, c = R;
115
- return b = class extends c {
115
+ return n = class extends c {
116
116
  get options() {
117
117
  var r;
118
118
  return Array.from(((r = this.querySelectorAll) == null ? void 0 : r.call(this, "sbb-option")) ?? []);
@@ -132,7 +132,7 @@ let R = (() => {
132
132
  var r, d;
133
133
  (r = this.closest) != null && r.call(this, "sbb-autocomplete") ? this.setAttribute("data-variant", "autocomplete") : (d = this.closest) != null && d.call(this, "sbb-select") && this.setAttribute("data-variant", "select");
134
134
  }
135
- }, s = b, (() => {
135
+ }, s = n, (() => {
136
136
  const r = typeof Symbol == "function" && Symbol.metadata ? Object.create(c[Symbol.metadata] ?? null) : void 0;
137
137
  v(null, a = { value: s }, i, { kind: "class", name: s.name, metadata: r }, null, l), s = a.value, r && Object.defineProperty(s, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: r }), p(s, l);
138
138
  })(), s;
@@ -1,7 +1,7 @@
1
1
  import { PropertyValues } from 'lit';
2
2
  import { SbbFocusHandler } from '../core/a11y.js';
3
3
  import { SbbOpenCloseBaseElement } from '../core/base-elements.js';
4
- import { SbbInertController, SbbLanguageController } from '../core/controllers.js';
4
+ import { SbbInertController, SbbLanguageController, SbbEscapableOverlayController } from '../core/controllers.js';
5
5
  import { SbbScrollHandler } from '../core/dom.js';
6
6
  import { EventEmitter } from '../core/eventing.js';
7
7
  import { SbbOverlayCloseEventDetails } from '../core/interfaces.js';
@@ -25,6 +25,7 @@ export declare abstract class SbbOverlayBaseElement extends SbbOverlayBaseElemen
25
25
  protected ariaLiveRef: SbbScreenReaderOnlyElement;
26
26
  protected language: SbbLanguageController;
27
27
  protected inertController: SbbInertController;
28
+ protected sbbEscapableOverlayController: SbbEscapableOverlayController;
28
29
  protected abstract closeAttribute: string;
29
30
  protected abstract onOverlayAnimationEnd(event: AnimationEvent): void;
30
31
  protected abstract setOverlayFocus(): void;
@@ -36,7 +37,6 @@ export declare abstract class SbbOverlayBaseElement extends SbbOverlayBaseElemen
36
37
  protected firstUpdated(changedProperties: PropertyValues<this>): void;
37
38
  disconnectedCallback(): void;
38
39
  protected attachOpenOverlayEvents(): void;
39
- protected onKeydownEvent(event: KeyboardEvent): void;
40
40
  protected removeInstanceFromGlobalCollection(): void;
41
41
  protected closeOnSbbOverlayCloseClick(event: Event): void;
42
42
  protected removeAriaLiveRefContent(): void;
@@ -1 +1 @@
1
- {"version":3,"file":"overlay-base-element.d.ts","sourceRoot":"","sources":["../../../src/elements/overlay/overlay-base-element.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAG1C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAA6B,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AAC9F,OAAO,EAAE,kBAAkB,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAEnF,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAEnD,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,uBAAuB,CAAC;AAEzE,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AAG3E,eAAO,MAAM,WAAW,EAAE,qBAAqB,EAAO,CAAC;;AAEvD,8BAIe,qBAAsB,SAAQ,0BAAyC;IACpF,kHAAkH;IAClH,SAEgB,kBAAkB,EAAE,MAAM,CAAM;IAEhD,8CAA8C;IAC9C,UAAmB,QAAQ,EAAE,YAAY,CAAC,2BAA2B,CAAC,CAIpE;IAGF,SAAS,CAAC,kBAAkB,CAAC,EAAE,WAAW,CAAC;IAC3C,SAAS,CAAC,mBAAmB,CAAC,EAAE,WAAW,CAAC;IAC5C,kBAAkB;IAClB,SAAS,CAAC,iBAAiB,EAAG,eAAe,CAAC;IAC9C,SAAS,CAAC,qBAAqB,EAAG,eAAe,CAAC;IAClD,SAAS,CAAC,YAAY,kBAAyB;IAC/C,SAAS,CAAC,aAAa,mBAA0B;IACjD,SAAS,CAAC,WAAW,EAAE,GAAG,CAAC;IAC3B,SAAS,CAAC,iBAAiB,UAAS;IACpC,SAAS,CAAC,WAAW,EAAG,0BAA0B,CAAC;IACnD,SAAS,CAAC,QAAQ,wBAAmC;IACrD,SAAS,CAAC,eAAe,qBAAgC;IAEzD,SAAS,CAAC,QAAQ,CAAC,cAAc,EAAE,MAAM,CAAC;IAC1C,SAAS,CAAC,QAAQ,CAAC,qBAAqB,CAAC,KAAK,EAAE,cAAc,GAAG,IAAI;IACrE,SAAS,CAAC,QAAQ,CAAC,eAAe,IAAI,IAAI;IAC1C,SAAS,CAAC,QAAQ,CAAC,aAAa,IAAI,IAAI;IACxC,SAAS,CAAC,QAAQ,CAAC,uBAAuB,IAAI,OAAO;IAErD,4BAA4B;IACrB,KAAK,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,EAAE,WAAW,GAAG,GAAG;IAyBrC,iBAAiB,IAAI,IAAI;cAMtB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO9D,oBAAoB,IAAI,IAAI;IAS5C,SAAS,CAAC,uBAAuB,IAAI,IAAI;IAkBzC,SAAS,CAAC,cAAc,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAWpD,SAAS,CAAC,kCAAkC,IAAI,IAAI;IAKpD,SAAS,CAAC,2BAA2B,CAAC,KAAK,EAAE,KAAK,GAAG,IAAI;IAoBzD,SAAS,CAAC,wBAAwB,IAAI,IAAI;IAI1C,SAAS,CAAC,qBAAqB,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI;CAStD"}
1
+ {"version":3,"file":"overlay-base-element.d.ts","sourceRoot":"","sources":["../../../src/elements/overlay/overlay-base-element.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAG1C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAA6B,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AAC9F,OAAO,EACL,kBAAkB,EAClB,qBAAqB,EACrB,6BAA6B,EAC9B,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAEnD,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,uBAAuB,CAAC;AAEzE,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AAG3E,eAAO,MAAM,WAAW,EAAE,qBAAqB,EAAO,CAAC;;AAEvD,8BAIe,qBAAsB,SAAQ,0BAAyC;IACpF,kHAAkH;IAClH,SAEgB,kBAAkB,EAAE,MAAM,CAAM;IAEhD,8CAA8C;IAC9C,UAAmB,QAAQ,EAAE,YAAY,CAAC,2BAA2B,CAAC,CAIpE;IAGF,SAAS,CAAC,kBAAkB,CAAC,EAAE,WAAW,CAAC;IAC3C,SAAS,CAAC,mBAAmB,CAAC,EAAE,WAAW,CAAC;IAC5C,kBAAkB;IAClB,SAAS,CAAC,iBAAiB,EAAG,eAAe,CAAC;IAC9C,SAAS,CAAC,qBAAqB,EAAG,eAAe,CAAC;IAClD,SAAS,CAAC,YAAY,kBAAyB;IAC/C,SAAS,CAAC,aAAa,mBAA0B;IACjD,SAAS,CAAC,WAAW,EAAE,GAAG,CAAC;IAC3B,SAAS,CAAC,iBAAiB,UAAS;IACpC,SAAS,CAAC,WAAW,EAAG,0BAA0B,CAAC;IACnD,SAAS,CAAC,QAAQ,wBAAmC;IACrD,SAAS,CAAC,eAAe,qBAAgC;IACzD,SAAS,CAAC,6BAA6B,gCAA2C;IAElF,SAAS,CAAC,QAAQ,CAAC,cAAc,EAAE,MAAM,CAAC;IAC1C,SAAS,CAAC,QAAQ,CAAC,qBAAqB,CAAC,KAAK,EAAE,cAAc,GAAG,IAAI;IACrE,SAAS,CAAC,QAAQ,CAAC,eAAe,IAAI,IAAI;IAC1C,SAAS,CAAC,QAAQ,CAAC,aAAa,IAAI,IAAI;IACxC,SAAS,CAAC,QAAQ,CAAC,uBAAuB,IAAI,OAAO;IAErD,4BAA4B;IACrB,KAAK,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,EAAE,WAAW,GAAG,GAAG;IAyBrC,iBAAiB,IAAI,IAAI;cAMtB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO9D,oBAAoB,IAAI,IAAI;IAS5C,SAAS,CAAC,uBAAuB,IAAI,IAAI;IAiBzC,SAAS,CAAC,kCAAkC,IAAI,IAAI;IAKpD,SAAS,CAAC,2BAA2B,CAAC,KAAK,EAAE,KAAK,GAAG,IAAI;IAoBzD,SAAS,CAAC,wBAAwB,IAAI,IAAI;IAI1C,SAAS,CAAC,qBAAqB,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI;CAStD"}
@@ -1 +1 @@
1
- {"version":3,"file":"overlay.d.ts","sourceRoot":"","sources":["../../../src/elements/overlay/overlay.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAW1D,OAAO,EAAe,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AAG/E,OAAO,+BAA+B,CAAC;AACvC,OAAO,iCAAiC,CAAC;AACzC,OAAO,iBAAiB,CAAC;AACzB,OAAO,0BAA0B,CAAC;AAElC;;;;;;;;;;;;GAYG;AACH,qBAEM,iBAAkB,SAAQ,qBAAqB;IACnD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAGtD,gBAAgC,MAAM;;;;;;MAM3B;IAEX;;;OAGG;IACH,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C,4DAA4D;IAC5D,SAEgB,UAAU,EAAE,OAAO,CAAS;IAE5C,wEAAwE;IACxE,SAEgB,uBAAuB,EAAE,MAAM,CAAM;IAErD,uEAAuE;IACvE,SAEgB,sBAAsB,EAAE,MAAM,CAAM;IAEpD,SAAS,CAAC,cAAc,EAAE,MAAM,CAAuB;IAEvD,iDAAiD;IACjD,OAAO,CAAC,UAAU,CAGhB;IACF,OAAO,CAAC,sBAAsB,CAA4B;IAE1D,2BAA2B;IACpB,IAAI,IAAI,IAAI;IA8BnB,SAAS,CAAC,uBAAuB,IAAI,OAAO;IAI5C,OAAO,CAAC,cAAc;cAWH,aAAa,IAAI,IAAI;IAwBxC,SAAS,CAAC,qBAAqB,CAAC,KAAK,EAAE,cAAc,GAAG,IAAI;IAS5D,SAAS,CAAC,eAAe,IAAI,IAAI;cAUd,MAAM,IAAI,cAAc;CAsD5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,aAAa,EAAE,iBAAiB,CAAC;KAClC;CACF"}
1
+ {"version":3,"file":"overlay.d.ts","sourceRoot":"","sources":["../../../src/elements/overlay/overlay.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAW1D,OAAO,EAAe,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AAG/E,OAAO,+BAA+B,CAAC;AACvC,OAAO,iCAAiC,CAAC;AACzC,OAAO,iBAAiB,CAAC;AACzB,OAAO,0BAA0B,CAAC;AAElC;;;;;;;;;;;;GAYG;AACH,qBAEM,iBAAkB,SAAQ,qBAAqB;IACnD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAGtD,gBAAgC,MAAM;;;;;;MAM3B;IAEX;;;OAGG;IACH,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C,4DAA4D;IAC5D,SAEgB,UAAU,EAAE,OAAO,CAAS;IAE5C,wEAAwE;IACxE,SAEgB,uBAAuB,EAAE,MAAM,CAAM;IAErD,uEAAuE;IACvE,SAEgB,sBAAsB,EAAE,MAAM,CAAM;IAEpD,SAAS,CAAC,cAAc,EAAE,MAAM,CAAuB;IAEvD,iDAAiD;IACjD,OAAO,CAAC,UAAU,CAGhB;IACF,OAAO,CAAC,sBAAsB,CAA4B;IAE1D,2BAA2B;IACpB,IAAI,IAAI,IAAI;IA8BnB,SAAS,CAAC,uBAAuB,IAAI,OAAO;IAI5C,OAAO,CAAC,cAAc;cAYH,aAAa,IAAI,IAAI;IAyBxC,SAAS,CAAC,qBAAqB,CAAC,KAAK,EAAE,cAAc,GAAG,IAAI;IAS5D,SAAS,CAAC,eAAe,IAAI,IAAI;cAUd,MAAM,IAAI,cAAc;CAsD5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,aAAa,EAAE,iBAAiB,CAAC;KAClC;CACF"}