@sbb-esta/lyne-elements 1.7.0 → 1.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (88) hide show
  1. package/calendar/calendar.d.ts +5 -2
  2. package/calendar/calendar.d.ts.map +1 -1
  3. package/calendar.js +73 -66
  4. package/container/container.js +5 -5
  5. package/core/base-elements/open-close-base-element.d.ts +10 -0
  6. package/core/base-elements/open-close-base-element.d.ts.map +1 -1
  7. package/core/base-elements.js +4 -0
  8. package/core/controllers/inert-controller.d.ts +18 -0
  9. package/core/controllers/inert-controller.d.ts.map +1 -0
  10. package/core/controllers.d.ts +1 -0
  11. package/core/controllers.d.ts.map +1 -1
  12. package/core/controllers.js +67 -23
  13. package/core/overlay/overlay.d.ts +0 -13
  14. package/core/overlay/overlay.d.ts.map +1 -1
  15. package/core/overlay.js +36 -86
  16. package/custom-elements.json +369 -65
  17. package/datepicker/datepicker-toggle/datepicker-toggle.d.ts +4 -0
  18. package/datepicker/datepicker-toggle/datepicker-toggle.d.ts.map +1 -1
  19. package/datepicker/datepicker-toggle.js +51 -41
  20. package/development/calendar/calendar.d.ts +5 -2
  21. package/development/calendar/calendar.d.ts.map +1 -1
  22. package/development/calendar.js +35 -19
  23. package/development/container/container.js +8 -4
  24. package/development/core/base-elements/open-close-base-element.d.ts +10 -0
  25. package/development/core/base-elements/open-close-base-element.d.ts.map +1 -1
  26. package/development/core/base-elements.js +5 -1
  27. package/development/core/controllers/inert-controller.d.ts +18 -0
  28. package/development/core/controllers/inert-controller.d.ts.map +1 -0
  29. package/development/core/controllers.d.ts +1 -0
  30. package/development/core/controllers.d.ts.map +1 -1
  31. package/development/core/controllers.js +90 -1
  32. package/development/core/overlay/overlay.d.ts +0 -13
  33. package/development/core/overlay/overlay.d.ts.map +1 -1
  34. package/development/core/overlay.js +1 -87
  35. package/development/datepicker/datepicker-toggle/datepicker-toggle.d.ts +4 -0
  36. package/development/datepicker/datepicker-toggle/datepicker-toggle.d.ts.map +1 -1
  37. package/development/datepicker/datepicker-toggle.js +17 -2
  38. package/development/dialog/dialog/dialog.d.ts.map +1 -1
  39. package/development/dialog/dialog.js +3 -4
  40. package/development/flip-card/flip-card/flip-card.d.ts.map +1 -1
  41. package/development/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -1
  42. package/development/flip-card/flip-card-details.js +28 -9
  43. package/development/flip-card/flip-card-summary.js +6 -1
  44. package/development/flip-card/flip-card.js +43 -12
  45. package/development/form-field/form-field.js +4 -2
  46. package/development/lead-container.js +5 -1
  47. package/development/menu/menu/menu.d.ts +1 -0
  48. package/development/menu/menu/menu.d.ts.map +1 -1
  49. package/development/menu/menu.js +6 -9
  50. package/development/navigation/navigation/navigation.d.ts +1 -0
  51. package/development/navigation/navigation/navigation.d.ts.map +1 -1
  52. package/development/navigation/navigation.js +6 -9
  53. package/development/overlay/overlay-base-element.d.ts +2 -1
  54. package/development/overlay/overlay-base-element.d.ts.map +1 -1
  55. package/development/overlay/overlay.d.ts.map +1 -1
  56. package/development/overlay.js +5 -9
  57. package/development/popover/popover.js +2 -2
  58. package/development/toggle/toggle/toggle.d.ts +2 -1
  59. package/development/toggle/toggle/toggle.d.ts.map +1 -1
  60. package/development/toggle/toggle-option/toggle-option.d.ts.map +1 -1
  61. package/development/toggle/toggle-option.js +3 -2
  62. package/development/toggle/toggle.js +7 -7
  63. package/dialog/dialog/dialog.d.ts.map +1 -1
  64. package/dialog/dialog.js +11 -12
  65. package/flip-card/flip-card/flip-card.d.ts.map +1 -1
  66. package/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -1
  67. package/flip-card/flip-card-details.js +19 -17
  68. package/flip-card/flip-card-summary.js +13 -13
  69. package/flip-card/flip-card.js +26 -24
  70. package/form-field/form-field.js +1 -1
  71. package/lead-container.js +1 -1
  72. package/menu/menu/menu.d.ts +1 -0
  73. package/menu/menu/menu.d.ts.map +1 -1
  74. package/menu/menu.js +30 -30
  75. package/navigation/navigation/navigation.d.ts +1 -0
  76. package/navigation/navigation/navigation.d.ts.map +1 -1
  77. package/navigation/navigation.js +37 -37
  78. package/overlay/overlay-base-element.d.ts +2 -1
  79. package/overlay/overlay-base-element.d.ts.map +1 -1
  80. package/overlay/overlay.d.ts.map +1 -1
  81. package/overlay.js +44 -45
  82. package/package.json +1 -1
  83. package/popover/popover.js +1 -1
  84. package/toggle/toggle/toggle.d.ts +2 -1
  85. package/toggle/toggle/toggle.d.ts.map +1 -1
  86. package/toggle/toggle-option/toggle-option.d.ts.map +1 -1
  87. package/toggle/toggle-option.js +8 -8
  88. package/toggle/toggle.js +20 -21
@@ -45,10 +45,14 @@ const style = css`@charset "UTF-8";
45
45
  --sbb-container-padding: var(--sbb-spacing-responsive-xxl);
46
46
  }
47
47
 
48
- :host(:not([expanded])[background-expanded]) {
48
+ :host([background-expanded]:not([expanded])) {
49
49
  background-color: var(--sbb-container-background-color);
50
50
  }
51
51
 
52
+ :host([data-slot-names~=image][background-expanded]) {
53
+ position: relative;
54
+ }
55
+
52
56
  .sbb-container {
53
57
  background-color: var(--sbb-container-background-color);
54
58
  padding: var(--sbb-container-padding);
@@ -76,7 +80,7 @@ const style = css`@charset "UTF-8";
76
80
  :host([expanded]) .sbb-container {
77
81
  padding-inline: var(--sbb-spacing-responsive-xxs);
78
82
  }
79
- :host([data-slot-names~=image]) .sbb-container {
83
+ :host([data-slot-names~=image]:not([background-expanded])) .sbb-container {
80
84
  position: relative;
81
85
  }
82
86
 
@@ -90,7 +94,7 @@ const style = css`@charset "UTF-8";
90
94
  inset: 0;
91
95
  }
92
96
  @media (min-width: calc(90rem)) {
93
- :host(:not([expanded])) ::slotted([slot=image]) {
97
+ :host(:not([expanded], [background-expanded])) ::slotted([slot=image]) {
94
98
  --sbb-image-border-radius: var(--sbb-border-radius-4x);
95
99
  border-radius: var(--sbb-border-radius-4x);
96
100
  }
@@ -154,4 +158,4 @@ SbbContainerElement = __decorateClass([
154
158
  export {
155
159
  SbbContainerElement
156
160
  };
157
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFpbmVyLmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMvY29udGFpbmVyL2NvbnRhaW5lci9jb250YWluZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdHlwZSBDU1NSZXN1bHRHcm91cCxcbiAgaHRtbCxcbiAgTGl0RWxlbWVudCxcbiAgdHlwZSBQcm9wZXJ0eVZhbHVlcyxcbiAgdHlwZSBUZW1wbGF0ZVJlc3VsdCxcbn0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBzbG90U3RhdGUgfSBmcm9tICcuLi8uLi9jb3JlL2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9jb250YWluZXIuc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBJdCBkaXNwbGF5cyBpdHMgY29udGVudCB3aXRoIHRoZSBkZWZhdWx0IHBhZ2Ugc3BhY2luZy5cbiAqXG4gKiBAc2xvdCAtIFVzZSB0aGUgdW5uYW1lZCBzbG90IHRvIGFkZCBhbnl0aGluZyB0byB0aGUgY29udGFpbmVyLlxuICogQHNsb3Qgc3RpY2t5LWJhciAtIFRoZSBzbG90IHVzZWQgYnkgdGhlIHNiYi1zdGlja3ktYmFyIGNvbXBvbmVudC5cbiAqIEBzbG90IGltYWdlIC0gVGhlIHNsb3QgdXNlZCB0byBzbG90IGFuIGBzYmItaW1hZ2VgIHRvIHVzZSBhcyBiYWNrZ3JvdW5kLlxuICovXG5AY3VzdG9tRWxlbWVudCgnc2JiLWNvbnRhaW5lcicpXG5Ac2xvdFN0YXRlKClcbmV4cG9ydCBjbGFzcyBTYmJDb250YWluZXJFbGVtZW50IGV4dGVuZHMgTGl0RWxlbWVudCB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IHN0eWxlO1xuXG4gIC8qKiBXaGV0aGVyIHRoZSBjb250YWluZXIgaXMgZXhwYW5kZWQuICovXG4gIEBwcm9wZXJ0eSh7IHR5cGU6IEJvb2xlYW4sIHJlZmxlY3Q6IHRydWUgfSkgcHVibGljIGV4cGFuZGVkID0gZmFsc2U7XG5cbiAgLyoqIFdoZXRoZXIgdGhlIGJhY2tncm91bmQgY29sb3IgaXMgc2hvd24gb24gZnVsbCBjb250YWluZXIgd2lkdGggb24gbGFyZ2Ugc2NyZWVucy4gKi9cbiAgQHByb3BlcnR5KHsgdHlwZTogQm9vbGVhbiwgcmVmbGVjdDogdHJ1ZSwgYXR0cmlidXRlOiAnYmFja2dyb3VuZC1leHBhbmRlZCcgfSlcbiAgcHVibGljIGJhY2tncm91bmRFeHBhbmRlZCA9IGZhbHNlO1xuXG4gIC8qKiBDb2xvciBvZiB0aGUgY29udGFpbmVyLCBsaWtlIHRyYW5zcGFyZW50LCB3aGl0ZSBldGMuICovXG4gIEBwcm9wZXJ0eSh7IHJlZmxlY3Q6IHRydWUgfSkgcHVibGljIGNvbG9yOiAndHJhbnNwYXJlbnQnIHwgJ3doaXRlJyB8ICdtaWxrJyA9ICd3aGl0ZSc7XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHdpbGxVcGRhdGUoY2hhbmdlZFByb3BlcnRpZXM6IFByb3BlcnR5VmFsdWVzPHRoaXM+KTogdm9pZCB7XG4gICAgc3VwZXIud2lsbFVwZGF0ZShjaGFuZ2VkUHJvcGVydGllcyk7XG5cbiAgICBpZiAoY2hhbmdlZFByb3BlcnRpZXMuaGFzKCdleHBhbmRlZCcpKSB7XG4gICAgICB0aGlzLnF1ZXJ5U2VsZWN0b3I/Lignc2JiLXN0aWNreS1iYXInKT8udG9nZ2xlQXR0cmlidXRlKCdkYXRhLWV4cGFuZGVkJywgdGhpcy5leHBhbmRlZCk7XG4gICAgfVxuICB9XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgcmV0dXJuIGh0bWxgXG4gICAgICA8ZGl2IGNsYXNzPVwic2JiLWNvbnRhaW5lclwiPlxuICAgICAgICA8c2xvdCBuYW1lPVwiaW1hZ2VcIj48L3Nsb3Q+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJzYmItY29udGFpbmVyX19jb250ZW50XCI+XG4gICAgICAgICAgPHNsb3Q+PC9zbG90PlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuICAgICAgPHNsb3QgbmFtZT1cInN0aWNreS1iYXJcIj48L3Nsb3Q+XG4gICAgYDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLWNvbnRhaW5lcic6IFNiYkNvbnRhaW5lckVsZW1lbnQ7XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQXNCYSxJQUFBLHNCQUFOLGNBQWtDLFdBQVc7QUFBQSxFQUE3QyxjQUFBO0FBQUEsVUFBQSxHQUFBLFNBQUE7QUFJdUMsU0FBTyxXQUFXO0FBSTlELFNBQU8scUJBQXFCO0FBR0MsU0FBTyxRQUEwQztBQUFBLEVBQUE7QUFBQSxFQUUzRCxXQUFXLG1CQUErQzs7QUFDM0UsVUFBTSxXQUFXLGlCQUFpQjtBQUU5QixRQUFBLGtCQUFrQixJQUFJLFVBQVUsR0FBRztBQUNyQyx1QkFBSyxrQkFBTCw4QkFBcUIsc0JBQXJCLG1CQUF3QyxnQkFBZ0IsaUJBQWlCLEtBQUs7QUFBQSxJQUNoRjtBQUFBLEVBQ0Y7QUFBQSxFQUVtQixTQUF5QjtBQUNuQyxXQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBU1Q7QUFDRjtBQWhDYSxvQkFDWSxTQUF5QjtBQUdHLGdCQUFBO0FBQUEsRUFBbEQsU0FBUyxFQUFFLE1BQU0sU0FBUyxTQUFTLE1BQU07QUFBQSxHQUovQixvQkFJd0MsV0FBQSxZQUFBLENBQUE7QUFJNUMsZ0JBQUE7QUFBQSxFQUROLFNBQVMsRUFBRSxNQUFNLFNBQVMsU0FBUyxNQUFNLFdBQVcsdUJBQXVCO0FBQUEsR0FQakUsb0JBUUosV0FBQSxzQkFBQSxDQUFBO0FBRzZCLGdCQUFBO0FBQUEsRUFBbkMsU0FBUyxFQUFFLFNBQVMsTUFBTTtBQUFBLEdBWGhCLG9CQVd5QixXQUFBLFNBQUEsQ0FBQTtBQVh6QixzQkFBTixnQkFBQTtBQUFBLEVBRk4sY0FBYyxlQUFlO0FBQUEsRUFDN0IsVUFBVTtBQUFBLEdBQ0UsbUJBQUE7In0=
161
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFpbmVyLmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMvY29udGFpbmVyL2NvbnRhaW5lci9jb250YWluZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdHlwZSBDU1NSZXN1bHRHcm91cCxcbiAgaHRtbCxcbiAgTGl0RWxlbWVudCxcbiAgdHlwZSBQcm9wZXJ0eVZhbHVlcyxcbiAgdHlwZSBUZW1wbGF0ZVJlc3VsdCxcbn0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBzbG90U3RhdGUgfSBmcm9tICcuLi8uLi9jb3JlL2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9jb250YWluZXIuc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBJdCBkaXNwbGF5cyBpdHMgY29udGVudCB3aXRoIHRoZSBkZWZhdWx0IHBhZ2Ugc3BhY2luZy5cbiAqXG4gKiBAc2xvdCAtIFVzZSB0aGUgdW5uYW1lZCBzbG90IHRvIGFkZCBhbnl0aGluZyB0byB0aGUgY29udGFpbmVyLlxuICogQHNsb3Qgc3RpY2t5LWJhciAtIFRoZSBzbG90IHVzZWQgYnkgdGhlIHNiYi1zdGlja3ktYmFyIGNvbXBvbmVudC5cbiAqIEBzbG90IGltYWdlIC0gVGhlIHNsb3QgdXNlZCB0byBzbG90IGFuIGBzYmItaW1hZ2VgIHRvIHVzZSBhcyBiYWNrZ3JvdW5kLlxuICovXG5AY3VzdG9tRWxlbWVudCgnc2JiLWNvbnRhaW5lcicpXG5Ac2xvdFN0YXRlKClcbmV4cG9ydCBjbGFzcyBTYmJDb250YWluZXJFbGVtZW50IGV4dGVuZHMgTGl0RWxlbWVudCB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IHN0eWxlO1xuXG4gIC8qKiBXaGV0aGVyIHRoZSBjb250YWluZXIgaXMgZXhwYW5kZWQuICovXG4gIEBwcm9wZXJ0eSh7IHR5cGU6IEJvb2xlYW4sIHJlZmxlY3Q6IHRydWUgfSkgcHVibGljIGV4cGFuZGVkID0gZmFsc2U7XG5cbiAgLyoqIFdoZXRoZXIgdGhlIGJhY2tncm91bmQgY29sb3IgaXMgc2hvd24gb24gZnVsbCBjb250YWluZXIgd2lkdGggb24gbGFyZ2Ugc2NyZWVucy4gKi9cbiAgQHByb3BlcnR5KHsgdHlwZTogQm9vbGVhbiwgcmVmbGVjdDogdHJ1ZSwgYXR0cmlidXRlOiAnYmFja2dyb3VuZC1leHBhbmRlZCcgfSlcbiAgcHVibGljIGJhY2tncm91bmRFeHBhbmRlZCA9IGZhbHNlO1xuXG4gIC8qKiBDb2xvciBvZiB0aGUgY29udGFpbmVyLCBsaWtlIHRyYW5zcGFyZW50LCB3aGl0ZSBldGMuICovXG4gIEBwcm9wZXJ0eSh7IHJlZmxlY3Q6IHRydWUgfSkgcHVibGljIGNvbG9yOiAndHJhbnNwYXJlbnQnIHwgJ3doaXRlJyB8ICdtaWxrJyA9ICd3aGl0ZSc7XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHdpbGxVcGRhdGUoY2hhbmdlZFByb3BlcnRpZXM6IFByb3BlcnR5VmFsdWVzPHRoaXM+KTogdm9pZCB7XG4gICAgc3VwZXIud2lsbFVwZGF0ZShjaGFuZ2VkUHJvcGVydGllcyk7XG5cbiAgICBpZiAoY2hhbmdlZFByb3BlcnRpZXMuaGFzKCdleHBhbmRlZCcpKSB7XG4gICAgICB0aGlzLnF1ZXJ5U2VsZWN0b3I/Lignc2JiLXN0aWNreS1iYXInKT8udG9nZ2xlQXR0cmlidXRlKCdkYXRhLWV4cGFuZGVkJywgdGhpcy5leHBhbmRlZCk7XG4gICAgfVxuICB9XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgcmV0dXJuIGh0bWxgXG4gICAgICA8ZGl2IGNsYXNzPVwic2JiLWNvbnRhaW5lclwiPlxuICAgICAgICA8c2xvdCBuYW1lPVwiaW1hZ2VcIj48L3Nsb3Q+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJzYmItY29udGFpbmVyX19jb250ZW50XCI+XG4gICAgICAgICAgPHNsb3Q+PC9zbG90PlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuICAgICAgPHNsb3QgbmFtZT1cInN0aWNreS1iYXJcIj48L3Nsb3Q+XG4gICAgYDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLWNvbnRhaW5lcic6IFNiYkNvbnRhaW5lckVsZW1lbnQ7XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFzQmEsSUFBQSxzQkFBTixjQUFrQyxXQUFXO0FBQUEsRUFBN0MsY0FBQTtBQUFBLFVBQUEsR0FBQSxTQUFBO0FBSXVDLFNBQU8sV0FBVztBQUk5RCxTQUFPLHFCQUFxQjtBQUdDLFNBQU8sUUFBMEM7QUFBQSxFQUFBO0FBQUEsRUFFM0QsV0FBVyxtQkFBK0M7O0FBQzNFLFVBQU0sV0FBVyxpQkFBaUI7QUFFOUIsUUFBQSxrQkFBa0IsSUFBSSxVQUFVLEdBQUc7QUFDckMsdUJBQUssa0JBQUwsOEJBQXFCLHNCQUFyQixtQkFBd0MsZ0JBQWdCLGlCQUFpQixLQUFLO0FBQUEsSUFDaEY7QUFBQSxFQUNGO0FBQUEsRUFFbUIsU0FBeUI7QUFDbkMsV0FBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxFQVNUO0FBQ0Y7QUFoQ2Esb0JBQ1ksU0FBeUI7QUFHRyxnQkFBQTtBQUFBLEVBQWxELFNBQVMsRUFBRSxNQUFNLFNBQVMsU0FBUyxNQUFNO0FBQUEsR0FKL0Isb0JBSXdDLFdBQUEsWUFBQSxDQUFBO0FBSTVDLGdCQUFBO0FBQUEsRUFETixTQUFTLEVBQUUsTUFBTSxTQUFTLFNBQVMsTUFBTSxXQUFXLHVCQUF1QjtBQUFBLEdBUGpFLG9CQVFKLFdBQUEsc0JBQUEsQ0FBQTtBQUc2QixnQkFBQTtBQUFBLEVBQW5DLFNBQVMsRUFBRSxTQUFTLE1BQU07QUFBQSxHQVhoQixvQkFXeUIsV0FBQSxTQUFBLENBQUE7QUFYekIsc0JBQU4sZ0JBQUE7QUFBQSxFQUZOLGNBQWMsZUFBZTtBQUFBLEVBQzdCLFVBQVU7QUFBQSxHQUNFLG1CQUFBOyJ9
@@ -19,6 +19,8 @@ export declare abstract class SbbOpenCloseBaseElement extends LitElement {
19
19
  /** The state of the component. */
20
20
  protected set state(state: SbbOpenedClosedState);
21
21
  protected get state(): SbbOpenedClosedState;
22
+ /** Whether the element is open. */
23
+ get isOpen(): boolean;
22
24
  /** Emits whenever the component starts the opening transition. */
23
25
  protected willOpen: EventEmitter;
24
26
  /** Emits whenever the component is opened. */
@@ -33,4 +35,12 @@ export declare abstract class SbbOpenCloseBaseElement extends LitElement {
33
35
  abstract close(): void;
34
36
  connectedCallback(): void;
35
37
  }
38
+ declare global {
39
+ interface GlobalEventHandlersEventMap {
40
+ willOpen: CustomEvent<void>;
41
+ willClose: CustomEvent<void>;
42
+ didOpen: CustomEvent<void>;
43
+ didClose: CustomEvent<void>;
44
+ }
45
+ }
36
46
  //# sourceMappingURL=open-close-base-element.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"open-close-base-element.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/base-elements/open-close-base-element.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,KAAK,CAAC;AAEjC,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAE7D;;;;;;;GAOG;AACH,8BAAsB,uBAAwB,SAAQ,UAAU;IAC9D,gBAAuB,MAAM;;;;;MAKlB;IAEX,kCAAkC;IAClC,SAAS,KAAK,KAAK,CAAC,KAAK,EAAE,oBAAoB,EAE9C;IACD,SAAS,KAAK,KAAK,IAAI,oBAAoB,CAE1C;IAED,kEAAkE;IAClE,SAAS,CAAC,QAAQ,EAAE,YAAY,CAG9B;IAEF,8CAA8C;IAC9C,SAAS,CAAC,OAAO,EAAE,YAAY,CAAkE;IAEjG,kEAAkE;IAClE,SAAS,CAAC,SAAS,EAAE,YAAY,CAG/B;IAEF,8CAA8C;IAC9C,SAAS,CAAC,QAAQ,EAAE,YAAY,CAG9B;IAEF,2BAA2B;aACX,IAAI,IAAI,IAAI;IAC5B,4BAA4B;aACZ,KAAK,IAAI,IAAI;IAEb,iBAAiB,IAAI,IAAI;CAI1C"}
1
+ {"version":3,"file":"open-close-base-element.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/base-elements/open-close-base-element.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,KAAK,CAAC;AAEjC,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAE7D;;;;;;;GAOG;AACH,8BAAsB,uBAAwB,SAAQ,UAAU;IAC9D,gBAAuB,MAAM;;;;;MAKlB;IAEX,kCAAkC;IAClC,SAAS,KAAK,KAAK,CAAC,KAAK,EAAE,oBAAoB,EAE9C;IACD,SAAS,KAAK,KAAK,IAAI,oBAAoB,CAE1C;IAED,mCAAmC;IACnC,IAAW,MAAM,IAAI,OAAO,CAE3B;IAED,kEAAkE;IAClE,SAAS,CAAC,QAAQ,EAAE,YAAY,CAG9B;IAEF,8CAA8C;IAC9C,SAAS,CAAC,OAAO,EAAE,YAAY,CAAkE;IAEjG,kEAAkE;IAClE,SAAS,CAAC,SAAS,EAAE,YAAY,CAG/B;IAEF,8CAA8C;IAC9C,SAAS,CAAC,QAAQ,EAAE,YAAY,CAG9B;IAEF,2BAA2B;aACX,IAAI,IAAI,IAAI;IAC5B,4BAA4B;aACZ,KAAK,IAAI,IAAI;IAEb,iBAAiB,IAAI,IAAI;CAI1C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,2BAA2B;QACnC,QAAQ,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;QAC5B,SAAS,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;QAC7B,OAAO,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;QAC3B,QAAQ,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;KAC7B;CACF"}
@@ -268,6 +268,10 @@ const _SbbOpenCloseBaseElement = class _SbbOpenCloseBaseElement extends LitEleme
268
268
  get state() {
269
269
  return this.getAttribute("data-state");
270
270
  }
271
+ /** Whether the element is open. */
272
+ get isOpen() {
273
+ return this.state === "opened";
274
+ }
271
275
  connectedCallback() {
272
276
  super.connectedCallback();
273
277
  this.state || (this.state = "closed");
@@ -286,4 +290,4 @@ export {
286
290
  SbbLinkBaseElement,
287
291
  SbbOpenCloseBaseElement
288
292
  };
289
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"base-elements.js","sources":["../../../../src/elements/core/base-elements/action-base-element.ts","../../../../src/elements/core/base-elements/button-base-element.ts","../../../../src/elements/core/base-elements/link-base-element.ts","../../../../src/elements/core/base-elements/open-close-base-element.ts"],"sourcesContent":["import { html, LitElement, type TemplateResult } from 'lit';\n\nimport { hostAttributes } from '../decorators.js';\nimport { getDocumentWritingMode, getLocalName } from '../dom.js';\n\n/**\n * Whenever an element can be disabled it has disabled property\n * or formDisabled if it's a form element.\n * Because we can't use types here directly we created this helper type.\n */\ntype MaybeDisabled = {\n  disabled?: boolean;\n  formDisabled?: boolean;\n};\n\n@hostAttributes({\n  dir: getDocumentWritingMode(),\n  'data-action': '',\n})\nexport abstract class SbbActionBaseElement extends LitElement {\n  protected get maybeDisabled(): boolean | undefined {\n    const maybeDisabled = this as MaybeDisabled;\n    return maybeDisabled.disabled || maybeDisabled.formDisabled;\n  }\n\n  protected setupBaseEventHandlers(): void {\n    this.addEventListener(\n      'click',\n      (event) => {\n        if (this.maybeDisabled) {\n          event.preventDefault();\n          event.stopImmediatePropagation();\n        }\n      },\n      // capture is necessary here, as this event handler needs to be executed before any other\n      // in order to stop immediate propagation in the disabled case.\n      { capture: true },\n    );\n  }\n\n  /** Override this method to render the component template. */\n  protected renderTemplate(): TemplateResult {\n    throw new Error('Implementation needed!');\n  }\n\n  /** Default render method for button-like components. */\n  protected override render(): TemplateResult {\n    return html`\n      <span class=\"sbb-action-base ${this.localName ?? getLocalName(this)}\">\n        ${this.renderTemplate()}\n      </span>\n    `;\n  }\n}\n","import { isServer } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { hostAttributes } from '../decorators.js';\nimport { isEventPrevented } from '../eventing.js';\n\nimport { SbbActionBaseElement } from './action-base-element.js';\n\n/** Enumeration for type attribute in <button> HTML tag. */\nexport type SbbButtonType = 'button' | 'reset' | 'submit';\n\n/** Button base class. */\n@hostAttributes({\n  role: 'button',\n  tabindex: '0',\n  'data-button': '',\n})\nexport abstract class SbbButtonBaseElement extends SbbActionBaseElement {\n  /** The type attribute to use for the button. */\n  @property() public type: SbbButtonType = 'button';\n\n  /**\n   * The name of the button element.\n   *\n   * @description Developer note: In this case updating the attribute must be synchronous.\n   * Due to this it is implemented as a getter/setter and the attributeChangedCallback() handles the diff check.\n   */\n  @property()\n  public set name(name: string) {\n    this.setAttribute('name', `${name}`);\n  }\n  public get name(): string {\n    return this.getAttribute('name') ?? '';\n  }\n\n  /**\n   * The value of the button element.\n   *\n   * @description Developer note: In this case updating the attribute must be synchronous.\n   * Due to this it is implemented as a getter/setter and the attributeChangedCallback() handles the diff check.\n   */\n  @property()\n  public set value(value: string) {\n    this.setAttribute('value', `${value}`);\n  }\n  public get value(): string {\n    return this.getAttribute('value') ?? '';\n  }\n\n  /** The <form> element to associate the button with. */\n  @property() public form?: string;\n\n  private _handleButtonClick = async (event: MouseEvent): Promise<void> => {\n    if (this.type === 'button' || (await isEventPrevented(event))) {\n      return;\n    }\n\n    // Use querySelector with form and id selector, as the form property must\n    // reference a valid <form> element\n    const form = this.form\n      ? (this.ownerDocument.querySelector(`form#${this.form}`) as HTMLFormElement)\n      : this.closest('form');\n    if (!form) {\n      return;\n    } else if (this.type === 'submit') {\n      // `form.requestSubmit(element);` seems not to work for CustomElements, so the `element` parameter has been removed;\n      // TODO: Check if solved in any way, see https://github.com/WICG/webcomponents/issues/814#issuecomment-1218452137\n      form.requestSubmit();\n    } else if (this.type === 'reset') {\n      form.reset();\n    }\n  };\n\n  /**\n   * Prevents scrolling from pressing Space, when the event target is an action element.\n   * Also sets data-active attribute.\n   * @param event The origin event.\n   */\n  private _preventScrollOnSpaceKeydown = (event: KeyboardEvent): void => {\n    if (event.key === ' ') {\n      event.preventDefault();\n      (event.target as HTMLElement).toggleAttribute('data-active', true);\n    }\n  };\n\n  private _removeActiveMarker = (event: Event): void => {\n    (event.target as HTMLElement).removeAttribute('data-active');\n  };\n\n  /**\n   * Dispatches a 'click' PointerEvent if the original keyboard event is a 'Space' press.\n   * As verified with the native button, when 'Space' is pressed, a 'click' event is dispatched\n   * after the 'keyup' event.\n   * @param event The origin event.\n   */\n  private _dispatchClickEventOnSpaceKeyup = (event: KeyboardEvent): void => {\n    if (event.key === ' ') {\n      this._removeActiveMarker(event);\n      this._dispatchClickEvent(event);\n    }\n  };\n\n  private _dispatchClickEvent = (event: KeyboardEvent): void => {\n    const { altKey, ctrlKey, metaKey, shiftKey } = event;\n    (event.target as Element).dispatchEvent(\n      new PointerEvent('click', {\n        bubbles: true,\n        cancelable: true,\n        composed: true,\n        pointerId: -1,\n        pointerType: '',\n        altKey,\n        ctrlKey,\n        metaKey,\n        shiftKey,\n      }),\n    );\n  };\n\n  public constructor() {\n    super();\n    if (!isServer) {\n      this.setupBaseEventHandlers();\n\n      const passiveOptions = { passive: true };\n      this.addEventListener('click', this._handleButtonClick);\n      this.addEventListener('keydown', this._preventScrollOnSpaceKeydown);\n      this.addEventListener('keyup', this._dispatchClickEventOnSpaceKeyup, passiveOptions);\n      this.addEventListener('blur', this._removeActiveMarker, passiveOptions);\n      this.addEventListener(\n        'keypress',\n        (event: KeyboardEvent): void => {\n          if (event.key === 'Enter' || event.key === '\\n') {\n            this._dispatchClickEvent(event);\n          }\n        },\n        passiveOptions,\n      );\n    }\n  }\n\n  public override attributeChangedCallback(\n    name: string,\n    old: string | null,\n    value: string | null,\n  ): void {\n    if (!['name', 'value'].includes(name) || old !== value) {\n      super.attributeChangedCallback(name, old, value);\n    }\n  }\n}\n","import { html, isServer, nothing, type TemplateResult } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbLanguageController } from '../controllers.js';\nimport { hostAttributes } from '../decorators.js';\nimport { getLocalName } from '../dom.js';\nimport { i18nTargetOpensInNewWindow } from '../i18n.js';\n\nimport { SbbActionBaseElement } from './action-base-element.js';\n\nimport '../../screen-reader-only.js';\n\n/** Enumeration for 'target' attribute in <a> HTML tag. */\nexport type LinkTargetType = '_blank' | '_self' | '_parent' | '_top';\n\n/** Link base class. */\n@hostAttributes({\n  'data-link': '',\n})\nexport abstract class SbbLinkBaseElement extends SbbActionBaseElement {\n  /** The href value you want to link to. */\n  @property() public href?: string;\n\n  /** Where to display the linked URL. */\n  @property() public target?: LinkTargetType | string;\n\n  /** The relationship of the linked URL as space-separated link types. */\n  @property() public rel?: string;\n\n  /** Whether the browser will show the download dialog on click. */\n  @property({ type: Boolean }) public download?: boolean;\n\n  /** This will be forwarded as aria-label to the inner anchor element. */\n  @property({ attribute: 'accessibility-label' }) public accessibilityLabel: string | undefined;\n\n  protected language = new SbbLanguageController(this);\n\n  public constructor() {\n    super();\n    if (!isServer) {\n      this.setupBaseEventHandlers();\n    }\n  }\n\n  /** @internal */\n  public override focus(options?: FocusOptions | undefined): void {\n    this.shadowRoot!.querySelector<HTMLAnchorElement>('a')?.focus(options);\n  }\n\n  /** @internal */\n  public override blur(): void {\n    this.shadowRoot!.querySelector<HTMLAnchorElement>('a')?.blur();\n  }\n\n  /** @internal */\n  public override click(): void {\n    this.shadowRoot!.querySelector<HTMLAnchorElement>('a')?.click();\n  }\n\n  private _evaluateRelAttribute = (): string | typeof nothing => {\n    return this.rel ? this.rel : this.target === '_blank' ? 'external noopener nofollow' : nothing;\n  };\n\n  /** Default render method for link-like components. Can be overridden if the LinkRenderVariables are not needed. */\n  protected override render(): TemplateResult {\n    return html`\n      <a\n        class=\"sbb-action-base ${this.localName ?? getLocalName(this)}\"\n        href=${this.href || nothing}\n        ?download=${this.download}\n        target=${this.target || nothing}\n        rel=${this._evaluateRelAttribute()}\n        aria-label=${this.accessibilityLabel || nothing}\n        tabindex=${this.maybeDisabled ? '-1' : nothing}\n        aria-disabled=${this.maybeDisabled ? 'true' : nothing}\n      >\n        ${this.renderTemplate()}\n        ${!!this.href && this.target === '_blank'\n          ? html`<sbb-screen-reader-only\n              >. ${i18nTargetOpensInNewWindow[this.language.current]}</sbb-screen-reader-only\n            >`\n          : nothing}\n      </a>\n    `;\n  }\n}\n","import { LitElement } from 'lit';\n\nimport { EventEmitter } from '../eventing.js';\nimport type { SbbOpenedClosedState } from '../interfaces.js';\n\n/**\n * Base class for overlay components.\n *\n * @event willOpen - Emits whenever the component starts the opening transition. Can be canceled.\n * @event didOpen - Emits whenever the component is opened.\n * @event willClose - Emits whenever the component begins the closing transition. Can be canceled.\n * @event didClose - Emits whenever the component is closed.\n */\nexport abstract class SbbOpenCloseBaseElement extends LitElement {\n  public static readonly events = {\n    willOpen: 'willOpen',\n    didOpen: 'didOpen',\n    willClose: 'willClose',\n    didClose: 'didClose',\n  } as const;\n\n  /** The state of the component. */\n  protected set state(state: SbbOpenedClosedState) {\n    this.setAttribute('data-state', state);\n  }\n  protected get state(): SbbOpenedClosedState {\n    return this.getAttribute('data-state') as SbbOpenedClosedState;\n  }\n\n  /** Emits whenever the component starts the opening transition. */\n  protected willOpen: EventEmitter = new EventEmitter(\n    this,\n    SbbOpenCloseBaseElement.events.willOpen,\n  );\n\n  /** Emits whenever the component is opened. */\n  protected didOpen: EventEmitter = new EventEmitter(this, SbbOpenCloseBaseElement.events.didOpen);\n\n  /** Emits whenever the component begins the closing transition. */\n  protected willClose: EventEmitter = new EventEmitter(\n    this,\n    SbbOpenCloseBaseElement.events.willClose,\n  );\n\n  /** Emits whenever the component is closed. */\n  protected didClose: EventEmitter = new EventEmitter(\n    this,\n    SbbOpenCloseBaseElement.events.didClose,\n  );\n\n  /** Opens the component. */\n  public abstract open(): void;\n  /** Closes the component. */\n  public abstract close(): void;\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.state ||= 'closed';\n  }\n}\n"],"names":["__decorateClass"],"mappings":"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"}
293
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"base-elements.js","sources":["../../../../src/elements/core/base-elements/action-base-element.ts","../../../../src/elements/core/base-elements/button-base-element.ts","../../../../src/elements/core/base-elements/link-base-element.ts","../../../../src/elements/core/base-elements/open-close-base-element.ts"],"sourcesContent":["import { html, LitElement, type TemplateResult } from 'lit';\n\nimport { hostAttributes } from '../decorators.js';\nimport { getDocumentWritingMode, getLocalName } from '../dom.js';\n\n/**\n * Whenever an element can be disabled it has disabled property\n * or formDisabled if it's a form element.\n * Because we can't use types here directly we created this helper type.\n */\ntype MaybeDisabled = {\n  disabled?: boolean;\n  formDisabled?: boolean;\n};\n\n@hostAttributes({\n  dir: getDocumentWritingMode(),\n  'data-action': '',\n})\nexport abstract class SbbActionBaseElement extends LitElement {\n  protected get maybeDisabled(): boolean | undefined {\n    const maybeDisabled = this as MaybeDisabled;\n    return maybeDisabled.disabled || maybeDisabled.formDisabled;\n  }\n\n  protected setupBaseEventHandlers(): void {\n    this.addEventListener(\n      'click',\n      (event) => {\n        if (this.maybeDisabled) {\n          event.preventDefault();\n          event.stopImmediatePropagation();\n        }\n      },\n      // capture is necessary here, as this event handler needs to be executed before any other\n      // in order to stop immediate propagation in the disabled case.\n      { capture: true },\n    );\n  }\n\n  /** Override this method to render the component template. */\n  protected renderTemplate(): TemplateResult {\n    throw new Error('Implementation needed!');\n  }\n\n  /** Default render method for button-like components. */\n  protected override render(): TemplateResult {\n    return html`\n      <span class=\"sbb-action-base ${this.localName ?? getLocalName(this)}\">\n        ${this.renderTemplate()}\n      </span>\n    `;\n  }\n}\n","import { isServer } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { hostAttributes } from '../decorators.js';\nimport { isEventPrevented } from '../eventing.js';\n\nimport { SbbActionBaseElement } from './action-base-element.js';\n\n/** Enumeration for type attribute in <button> HTML tag. */\nexport type SbbButtonType = 'button' | 'reset' | 'submit';\n\n/** Button base class. */\n@hostAttributes({\n  role: 'button',\n  tabindex: '0',\n  'data-button': '',\n})\nexport abstract class SbbButtonBaseElement extends SbbActionBaseElement {\n  /** The type attribute to use for the button. */\n  @property() public type: SbbButtonType = 'button';\n\n  /**\n   * The name of the button element.\n   *\n   * @description Developer note: In this case updating the attribute must be synchronous.\n   * Due to this it is implemented as a getter/setter and the attributeChangedCallback() handles the diff check.\n   */\n  @property()\n  public set name(name: string) {\n    this.setAttribute('name', `${name}`);\n  }\n  public get name(): string {\n    return this.getAttribute('name') ?? '';\n  }\n\n  /**\n   * The value of the button element.\n   *\n   * @description Developer note: In this case updating the attribute must be synchronous.\n   * Due to this it is implemented as a getter/setter and the attributeChangedCallback() handles the diff check.\n   */\n  @property()\n  public set value(value: string) {\n    this.setAttribute('value', `${value}`);\n  }\n  public get value(): string {\n    return this.getAttribute('value') ?? '';\n  }\n\n  /** The <form> element to associate the button with. */\n  @property() public form?: string;\n\n  private _handleButtonClick = async (event: MouseEvent): Promise<void> => {\n    if (this.type === 'button' || (await isEventPrevented(event))) {\n      return;\n    }\n\n    // Use querySelector with form and id selector, as the form property must\n    // reference a valid <form> element\n    const form = this.form\n      ? (this.ownerDocument.querySelector(`form#${this.form}`) as HTMLFormElement)\n      : this.closest('form');\n    if (!form) {\n      return;\n    } else if (this.type === 'submit') {\n      // `form.requestSubmit(element);` seems not to work for CustomElements, so the `element` parameter has been removed;\n      // TODO: Check if solved in any way, see https://github.com/WICG/webcomponents/issues/814#issuecomment-1218452137\n      form.requestSubmit();\n    } else if (this.type === 'reset') {\n      form.reset();\n    }\n  };\n\n  /**\n   * Prevents scrolling from pressing Space, when the event target is an action element.\n   * Also sets data-active attribute.\n   * @param event The origin event.\n   */\n  private _preventScrollOnSpaceKeydown = (event: KeyboardEvent): void => {\n    if (event.key === ' ') {\n      event.preventDefault();\n      (event.target as HTMLElement).toggleAttribute('data-active', true);\n    }\n  };\n\n  private _removeActiveMarker = (event: Event): void => {\n    (event.target as HTMLElement).removeAttribute('data-active');\n  };\n\n  /**\n   * Dispatches a 'click' PointerEvent if the original keyboard event is a 'Space' press.\n   * As verified with the native button, when 'Space' is pressed, a 'click' event is dispatched\n   * after the 'keyup' event.\n   * @param event The origin event.\n   */\n  private _dispatchClickEventOnSpaceKeyup = (event: KeyboardEvent): void => {\n    if (event.key === ' ') {\n      this._removeActiveMarker(event);\n      this._dispatchClickEvent(event);\n    }\n  };\n\n  private _dispatchClickEvent = (event: KeyboardEvent): void => {\n    const { altKey, ctrlKey, metaKey, shiftKey } = event;\n    (event.target as Element).dispatchEvent(\n      new PointerEvent('click', {\n        bubbles: true,\n        cancelable: true,\n        composed: true,\n        pointerId: -1,\n        pointerType: '',\n        altKey,\n        ctrlKey,\n        metaKey,\n        shiftKey,\n      }),\n    );\n  };\n\n  public constructor() {\n    super();\n    if (!isServer) {\n      this.setupBaseEventHandlers();\n\n      const passiveOptions = { passive: true };\n      this.addEventListener('click', this._handleButtonClick);\n      this.addEventListener('keydown', this._preventScrollOnSpaceKeydown);\n      this.addEventListener('keyup', this._dispatchClickEventOnSpaceKeyup, passiveOptions);\n      this.addEventListener('blur', this._removeActiveMarker, passiveOptions);\n      this.addEventListener(\n        'keypress',\n        (event: KeyboardEvent): void => {\n          if (event.key === 'Enter' || event.key === '\\n') {\n            this._dispatchClickEvent(event);\n          }\n        },\n        passiveOptions,\n      );\n    }\n  }\n\n  public override attributeChangedCallback(\n    name: string,\n    old: string | null,\n    value: string | null,\n  ): void {\n    if (!['name', 'value'].includes(name) || old !== value) {\n      super.attributeChangedCallback(name, old, value);\n    }\n  }\n}\n","import { html, isServer, nothing, type TemplateResult } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbLanguageController } from '../controllers.js';\nimport { hostAttributes } from '../decorators.js';\nimport { getLocalName } from '../dom.js';\nimport { i18nTargetOpensInNewWindow } from '../i18n.js';\n\nimport { SbbActionBaseElement } from './action-base-element.js';\n\nimport '../../screen-reader-only.js';\n\n/** Enumeration for 'target' attribute in <a> HTML tag. */\nexport type LinkTargetType = '_blank' | '_self' | '_parent' | '_top';\n\n/** Link base class. */\n@hostAttributes({\n  'data-link': '',\n})\nexport abstract class SbbLinkBaseElement extends SbbActionBaseElement {\n  /** The href value you want to link to. */\n  @property() public href?: string;\n\n  /** Where to display the linked URL. */\n  @property() public target?: LinkTargetType | string;\n\n  /** The relationship of the linked URL as space-separated link types. */\n  @property() public rel?: string;\n\n  /** Whether the browser will show the download dialog on click. */\n  @property({ type: Boolean }) public download?: boolean;\n\n  /** This will be forwarded as aria-label to the inner anchor element. */\n  @property({ attribute: 'accessibility-label' }) public accessibilityLabel: string | undefined;\n\n  protected language = new SbbLanguageController(this);\n\n  public constructor() {\n    super();\n    if (!isServer) {\n      this.setupBaseEventHandlers();\n    }\n  }\n\n  /** @internal */\n  public override focus(options?: FocusOptions | undefined): void {\n    this.shadowRoot!.querySelector<HTMLAnchorElement>('a')?.focus(options);\n  }\n\n  /** @internal */\n  public override blur(): void {\n    this.shadowRoot!.querySelector<HTMLAnchorElement>('a')?.blur();\n  }\n\n  /** @internal */\n  public override click(): void {\n    this.shadowRoot!.querySelector<HTMLAnchorElement>('a')?.click();\n  }\n\n  private _evaluateRelAttribute = (): string | typeof nothing => {\n    return this.rel ? this.rel : this.target === '_blank' ? 'external noopener nofollow' : nothing;\n  };\n\n  /** Default render method for link-like components. Can be overridden if the LinkRenderVariables are not needed. */\n  protected override render(): TemplateResult {\n    return html`\n      <a\n        class=\"sbb-action-base ${this.localName ?? getLocalName(this)}\"\n        href=${this.href || nothing}\n        ?download=${this.download}\n        target=${this.target || nothing}\n        rel=${this._evaluateRelAttribute()}\n        aria-label=${this.accessibilityLabel || nothing}\n        tabindex=${this.maybeDisabled ? '-1' : nothing}\n        aria-disabled=${this.maybeDisabled ? 'true' : nothing}\n      >\n        ${this.renderTemplate()}\n        ${!!this.href && this.target === '_blank'\n          ? html`<sbb-screen-reader-only\n              >. ${i18nTargetOpensInNewWindow[this.language.current]}</sbb-screen-reader-only\n            >`\n          : nothing}\n      </a>\n    `;\n  }\n}\n","import { LitElement } from 'lit';\n\nimport { EventEmitter } from '../eventing.js';\nimport type { SbbOpenedClosedState } from '../interfaces.js';\n\n/**\n * Base class for overlay components.\n *\n * @event willOpen - Emits whenever the component starts the opening transition. Can be canceled.\n * @event didOpen - Emits whenever the component is opened.\n * @event willClose - Emits whenever the component begins the closing transition. Can be canceled.\n * @event didClose - Emits whenever the component is closed.\n */\nexport abstract class SbbOpenCloseBaseElement extends LitElement {\n  public static readonly events = {\n    willOpen: 'willOpen',\n    didOpen: 'didOpen',\n    willClose: 'willClose',\n    didClose: 'didClose',\n  } as const;\n\n  /** The state of the component. */\n  protected set state(state: SbbOpenedClosedState) {\n    this.setAttribute('data-state', state);\n  }\n  protected get state(): SbbOpenedClosedState {\n    return this.getAttribute('data-state') as SbbOpenedClosedState;\n  }\n\n  /** Whether the element is open. */\n  public get isOpen(): boolean {\n    return this.state === 'opened';\n  }\n\n  /** Emits whenever the component starts the opening transition. */\n  protected willOpen: EventEmitter = new EventEmitter(\n    this,\n    SbbOpenCloseBaseElement.events.willOpen,\n  );\n\n  /** Emits whenever the component is opened. */\n  protected didOpen: EventEmitter = new EventEmitter(this, SbbOpenCloseBaseElement.events.didOpen);\n\n  /** Emits whenever the component begins the closing transition. */\n  protected willClose: EventEmitter = new EventEmitter(\n    this,\n    SbbOpenCloseBaseElement.events.willClose,\n  );\n\n  /** Emits whenever the component is closed. */\n  protected didClose: EventEmitter = new EventEmitter(\n    this,\n    SbbOpenCloseBaseElement.events.didClose,\n  );\n\n  /** Opens the component. */\n  public abstract open(): void;\n  /** Closes the component. */\n  public abstract close(): void;\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.state ||= 'closed';\n  }\n}\n\ndeclare global {\n  interface GlobalEventHandlersEventMap {\n    willOpen: CustomEvent<void>;\n    willClose: CustomEvent<void>;\n    didOpen: CustomEvent<void>;\n    didClose: CustomEvent<void>;\n  }\n}\n"],"names":["__decorateClass"],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import { ReactiveController, ReactiveControllerHost } from 'lit';
2
+ import { SbbOpenCloseBaseElement } from '../base-elements/open-close-base-element.js';
3
+ export declare class SbbInertController implements ReactiveController {
4
+ private _host;
5
+ private _inertElements;
6
+ private _inertOverlays;
7
+ constructor(_host: ReactiveControllerHost & SbbOpenCloseBaseElement, _inertElements?: Set<HTMLElement>, _inertOverlays?: Set<HTMLElement>);
8
+ hostConnected(): void;
9
+ hostDisconnected(): void;
10
+ /** Applies inert state to every other element on the page except the overlay. */
11
+ activate(): void;
12
+ /** Removes inert state. */
13
+ deactivate(): void;
14
+ private _currentOverlay;
15
+ private _removeInertAttributes;
16
+ private _addInertAttributes;
17
+ }
18
+ //# sourceMappingURL=inert-controller.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"inert-controller.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/controllers/inert-controller.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,sBAAsB,EAAE,MAAM,KAAK,CAAC;AAEtE,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,6CAA6C,CAAC;AAM3F,qBAAa,kBAAmB,YAAW,kBAAkB;IAEzD,OAAO,CAAC,KAAK;IACb,OAAO,CAAC,cAAc;IACtB,OAAO,CAAC,cAAc;gBAFd,KAAK,EAAE,sBAAsB,GAAG,uBAAuB,EACvD,cAAc,mBAAgB,EAC9B,cAAc,mBAAgB;IAKjC,aAAa,IAAI,IAAI;IAMrB,gBAAgB,IAAI,IAAI;IAM/B,iFAAiF;IAC1E,QAAQ,IAAI,IAAI;IAUvB,2BAA2B;IACpB,UAAU,IAAI,IAAI;IAyBzB,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,sBAAsB;IAmB9B,OAAO,CAAC,mBAAmB;CA6B5B"}
@@ -1,4 +1,5 @@
1
1
  export * from './controllers/connected-abort-controller.js';
2
+ export * from './controllers/inert-controller.js';
2
3
  export * from './controllers/language-controller.js';
3
4
  export * from './controllers/slot-state-controller.js';
4
5
  //# sourceMappingURL=controllers.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"controllers.d.ts","sourceRoot":"","sources":["../../../../src/elements/core/controllers.ts"],"names":[],"mappings":"AAAA,cAAc,6CAA6C,CAAC;AAC5D,cAAc,sCAAsC,CAAC;AACrD,cAAc,wCAAwC,CAAC"}
1
+ {"version":3,"file":"controllers.d.ts","sourceRoot":"","sources":["../../../../src/elements/core/controllers.ts"],"names":[],"mappings":"AAAA,cAAc,6CAA6C,CAAC;AAC5D,cAAc,mCAAmC,CAAC;AAClD,cAAc,sCAAsC,CAAC;AACrD,cAAc,wCAAwC,CAAC"}
@@ -22,6 +22,94 @@ class SbbConnectedAbortController {
22
22
  this._abortController = void 0;
23
23
  }
24
24
  }
25
+ const IGNORED_ELEMENTS = ["script", "head", "template", "style"];
26
+ const inertElements = /* @__PURE__ */ new Set();
27
+ const inertOverlays = /* @__PURE__ */ new Set();
28
+ class SbbInertController {
29
+ constructor(_host, _inertElements = inertElements, _inertOverlays = inertOverlays) {
30
+ var _a, _b;
31
+ this._host = _host;
32
+ this._inertElements = _inertElements;
33
+ this._inertOverlays = _inertOverlays;
34
+ (_b = (_a = this._host).addController) == null ? void 0 : _b.call(_a, this);
35
+ }
36
+ hostConnected() {
37
+ if (this._host.isOpen) {
38
+ this.activate();
39
+ }
40
+ }
41
+ hostDisconnected() {
42
+ if (this._inertOverlays.has(this._host)) {
43
+ this.deactivate();
44
+ }
45
+ }
46
+ /** Applies inert state to every other element on the page except the overlay. */
47
+ activate() {
48
+ if (this._inertOverlays.size) {
49
+ this._removeInertAttributes();
50
+ }
51
+ this._inertOverlays.add(this._host);
52
+ this._addInertAttributes();
53
+ }
54
+ /** Removes inert state. */
55
+ deactivate() {
56
+ if (this._currentOverlay() !== this._host) {
57
+ if (this._inertOverlays.has(this._host)) {
58
+ this._inertOverlays.delete(this._host);
59
+ } else {
60
+ console.warn(
61
+ "Trying to remove inert state of an overlay which never had an applied inert state.",
62
+ this._host
63
+ );
64
+ }
65
+ return;
66
+ }
67
+ this._removeInertAttributes();
68
+ this._inertOverlays.delete(this._host);
69
+ if (this._inertOverlays.size) {
70
+ this._addInertAttributes();
71
+ }
72
+ }
73
+ _currentOverlay() {
74
+ return [...this._inertOverlays].pop() ?? null;
75
+ }
76
+ _removeInertAttributes() {
77
+ this._inertElements.forEach((element) => {
78
+ if (!element) {
79
+ return;
80
+ }
81
+ if (element.hasAttribute("data-sbb-inert")) {
82
+ element.inert = false;
83
+ element.removeAttribute("data-sbb-inert");
84
+ }
85
+ if (element.hasAttribute("data-sbb-aria-hidden")) {
86
+ element.removeAttribute("aria-hidden");
87
+ element.removeAttribute("data-sbb-aria-hidden");
88
+ }
89
+ });
90
+ this._inertElements.clear();
91
+ }
92
+ _addInertAttributes() {
93
+ var _a, _b;
94
+ let element = this._currentOverlay();
95
+ while (element !== document.documentElement && element !== null) {
96
+ Array.from(((_a = (element == null ? void 0 : element.parentElement) ?? (element == null ? void 0 : element.getRootNode())) == null ? void 0 : _a.childNodes) ?? []).filter(
97
+ (child) => child !== element && child instanceof window.HTMLElement && !IGNORED_ELEMENTS.includes(child.localName)
98
+ ).forEach((element2) => {
99
+ this._inertElements.add(element2);
100
+ if (!element2.inert) {
101
+ element2.inert = true;
102
+ element2.toggleAttribute("data-sbb-inert", true);
103
+ }
104
+ if (!element2.hasAttribute("aria-hidden")) {
105
+ element2.setAttribute("aria-hidden", "true");
106
+ element2.toggleAttribute("data-sbb-aria-hidden", true);
107
+ }
108
+ });
109
+ element = (element == null ? void 0 : element.parentElement) ?? ((_b = element == null ? void 0 : element.getRootNode()) == null ? void 0 : _b.host) ?? null;
110
+ }
111
+ }
112
+ }
25
113
  const _SbbLanguageController = class _SbbLanguageController {
26
114
  constructor(_host) {
27
115
  this._host = _host;
@@ -128,7 +216,8 @@ class SbbSlotStateController {
128
216
  }
129
217
  export {
130
218
  SbbConnectedAbortController,
219
+ SbbInertController,
131
220
  SbbLanguageController,
132
221
  SbbSlotStateController
133
222
  };
134
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"controllers.js","sources":["../../../../src/elements/core/controllers/connected-abort-controller.ts","../../../../src/elements/core/controllers/language-controller.ts","../../../../src/elements/core/controllers/slot-state-controller.ts"],"sourcesContent":["import type { ReactiveController, ReactiveControllerHost } from 'lit';\n\nexport class SbbConnectedAbortController implements ReactiveController {\n  private _abortController?: AbortController = new AbortController();\n\n  public get signal(): AbortSignal | undefined {\n    return this._abortController?.signal;\n  }\n\n  public constructor(private _host: ReactiveControllerHost) {\n    this._host.addController(this);\n  }\n\n  public hostConnected(): void {\n    if (!this._abortController) {\n      this._abortController = new AbortController();\n    }\n  }\n\n  public hostDisconnected(): void {\n    this._abortController?.abort();\n    this._abortController = undefined;\n  }\n}\n","import { isServer, type ReactiveController, type ReactiveControllerHost } from 'lit';\n\nimport { readConfig } from '../config.js';\nimport { AgnosticMutationObserver } from '../observers.js';\n\n/**\n * The LanguageController is a reactive controller that observes the \"lang\" attribute\n * of the <html> tag.\n * On change of the \"lang\" attribute, it will request an update of connected\n * components.\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/lang\n */\nexport class SbbLanguageController implements ReactiveController {\n  private static readonly _defaultLanguage = 'en';\n  private static readonly _supportedLocales = ['en', 'de', 'fr', 'it'];\n\n  /** A set of connected components that should be notified on language change. */\n  private static readonly _listeners = new Set<SbbLanguageController>();\n\n  /** MutationObserver that observes the \"lang\" attribute of the <html> element. */\n  private static readonly _observer = new AgnosticMutationObserver((mutations) => {\n    if (mutations[0].oldValue !== document.documentElement.getAttribute('lang')) {\n      SbbLanguageController._listeners.forEach((l) => l._callHandlers());\n    }\n  });\n  private static readonly _observerConfig = {\n    attributeFilter: ['lang'],\n    attributeOldValue: true,\n  };\n\n  /** Get the current language. */\n  public static get current(): string {\n    const language =\n      (readConfig().language ??\n        (isServer\n          ? SbbLanguageController._defaultLanguage\n          : document.documentElement.getAttribute('lang'))) ||\n      SbbLanguageController._defaultLanguage;\n\n    // Support e.g. cases like `de-ch`.\n    const langAttributeNormalized = language.split('-')[0];\n    return SbbLanguageController._supportedLocales.includes(langAttributeNormalized)\n      ? langAttributeNormalized\n      : SbbLanguageController._defaultLanguage;\n  }\n\n  /** Get the current language. */\n  public get current(): string {\n    return SbbLanguageController.current;\n  }\n\n  private _previousLanguage?: string;\n  private _handlers: (() => void)[] = [];\n\n  public constructor(private _host: ReactiveControllerHost) {\n    this._host.addController(this);\n  }\n\n  /** Add a language change handler. */\n  public withHandler(handler: () => void): this {\n    // We use unshift here, to prepend additional handlers.\n    // This ensures that requestUpdate is called after the other handlers.\n    this._handlers.unshift(handler);\n    return this;\n  }\n\n  public hostConnected(): void {\n    if (!SbbLanguageController._listeners.size) {\n      SbbLanguageController._observer.observe(\n        document.documentElement,\n        SbbLanguageController._observerConfig,\n      );\n    }\n\n    SbbLanguageController._listeners.add(this);\n    if (this._previousLanguage !== this.current) {\n      this._callHandlers(this._previousLanguage !== undefined);\n    }\n  }\n\n  public hostDisconnected(): void {\n    this._previousLanguage = this.current;\n    SbbLanguageController._listeners.delete(this);\n    if (!SbbLanguageController._listeners.size) {\n      SbbLanguageController._observer.disconnect();\n    }\n  }\n\n  private _callHandlers(requestUpdate = true): void {\n    this._handlers.forEach((h) => h());\n    if (requestUpdate) {\n      this._host.requestUpdate();\n    }\n  }\n}\n","import type { ReactiveController, ReactiveControllerHost } from 'lit';\n\n/**\n * This controller checks for slotted children. From these it generates\n * a list of used slot names (`unnamed` for children without a slot attribute)\n * and adds this to the `data-slot-names` attribute, as a space separated list.\n *\n * This allows CSS attribute selector to display/hide/configure a section\n * of the component as required (see [attr~=value] selector specifically).\n *\n * @example\n * .example {\n *   display: none;\n *\n *   :host([data-slot-names~=\"icon\"]) & {\n *     display: inline;\n *   }\n * }\n *\n * https://developer.mozilla.org/en-US/docs/Web/CSS/Attribute_selectors\n */\nexport class SbbSlotStateController implements ReactiveController {\n  public readonly slots = new Set<string>();\n\n  // We avoid using AbortController here, as it would mean creating\n  // a new instance for every NamedSlotStateController instance.\n  private _slotchangeHandler = (event: Event): void => {\n    this._syncSlots(event.target as HTMLSlotElement);\n  };\n\n  public constructor(\n    private _host: ReactiveControllerHost & HTMLElement,\n    private _onChangeCallback: (() => void) | null = null,\n  ) {\n    this._host.addController(this);\n  }\n\n  public hostConnected(): void {\n    // TODO: Check if this is really needed with SSR.\n    this._syncSlots(...this._host.querySelectorAll!('slot'));\n    this._host.shadowRoot?.addEventListener('slotchange', this._slotchangeHandler);\n  }\n\n  public hostDisconnected(): void {\n    this._host.shadowRoot?.removeEventListener('slotchange', this._slotchangeHandler);\n  }\n\n  private _syncSlots(...slots: HTMLSlotElement[]): void {\n    for (const slot of slots) {\n      const slotName = slot.name || 'unnamed';\n      // We want to check, whether an element is slotted or a text node with actual content.\n      if (slot.assignedNodes().some((n) => 'tagName' in n || n.textContent?.trim())) {\n        this.slots.add(slotName);\n      } else {\n        this.slots.delete(slotName);\n      }\n    }\n\n    const oldValue = this._host.getAttribute('data-slot-names');\n    const joinedSlotNames = [...this.slots].sort().join(' ');\n    if (!joinedSlotNames) {\n      this._host.removeAttribute('data-slot-names');\n    } else if (this._host.getAttribute('data-slot-names') !== joinedSlotNames) {\n      this._host.setAttribute('data-slot-names', joinedSlotNames);\n    }\n\n    if (joinedSlotNames !== oldValue) {\n      this._onChangeCallback?.();\n    }\n  }\n}\n"],"names":["_a"],"mappings":"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"}
223
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"controllers.js","sources":["../../../../src/elements/core/controllers/connected-abort-controller.ts","../../../../src/elements/core/controllers/inert-controller.ts","../../../../src/elements/core/controllers/language-controller.ts","../../../../src/elements/core/controllers/slot-state-controller.ts"],"sourcesContent":["import type { ReactiveController, ReactiveControllerHost } from 'lit';\n\nexport class SbbConnectedAbortController implements ReactiveController {\n  private _abortController?: AbortController = new AbortController();\n\n  public get signal(): AbortSignal | undefined {\n    return this._abortController?.signal;\n  }\n\n  public constructor(private _host: ReactiveControllerHost) {\n    this._host.addController(this);\n  }\n\n  public hostConnected(): void {\n    if (!this._abortController) {\n      this._abortController = new AbortController();\n    }\n  }\n\n  public hostDisconnected(): void {\n    this._abortController?.abort();\n    this._abortController = undefined;\n  }\n}\n","import type { ReactiveController, ReactiveControllerHost } from 'lit';\n\nimport type { SbbOpenCloseBaseElement } from '../base-elements/open-close-base-element.js';\n\nconst IGNORED_ELEMENTS = ['script', 'head', 'template', 'style'];\nconst inertElements = new Set<HTMLElement>();\nconst inertOverlays = new Set<HTMLElement>();\n\nexport class SbbInertController implements ReactiveController {\n  public constructor(\n    private _host: ReactiveControllerHost & SbbOpenCloseBaseElement,\n    private _inertElements = inertElements,\n    private _inertOverlays = inertOverlays,\n  ) {\n    this._host.addController?.(this);\n  }\n\n  public hostConnected(): void {\n    if (this._host.isOpen) {\n      this.activate();\n    }\n  }\n\n  public hostDisconnected(): void {\n    if (this._inertOverlays.has(this._host)) {\n      this.deactivate();\n    }\n  }\n\n  /** Applies inert state to every other element on the page except the overlay. */\n  public activate(): void {\n    // Remove inert state from previous opened overlay\n    if (this._inertOverlays.size) {\n      this._removeInertAttributes();\n    }\n\n    this._inertOverlays.add(this._host);\n    this._addInertAttributes();\n  }\n\n  /** Removes inert state. */\n  public deactivate(): void {\n    if (this._currentOverlay() !== this._host) {\n      // If e.g. a component gets disconnected, it could be that it is not the top most.\n      // In this case, we can directly remove it, as there is currently no inert state applied.\n      if (this._inertOverlays.has(this._host)) {\n        this._inertOverlays.delete(this._host);\n      } else if (import.meta.env.DEV) {\n        console.warn(\n          'Trying to remove inert state of an overlay which never had an applied inert state.',\n          this._host,\n        );\n      }\n\n      return;\n    }\n\n    this._removeInertAttributes();\n    this._inertOverlays.delete(this._host);\n\n    // If there is as previous opened overlay, set its inert state again.\n    if (this._inertOverlays.size) {\n      this._addInertAttributes();\n    }\n  }\n\n  private _currentOverlay(): HTMLElement | null {\n    return [...this._inertOverlays].pop() ?? null;\n  }\n\n  private _removeInertAttributes(): void {\n    this._inertElements.forEach((element: HTMLElement): void => {\n      if (!element) {\n        return;\n      }\n\n      if (element.hasAttribute('data-sbb-inert')) {\n        element.inert = false;\n        element.removeAttribute('data-sbb-inert');\n      }\n\n      if (element.hasAttribute('data-sbb-aria-hidden')) {\n        element.removeAttribute('aria-hidden');\n        element.removeAttribute('data-sbb-aria-hidden');\n      }\n    });\n    this._inertElements.clear();\n  }\n\n  private _addInertAttributes(): void {\n    let element: Element | null = this._currentOverlay();\n\n    while (element !== document.documentElement && element !== null) {\n      Array.from((element?.parentElement ?? element?.getRootNode())?.childNodes ?? [])\n        .filter(\n          (child): child is HTMLElement =>\n            child !== element &&\n            child instanceof window.HTMLElement &&\n            !IGNORED_ELEMENTS.includes(child.localName),\n        )\n        .forEach((element) => {\n          this._inertElements.add(element);\n\n          if (!element.inert) {\n            element.inert = true;\n            element.toggleAttribute('data-sbb-inert', true);\n          }\n\n          if (!element.hasAttribute('aria-hidden')) {\n            element.setAttribute('aria-hidden', 'true');\n            element.toggleAttribute('data-sbb-aria-hidden', true);\n          }\n        });\n\n      // We need to pierce through Shadow DOM boundary\n      element = element?.parentElement ?? (element?.getRootNode() as ShadowRoot)?.host ?? null;\n    }\n  }\n}\n","import { isServer, type ReactiveController, type ReactiveControllerHost } from 'lit';\n\nimport { readConfig } from '../config.js';\nimport { AgnosticMutationObserver } from '../observers.js';\n\n/**\n * The LanguageController is a reactive controller that observes the \"lang\" attribute\n * of the <html> tag.\n * On change of the \"lang\" attribute, it will request an update of connected\n * components.\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/lang\n */\nexport class SbbLanguageController implements ReactiveController {\n  private static readonly _defaultLanguage = 'en';\n  private static readonly _supportedLocales = ['en', 'de', 'fr', 'it'];\n\n  /** A set of connected components that should be notified on language change. */\n  private static readonly _listeners = new Set<SbbLanguageController>();\n\n  /** MutationObserver that observes the \"lang\" attribute of the <html> element. */\n  private static readonly _observer = new AgnosticMutationObserver((mutations) => {\n    if (mutations[0].oldValue !== document.documentElement.getAttribute('lang')) {\n      SbbLanguageController._listeners.forEach((l) => l._callHandlers());\n    }\n  });\n  private static readonly _observerConfig = {\n    attributeFilter: ['lang'],\n    attributeOldValue: true,\n  };\n\n  /** Get the current language. */\n  public static get current(): string {\n    const language =\n      (readConfig().language ??\n        (isServer\n          ? SbbLanguageController._defaultLanguage\n          : document.documentElement.getAttribute('lang'))) ||\n      SbbLanguageController._defaultLanguage;\n\n    // Support e.g. cases like `de-ch`.\n    const langAttributeNormalized = language.split('-')[0];\n    return SbbLanguageController._supportedLocales.includes(langAttributeNormalized)\n      ? langAttributeNormalized\n      : SbbLanguageController._defaultLanguage;\n  }\n\n  /** Get the current language. */\n  public get current(): string {\n    return SbbLanguageController.current;\n  }\n\n  private _previousLanguage?: string;\n  private _handlers: (() => void)[] = [];\n\n  public constructor(private _host: ReactiveControllerHost) {\n    this._host.addController(this);\n  }\n\n  /** Add a language change handler. */\n  public withHandler(handler: () => void): this {\n    // We use unshift here, to prepend additional handlers.\n    // This ensures that requestUpdate is called after the other handlers.\n    this._handlers.unshift(handler);\n    return this;\n  }\n\n  public hostConnected(): void {\n    if (!SbbLanguageController._listeners.size) {\n      SbbLanguageController._observer.observe(\n        document.documentElement,\n        SbbLanguageController._observerConfig,\n      );\n    }\n\n    SbbLanguageController._listeners.add(this);\n    if (this._previousLanguage !== this.current) {\n      this._callHandlers(this._previousLanguage !== undefined);\n    }\n  }\n\n  public hostDisconnected(): void {\n    this._previousLanguage = this.current;\n    SbbLanguageController._listeners.delete(this);\n    if (!SbbLanguageController._listeners.size) {\n      SbbLanguageController._observer.disconnect();\n    }\n  }\n\n  private _callHandlers(requestUpdate = true): void {\n    this._handlers.forEach((h) => h());\n    if (requestUpdate) {\n      this._host.requestUpdate();\n    }\n  }\n}\n","import type { ReactiveController, ReactiveControllerHost } from 'lit';\n\n/**\n * This controller checks for slotted children. From these it generates\n * a list of used slot names (`unnamed` for children without a slot attribute)\n * and adds this to the `data-slot-names` attribute, as a space separated list.\n *\n * This allows CSS attribute selector to display/hide/configure a section\n * of the component as required (see [attr~=value] selector specifically).\n *\n * @example\n * .example {\n *   display: none;\n *\n *   :host([data-slot-names~=\"icon\"]) & {\n *     display: inline;\n *   }\n * }\n *\n * https://developer.mozilla.org/en-US/docs/Web/CSS/Attribute_selectors\n */\nexport class SbbSlotStateController implements ReactiveController {\n  public readonly slots = new Set<string>();\n\n  // We avoid using AbortController here, as it would mean creating\n  // a new instance for every NamedSlotStateController instance.\n  private _slotchangeHandler = (event: Event): void => {\n    this._syncSlots(event.target as HTMLSlotElement);\n  };\n\n  public constructor(\n    private _host: ReactiveControllerHost & HTMLElement,\n    private _onChangeCallback: (() => void) | null = null,\n  ) {\n    this._host.addController(this);\n  }\n\n  public hostConnected(): void {\n    // TODO: Check if this is really needed with SSR.\n    this._syncSlots(...this._host.querySelectorAll!('slot'));\n    this._host.shadowRoot?.addEventListener('slotchange', this._slotchangeHandler);\n  }\n\n  public hostDisconnected(): void {\n    this._host.shadowRoot?.removeEventListener('slotchange', this._slotchangeHandler);\n  }\n\n  private _syncSlots(...slots: HTMLSlotElement[]): void {\n    for (const slot of slots) {\n      const slotName = slot.name || 'unnamed';\n      // We want to check, whether an element is slotted or a text node with actual content.\n      if (slot.assignedNodes().some((n) => 'tagName' in n || n.textContent?.trim())) {\n        this.slots.add(slotName);\n      } else {\n        this.slots.delete(slotName);\n      }\n    }\n\n    const oldValue = this._host.getAttribute('data-slot-names');\n    const joinedSlotNames = [...this.slots].sort().join(' ');\n    if (!joinedSlotNames) {\n      this._host.removeAttribute('data-slot-names');\n    } else if (this._host.getAttribute('data-slot-names') !== joinedSlotNames) {\n      this._host.setAttribute('data-slot-names', joinedSlotNames);\n    }\n\n    if (joinedSlotNames !== oldValue) {\n      this._onChangeCallback?.();\n    }\n  }\n}\n"],"names":["element","_a"],"mappings":"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"}
@@ -4,17 +4,4 @@ import { TemplateResult } from 'lit';
4
4
  * Works in conjunction with the 'overlayGapFixCorners()' function in 'overlay.ts'
5
5
  */
6
6
  export declare function overlayGapFixCorners(): TemplateResult;
7
- /**
8
- * Applies inert to every other element on the page except the overlay.
9
- */
10
- export declare function applyInertMechanism(overlay: HTMLElement): void;
11
- export declare function removeInertMechanism(): void;
12
- declare global {
13
- interface GlobalEventHandlersEventMap {
14
- willOpen: CustomEvent<void>;
15
- willClose: CustomEvent<void>;
16
- didOpen: CustomEvent<void>;
17
- didClose: CustomEvent<void>;
18
- }
19
- }
20
7
  //# sourceMappingURL=overlay.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"overlay.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/overlay/overlay.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAK1C;;;GAGG;AACH,wBAAgB,oBAAoB,IAAI,cAAc,CASrD;AA4DD;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,OAAO,EAAE,WAAW,GAAG,IAAI,CAyB9D;AAED,wBAAgB,oBAAoB,IAAI,IAAI,CAqB3C;AACD,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,2BAA2B;QACnC,QAAQ,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;QAC5B,SAAS,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;QAC7B,OAAO,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;QAC3B,QAAQ,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;KAC7B;CACF"}
1
+ {"version":3,"file":"overlay.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/overlay/overlay.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAG1C;;;GAGG;AACH,wBAAgB,oBAAoB,IAAI,cAAc,CASrD"}