@sbb-esta/lyne-elements 1.14.1 → 1.15.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 (167) hide show
  1. package/autocomplete/autocomplete.d.ts +1 -1
  2. package/autocomplete/autocomplete.d.ts.map +1 -1
  3. package/autocomplete-grid/autocomplete-grid/autocomplete-grid.d.ts +1 -1
  4. package/autocomplete-grid/autocomplete-grid/autocomplete-grid.d.ts.map +1 -1
  5. package/autocomplete-grid/autocomplete-grid.js +6 -6
  6. package/autocomplete.js +20 -19
  7. package/calendar/calendar.d.ts +1 -1
  8. package/calendar/calendar.d.ts.map +1 -1
  9. package/calendar.js +25 -27
  10. package/checkbox/checkbox-panel/checkbox-panel.d.ts +1 -1
  11. package/checkbox/checkbox-panel/checkbox-panel.d.ts.map +1 -1
  12. package/checkbox/checkbox-panel.js +5 -5
  13. package/checkbox/common.js +1 -1
  14. package/clock/clock.d.ts +1 -1
  15. package/clock/clock.d.ts.map +1 -1
  16. package/clock.js +2 -2
  17. package/container/sticky-bar/sticky-bar.d.ts +29 -2
  18. package/container/sticky-bar/sticky-bar.d.ts.map +1 -1
  19. package/container/sticky-bar.js +69 -31
  20. package/core/controllers/media-matchers-controller.d.ts +32 -0
  21. package/core/controllers/media-matchers-controller.d.ts.map +1 -0
  22. package/core/controllers.d.ts +1 -0
  23. package/core/controllers.d.ts.map +1 -1
  24. package/core/controllers.js +75 -33
  25. package/core/dom/breakpoint.d.ts +2 -1
  26. package/core/dom/breakpoint.d.ts.map +1 -1
  27. package/core/dom.js +7 -7
  28. package/core/mixins/form-associated-checkbox-mixin.d.ts.map +1 -1
  29. package/core/mixins.js +8 -1
  30. package/core/styles/core/mediaqueries.scss +1 -2
  31. package/core/styles/mixins/buttons.scss +5 -5
  32. package/core/testing/event-spy.d.ts +6 -4
  33. package/core/testing/event-spy.d.ts.map +1 -1
  34. package/core/testing.js +82 -55
  35. package/custom-elements.json +609 -62
  36. package/datepicker/datepicker/datepicker.d.ts.map +1 -1
  37. package/development/autocomplete/autocomplete.d.ts +1 -1
  38. package/development/autocomplete/autocomplete.d.ts.map +1 -1
  39. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.d.ts +1 -1
  40. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.d.ts.map +1 -1
  41. package/development/autocomplete-grid/autocomplete-grid.js +4 -3
  42. package/development/autocomplete.js +4 -3
  43. package/development/calendar/calendar.d.ts +1 -1
  44. package/development/calendar/calendar.d.ts.map +1 -1
  45. package/development/calendar.js +8 -11
  46. package/development/checkbox/checkbox-panel/checkbox-panel.d.ts +1 -1
  47. package/development/checkbox/checkbox-panel/checkbox-panel.d.ts.map +1 -1
  48. package/development/checkbox/checkbox-panel.js +2 -2
  49. package/development/checkbox/common.js +2 -2
  50. package/development/clock/clock.d.ts +1 -1
  51. package/development/clock/clock.d.ts.map +1 -1
  52. package/development/clock.js +3 -3
  53. package/development/container/sticky-bar/sticky-bar.d.ts +29 -2
  54. package/development/container/sticky-bar/sticky-bar.d.ts.map +1 -1
  55. package/development/container/sticky-bar.js +149 -36
  56. package/development/core/controllers/media-matchers-controller.d.ts +32 -0
  57. package/development/core/controllers/media-matchers-controller.d.ts.map +1 -0
  58. package/development/core/controllers.d.ts +1 -0
  59. package/development/core/controllers.d.ts.map +1 -1
  60. package/development/core/controllers.js +65 -1
  61. package/development/core/dom/breakpoint.d.ts +2 -1
  62. package/development/core/dom/breakpoint.d.ts.map +1 -1
  63. package/development/core/dom.js +2 -2
  64. package/development/core/mixins/form-associated-checkbox-mixin.d.ts.map +1 -1
  65. package/development/core/mixins.js +9 -2
  66. package/development/core/testing/event-spy.d.ts +6 -4
  67. package/development/core/testing/event-spy.d.ts.map +1 -1
  68. package/development/core/testing.js +35 -1
  69. package/development/datepicker/datepicker/datepicker.d.ts.map +1 -1
  70. package/development/datepicker/datepicker.js +1 -1
  71. package/development/dialog/dialog.js +2 -2
  72. package/development/expansion-panel/expansion-panel-header/expansion-panel-header.d.ts +2 -0
  73. package/development/expansion-panel/expansion-panel-header/expansion-panel-header.d.ts.map +1 -1
  74. package/development/expansion-panel/expansion-panel-header.js +7 -3
  75. package/development/file-selector/file-selector.d.ts +5 -0
  76. package/development/file-selector/file-selector.d.ts.map +1 -1
  77. package/development/file-selector.js +8 -1
  78. package/development/flip-card/flip-card/flip-card.d.ts +4 -0
  79. package/development/flip-card/flip-card/flip-card.d.ts.map +1 -1
  80. package/development/flip-card/flip-card-details.js +4 -6
  81. package/development/flip-card/flip-card-summary/flip-card-summary.d.ts +1 -1
  82. package/development/flip-card/flip-card-summary/flip-card-summary.d.ts.map +1 -1
  83. package/development/flip-card/flip-card-summary.js +9 -10
  84. package/development/flip-card/flip-card.js +26 -2
  85. package/development/form-field/form-field.js +5 -3
  86. package/development/icon/icon.d.ts +1 -1
  87. package/development/icon.js +1 -1
  88. package/development/image/image.d.ts.map +1 -1
  89. package/development/image.js +3 -19
  90. package/development/map-container.js +3 -2
  91. package/development/menu/menu/menu.d.ts +1 -0
  92. package/development/menu/menu/menu.d.ts.map +1 -1
  93. package/development/menu/menu.js +15 -11
  94. package/development/navigation/navigation-section.js +4 -14
  95. package/development/navigation/navigation.js +2 -7
  96. package/development/notification.js +3 -2
  97. package/development/paginator/paginator/paginator.d.ts +1 -5
  98. package/development/paginator/paginator/paginator.d.ts.map +1 -1
  99. package/development/paginator/paginator.js +19 -27
  100. package/development/popover/popover/popover.d.ts.map +1 -1
  101. package/development/popover/popover.js +9 -16
  102. package/development/radio-button/radio-button-panel/radio-button-panel.d.ts +1 -1
  103. package/development/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -1
  104. package/development/radio-button/radio-button-panel.js +2 -2
  105. package/development/sbb-tokens-BdGhUJjM.js +33 -0
  106. package/development/select/select.d.ts +6 -5
  107. package/development/select/select.d.ts.map +1 -1
  108. package/development/select.js +23 -14
  109. package/development/slider/slider.d.ts +5 -0
  110. package/development/slider/slider.d.ts.map +1 -1
  111. package/development/slider.js +8 -1
  112. package/development/table/table-wrapper/table-wrapper.d.ts +1 -1
  113. package/development/table/table-wrapper/table-wrapper.d.ts.map +1 -1
  114. package/development/table/table-wrapper.js +1 -1
  115. package/development/timetable-occupancy-icon/timetable-occupancy-icon.d.ts +2 -1
  116. package/development/timetable-occupancy-icon/timetable-occupancy-icon.d.ts.map +1 -1
  117. package/development/timetable-occupancy-icon.js +11 -9
  118. package/development/toggle-check/toggle-check.d.ts +1 -1
  119. package/development/toggle-check/toggle-check.d.ts.map +1 -1
  120. package/development/toggle-check.js +2 -2
  121. package/dialog/dialog.js +1 -1
  122. package/expansion-panel/expansion-panel-header/expansion-panel-header.d.ts +2 -0
  123. package/expansion-panel/expansion-panel-header/expansion-panel-header.d.ts.map +1 -1
  124. package/expansion-panel/expansion-panel-header.js +25 -23
  125. package/file-selector/file-selector.d.ts +5 -0
  126. package/file-selector/file-selector.d.ts.map +1 -1
  127. package/file-selector.js +7 -0
  128. package/flip-card/flip-card/flip-card.d.ts +4 -0
  129. package/flip-card/flip-card/flip-card.d.ts.map +1 -1
  130. package/flip-card/flip-card-details.js +6 -6
  131. package/flip-card/flip-card-summary/flip-card-summary.d.ts +1 -1
  132. package/flip-card/flip-card-summary/flip-card-summary.d.ts.map +1 -1
  133. package/flip-card/flip-card-summary.js +8 -8
  134. package/flip-card/flip-card.js +56 -42
  135. package/icon/icon.d.ts +1 -1
  136. package/image/image.d.ts.map +1 -1
  137. package/image.js +46 -45
  138. package/map-container.js +7 -7
  139. package/menu/menu/menu.d.ts +1 -0
  140. package/menu/menu/menu.d.ts.map +1 -1
  141. package/menu/menu.js +45 -41
  142. package/navigation/navigation-section.js +7 -7
  143. package/navigation/navigation.js +8 -8
  144. package/package.json +1 -1
  145. package/paginator/paginator/paginator.d.ts +1 -5
  146. package/paginator/paginator/paginator.d.ts.map +1 -1
  147. package/paginator/paginator.js +50 -52
  148. package/popover/popover/popover.d.ts.map +1 -1
  149. package/popover/popover.js +42 -46
  150. package/radio-button/radio-button-panel/radio-button-panel.d.ts +1 -1
  151. package/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -1
  152. package/radio-button/radio-button-panel.js +7 -7
  153. package/sbb-tokens-Dx20OtVg.js +18 -0
  154. package/select/select.d.ts +6 -5
  155. package/select/select.d.ts.map +1 -1
  156. package/select.js +55 -53
  157. package/slider/slider.d.ts +5 -0
  158. package/slider/slider.d.ts.map +1 -1
  159. package/slider.js +12 -5
  160. package/table/table-wrapper/table-wrapper.d.ts +1 -1
  161. package/table/table-wrapper/table-wrapper.d.ts.map +1 -1
  162. package/timetable-occupancy-icon/timetable-occupancy-icon.d.ts +2 -1
  163. package/timetable-occupancy-icon/timetable-occupancy-icon.d.ts.map +1 -1
  164. package/timetable-occupancy-icon.js +45 -44
  165. package/toggle-check/toggle-check.d.ts +1 -1
  166. package/toggle-check/toggle-check.d.ts.map +1 -1
  167. package/toggle-check.js +1 -1
@@ -40,7 +40,7 @@ const SbbCheckboxCommonElementMixin = (superClass) => {
40
40
  this._group = this.closest("sbb-checkbox-group");
41
41
  ["disabled", "required", "size"].forEach((p) => this.requestUpdate(p));
42
42
  }
43
- async willUpdate(changedProperties) {
43
+ willUpdate(changedProperties) {
44
44
  super.willUpdate(changedProperties);
45
45
  if (changedProperties.has("checked") || changedProperties.has("indeterminate")) {
46
46
  this.internals.ariaChecked = this.indeterminate ? "mixed" : `${this.checked}`;
@@ -152,4 +152,4 @@ export {
152
152
  SbbCheckboxCommonElementMixin,
153
153
  checkboxCommon as checkboxCommonStyle
154
154
  };
155
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMvY2hlY2tib3gvY29tbW9uL2NoZWNrYm94LWNvbW1vbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IExpdEVsZW1lbnQsIFByb3BlcnR5VmFsdWVzIH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBmb3JjZVR5cGUgfSBmcm9tICcuLi8uLi9jb3JlL2RlY29yYXRvcnMuanMnO1xuaW1wb3J0IHtcbiAgdHlwZSBDb25zdHJ1Y3RvcixcbiAgdHlwZSBTYmJEaXNhYmxlZE1peGluVHlwZSxcbiAgU2JiRm9ybUFzc29jaWF0ZWRDaGVja2JveE1peGluLFxuICB0eXBlIFNiYkZvcm1Bc3NvY2lhdGVkQ2hlY2tib3hNaXhpblR5cGUsXG4gIHR5cGUgU2JiUmVxdWlyZWRNaXhpblR5cGUsXG59IGZyb20gJy4uLy4uL2NvcmUvbWl4aW5zLmpzJztcbmltcG9ydCB0eXBlIHsgU2JiQ2hlY2tib3hHcm91cEVsZW1lbnQgfSBmcm9tICcuLi9jaGVja2JveC1ncm91cC5qcyc7XG5cbmV4cG9ydCB0eXBlIFNiYkNoZWNrYm94U2l6ZSA9ICd4cycgfCAncycgfCAnbSc7XG5cbmV4cG9ydCBkZWNsYXJlIGNsYXNzIFNiYkNoZWNrYm94Q29tbW9uRWxlbWVudE1peGluVHlwZVxuICBleHRlbmRzIFNiYkZvcm1Bc3NvY2lhdGVkQ2hlY2tib3hNaXhpblR5cGVcbiAgaW1wbGVtZW50cyBQYXJ0aWFsPFNiYkRpc2FibGVkTWl4aW5UeXBlPiwgUGFydGlhbDxTYmJSZXF1aXJlZE1peGluVHlwZT5cbntcbiAgcHVibGljIGFjY2Vzc29yIGluZGV0ZXJtaW5hdGU6IGJvb2xlYW47XG5cbiAgcHVibGljIGdldCBncm91cCgpOiBTYmJDaGVja2JveEdyb3VwRWxlbWVudCB8IG51bGw7XG59XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbmV4cG9ydCBjb25zdCBTYmJDaGVja2JveENvbW1vbkVsZW1lbnRNaXhpbiA9IDxUIGV4dGVuZHMgQ29uc3RydWN0b3I8TGl0RWxlbWVudD4+KFxuICBzdXBlckNsYXNzOiBULFxuKTogQ29uc3RydWN0b3I8U2JiQ2hlY2tib3hDb21tb25FbGVtZW50TWl4aW5UeXBlPiAmIFQgPT4ge1xuICBhYnN0cmFjdCBjbGFzcyBTYmJDaGVja2JveENvbW1vbkVsZW1lbnRcbiAgICBleHRlbmRzIFNiYkZvcm1Bc3NvY2lhdGVkQ2hlY2tib3hNaXhpbihzdXBlckNsYXNzKVxuICAgIGltcGxlbWVudHMgUGFydGlhbDxTYmJDaGVja2JveENvbW1vbkVsZW1lbnRNaXhpblR5cGU+XG4gIHtcbiAgICAvKiogV2hldGhlciB0aGUgY2hlY2tib3ggaXMgaW5kZXRlcm1pbmF0ZS4gKi9cbiAgICBAZm9yY2VUeXBlKClcbiAgICBAcHJvcGVydHkoeyB0eXBlOiBCb29sZWFuIH0pXG4gICAgcHVibGljIGFjY2Vzc29yIGluZGV0ZXJtaW5hdGU6IGJvb2xlYW4gPSBmYWxzZTtcblxuICAgIC8qKiBSZWZlcmVuY2UgdG8gdGhlIGNvbm5lY3RlZCBjaGVja2JveCBncm91cC4gKi9cbiAgICBwdWJsaWMgZ2V0IGdyb3VwKCk6IFNiYkNoZWNrYm94R3JvdXBFbGVtZW50IHwgbnVsbCB7XG4gICAgICByZXR1cm4gdGhpcy5fZ3JvdXA7XG4gICAgfVxuICAgIHByaXZhdGUgX2dyb3VwOiBTYmJDaGVja2JveEdyb3VwRWxlbWVudCB8IG51bGwgPSBudWxsO1xuXG4gICAgcHVibGljIG92ZXJyaWRlIGNvbm5lY3RlZENhbGxiYWNrKCk6IHZvaWQge1xuICAgICAgc3VwZXIuY29ubmVjdGVkQ2FsbGJhY2soKTtcbiAgICAgIHRoaXMuX2dyb3VwID0gdGhpcy5jbG9zZXN0KCdzYmItY2hlY2tib3gtZ3JvdXAnKSBhcyBTYmJDaGVja2JveEdyb3VwRWxlbWVudDtcblxuICAgICAgLy8gV2UgbmVlZCB0byBjYWxsIHJlcXVlc3RVcGRhdGUgdG8gdXBkYXRlIHRoZSByZWZsZWN0ZWQgYXR0cmlidXRlc1xuICAgICAgWydkaXNhYmxlZCcsICdyZXF1aXJlZCcsICdzaXplJ10uZm9yRWFjaCgocCkgPT4gdGhpcy5yZXF1ZXN0VXBkYXRlKHApKTtcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgb3ZlcnJpZGUgYXN5bmMgd2lsbFVwZGF0ZShjaGFuZ2VkUHJvcGVydGllczogUHJvcGVydHlWYWx1ZXM8dGhpcz4pOiBQcm9taXNlPHZvaWQ+IHtcbiAgICAgIHN1cGVyLndpbGxVcGRhdGUoY2hhbmdlZFByb3BlcnRpZXMpO1xuXG4gICAgICBpZiAoY2hhbmdlZFByb3BlcnRpZXMuaGFzKCdjaGVja2VkJykgfHwgY2hhbmdlZFByb3BlcnRpZXMuaGFzKCdpbmRldGVybWluYXRlJykpIHtcbiAgICAgICAgdGhpcy5pbnRlcm5hbHMuYXJpYUNoZWNrZWQgPSB0aGlzLmluZGV0ZXJtaW5hdGUgPyAnbWl4ZWQnIDogYCR7dGhpcy5jaGVja2VkfWA7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIG92ZXJyaWRlIGlzRGlzYWJsZWRFeHRlcm5hbGx5KCk6IGJvb2xlYW4ge1xuICAgICAgcmV0dXJuIHRoaXMuZ3JvdXA/LmRpc2FibGVkID8/IGZhbHNlO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBvdmVycmlkZSBpc1JlcXVpcmVkRXh0ZXJuYWxseSgpOiBib29sZWFuIHtcbiAgICAgIHJldHVybiB0aGlzLmdyb3VwPy5yZXF1aXJlZCA/PyBmYWxzZTtcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgb3ZlcnJpZGUgd2l0aFVzZXJJbnRlcmFjdGlvbigpOiB2b2lkIHtcbiAgICAgIGlmICh0aGlzLmluZGV0ZXJtaW5hdGUpIHtcbiAgICAgICAgdGhpcy5pbmRldGVybWluYXRlID0gZmFsc2U7XG4gICAgICB9XG4gICAgfVxuICB9XG4gIHJldHVybiBTYmJDaGVja2JveENvbW1vbkVsZW1lbnQgYXMgdW5rbm93biBhcyBDb25zdHJ1Y3RvcjxTYmJDaGVja2JveENvbW1vbkVsZW1lbnRNaXhpblR5cGU+ICYgVDtcbn07XG4iXSwibmFtZXMiOlsiX2EiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztBQXlCYSxNQUFBLGdDQUFnQyxDQUMzQyxlQUNzRDtNQUN2Qyw0QkFBd0IsTUFBQTs7c0JBQzdCLCtCQUErQixVQUFVOzs7O0FBRHBDLFdBQUEsbUJBQ0wsWUFBMEM7QUFBQTs7QUFNbEQ7QUFBZ0IsMkJBQUEsaUNBQUEsa0JBQUEsTUFBQSw2QkFBeUIsS0FBSztBQU10QyxhQUFNLFVBQUEsa0JBQUEsTUFBQSxnQ0FBQSxHQUFtQztBQUFBLE1BQUE7QUFBQTtBQUFBLE1BTmpELElBQWdCLGdCQUErQjtBQUFBLGVBQUEsbUJBQUE7QUFBQSxNQUFBO0FBQUEsTUFBL0MsSUFBZ0IsY0FBK0IsT0FBQTtBQUFBLDJCQUFBLGlDQUFBO0FBQUEsTUFBQTtBQUFBO0FBQUEsTUFHL0MsSUFBVyxRQUFLO0FBQ2QsZUFBTyxLQUFLO0FBQUEsTUFBQTtBQUFBLE1BSUUsb0JBQWlCO0FBQy9CLGNBQU0sa0JBQWlCO0FBQ2xCLGFBQUEsU0FBUyxLQUFLLFFBQVEsb0JBQW9CO0FBRzlDLFNBQUEsWUFBWSxZQUFZLE1BQU0sRUFBRSxRQUFRLENBQUMsTUFBTSxLQUFLLGNBQWMsQ0FBQyxDQUFDO0FBQUEsTUFBQTtBQUFBLE1BR3BELE1BQU0sV0FBVyxtQkFBdUM7QUFDekUsY0FBTSxXQUFXLGlCQUFpQjtBQUVsQyxZQUFJLGtCQUFrQixJQUFJLFNBQVMsS0FBSyxrQkFBa0IsSUFBSSxlQUFlLEdBQUc7QUFDOUUsZUFBSyxVQUFVLGNBQWMsS0FBSyxnQkFBZ0IsVUFBVSxHQUFHLEtBQUssT0FBTztBQUFBLFFBQUE7QUFBQSxNQUM3RTtBQUFBLE1BR2lCLHVCQUFvQjs7QUFDOUIsaUJBQUFBLE1BQUEsS0FBSyxVQUFMLGdCQUFBQSxJQUFZLGFBQVk7QUFBQSxNQUFBO0FBQUEsTUFHZCx1QkFBb0I7O0FBQzlCLGlCQUFBQSxNQUFBLEtBQUssVUFBTCxnQkFBQUEsSUFBWSxhQUFZO0FBQUEsTUFBQTtBQUFBLE1BR2Qsc0JBQW1CO0FBQ3BDLFlBQUksS0FBSyxlQUFlO0FBQ3RCLGVBQUssZ0JBQWdCO0FBQUEsUUFBQTtBQUFBLE1BQ3ZCO0FBQUEsT0FuQ0Y7O21DQUZDLGFBQ0EsU0FBUyxFQUFFLE1BQU0sUUFBQSxDQUFTLENBQUM7QUFDWixtQkFBQSxJQUFBLE1BQUEsMkJBQUEsRUFBQSxNQUFBLFlBQUEsTUFBQSxpQkFBQSxRQUFBLE9BQUEsU0FBQSxPQUFBLFFBQUEsRUFBQSxLQUFBLENBQUEsUUFBQSxtQkFBQSxLQUFBLEtBQUEsQ0FBQSxRQUFBLElBQUEsZUFBQSxLQUFBLENBQUEsS0FBQSxVQUFBO0FBQUEsWUFBQSxnQkFBK0I7QUFBQSxXQUFBLFVBQUEsYUFBQSw2QkFBQSxnQ0FBQTs7VUFQbEM7QUFBQTtBQTZDUixTQUFBO0FBQ1Q7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7In0=
155
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMvY2hlY2tib3gvY29tbW9uL2NoZWNrYm94LWNvbW1vbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IExpdEVsZW1lbnQsIFByb3BlcnR5VmFsdWVzIH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBmb3JjZVR5cGUgfSBmcm9tICcuLi8uLi9jb3JlL2RlY29yYXRvcnMuanMnO1xuaW1wb3J0IHtcbiAgdHlwZSBDb25zdHJ1Y3RvcixcbiAgdHlwZSBTYmJEaXNhYmxlZE1peGluVHlwZSxcbiAgU2JiRm9ybUFzc29jaWF0ZWRDaGVja2JveE1peGluLFxuICB0eXBlIFNiYkZvcm1Bc3NvY2lhdGVkQ2hlY2tib3hNaXhpblR5cGUsXG4gIHR5cGUgU2JiUmVxdWlyZWRNaXhpblR5cGUsXG59IGZyb20gJy4uLy4uL2NvcmUvbWl4aW5zLmpzJztcbmltcG9ydCB0eXBlIHsgU2JiQ2hlY2tib3hHcm91cEVsZW1lbnQgfSBmcm9tICcuLi9jaGVja2JveC1ncm91cC5qcyc7XG5cbmV4cG9ydCB0eXBlIFNiYkNoZWNrYm94U2l6ZSA9ICd4cycgfCAncycgfCAnbSc7XG5cbmV4cG9ydCBkZWNsYXJlIGNsYXNzIFNiYkNoZWNrYm94Q29tbW9uRWxlbWVudE1peGluVHlwZVxuICBleHRlbmRzIFNiYkZvcm1Bc3NvY2lhdGVkQ2hlY2tib3hNaXhpblR5cGVcbiAgaW1wbGVtZW50cyBQYXJ0aWFsPFNiYkRpc2FibGVkTWl4aW5UeXBlPiwgUGFydGlhbDxTYmJSZXF1aXJlZE1peGluVHlwZT5cbntcbiAgcHVibGljIGFjY2Vzc29yIGluZGV0ZXJtaW5hdGU6IGJvb2xlYW47XG5cbiAgcHVibGljIGdldCBncm91cCgpOiBTYmJDaGVja2JveEdyb3VwRWxlbWVudCB8IG51bGw7XG59XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbmV4cG9ydCBjb25zdCBTYmJDaGVja2JveENvbW1vbkVsZW1lbnRNaXhpbiA9IDxUIGV4dGVuZHMgQ29uc3RydWN0b3I8TGl0RWxlbWVudD4+KFxuICBzdXBlckNsYXNzOiBULFxuKTogQ29uc3RydWN0b3I8U2JiQ2hlY2tib3hDb21tb25FbGVtZW50TWl4aW5UeXBlPiAmIFQgPT4ge1xuICBhYnN0cmFjdCBjbGFzcyBTYmJDaGVja2JveENvbW1vbkVsZW1lbnRcbiAgICBleHRlbmRzIFNiYkZvcm1Bc3NvY2lhdGVkQ2hlY2tib3hNaXhpbihzdXBlckNsYXNzKVxuICAgIGltcGxlbWVudHMgUGFydGlhbDxTYmJDaGVja2JveENvbW1vbkVsZW1lbnRNaXhpblR5cGU+XG4gIHtcbiAgICAvKiogV2hldGhlciB0aGUgY2hlY2tib3ggaXMgaW5kZXRlcm1pbmF0ZS4gKi9cbiAgICBAZm9yY2VUeXBlKClcbiAgICBAcHJvcGVydHkoeyB0eXBlOiBCb29sZWFuIH0pXG4gICAgcHVibGljIGFjY2Vzc29yIGluZGV0ZXJtaW5hdGU6IGJvb2xlYW4gPSBmYWxzZTtcblxuICAgIC8qKiBSZWZlcmVuY2UgdG8gdGhlIGNvbm5lY3RlZCBjaGVja2JveCBncm91cC4gKi9cbiAgICBwdWJsaWMgZ2V0IGdyb3VwKCk6IFNiYkNoZWNrYm94R3JvdXBFbGVtZW50IHwgbnVsbCB7XG4gICAgICByZXR1cm4gdGhpcy5fZ3JvdXA7XG4gICAgfVxuICAgIHByaXZhdGUgX2dyb3VwOiBTYmJDaGVja2JveEdyb3VwRWxlbWVudCB8IG51bGwgPSBudWxsO1xuXG4gICAgcHVibGljIG92ZXJyaWRlIGNvbm5lY3RlZENhbGxiYWNrKCk6IHZvaWQge1xuICAgICAgc3VwZXIuY29ubmVjdGVkQ2FsbGJhY2soKTtcbiAgICAgIHRoaXMuX2dyb3VwID0gdGhpcy5jbG9zZXN0KCdzYmItY2hlY2tib3gtZ3JvdXAnKSBhcyBTYmJDaGVja2JveEdyb3VwRWxlbWVudDtcblxuICAgICAgLy8gV2UgbmVlZCB0byBjYWxsIHJlcXVlc3RVcGRhdGUgdG8gdXBkYXRlIHRoZSByZWZsZWN0ZWQgYXR0cmlidXRlc1xuICAgICAgWydkaXNhYmxlZCcsICdyZXF1aXJlZCcsICdzaXplJ10uZm9yRWFjaCgocCkgPT4gdGhpcy5yZXF1ZXN0VXBkYXRlKHApKTtcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgb3ZlcnJpZGUgd2lsbFVwZGF0ZShjaGFuZ2VkUHJvcGVydGllczogUHJvcGVydHlWYWx1ZXM8dGhpcz4pOiB2b2lkIHtcbiAgICAgIHN1cGVyLndpbGxVcGRhdGUoY2hhbmdlZFByb3BlcnRpZXMpO1xuXG4gICAgICBpZiAoY2hhbmdlZFByb3BlcnRpZXMuaGFzKCdjaGVja2VkJykgfHwgY2hhbmdlZFByb3BlcnRpZXMuaGFzKCdpbmRldGVybWluYXRlJykpIHtcbiAgICAgICAgdGhpcy5pbnRlcm5hbHMuYXJpYUNoZWNrZWQgPSB0aGlzLmluZGV0ZXJtaW5hdGUgPyAnbWl4ZWQnIDogYCR7dGhpcy5jaGVja2VkfWA7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIG92ZXJyaWRlIGlzRGlzYWJsZWRFeHRlcm5hbGx5KCk6IGJvb2xlYW4ge1xuICAgICAgcmV0dXJuIHRoaXMuZ3JvdXA/LmRpc2FibGVkID8/IGZhbHNlO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBvdmVycmlkZSBpc1JlcXVpcmVkRXh0ZXJuYWxseSgpOiBib29sZWFuIHtcbiAgICAgIHJldHVybiB0aGlzLmdyb3VwPy5yZXF1aXJlZCA/PyBmYWxzZTtcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgb3ZlcnJpZGUgd2l0aFVzZXJJbnRlcmFjdGlvbigpOiB2b2lkIHtcbiAgICAgIGlmICh0aGlzLmluZGV0ZXJtaW5hdGUpIHtcbiAgICAgICAgdGhpcy5pbmRldGVybWluYXRlID0gZmFsc2U7XG4gICAgICB9XG4gICAgfVxuICB9XG4gIHJldHVybiBTYmJDaGVja2JveENvbW1vbkVsZW1lbnQgYXMgdW5rbm93biBhcyBDb25zdHJ1Y3RvcjxTYmJDaGVja2JveENvbW1vbkVsZW1lbnRNaXhpblR5cGU+ICYgVDtcbn07XG4iXSwibmFtZXMiOlsiX2EiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztBQXlCYSxNQUFBLGdDQUFnQyxDQUMzQyxlQUNzRDtNQUN2Qyw0QkFBd0IsTUFBQTs7c0JBQzdCLCtCQUErQixVQUFVOzs7O0FBRHBDLFdBQUEsbUJBQ0wsWUFBMEM7QUFBQTs7QUFNbEQ7QUFBZ0IsMkJBQUEsaUNBQUEsa0JBQUEsTUFBQSw2QkFBeUIsS0FBSztBQU10QyxhQUFNLFVBQUEsa0JBQUEsTUFBQSxnQ0FBQSxHQUFtQztBQUFBLE1BQUE7QUFBQTtBQUFBLE1BTmpELElBQWdCLGdCQUErQjtBQUFBLGVBQUEsbUJBQUE7QUFBQSxNQUFBO0FBQUEsTUFBL0MsSUFBZ0IsY0FBK0IsT0FBQTtBQUFBLDJCQUFBLGlDQUFBO0FBQUEsTUFBQTtBQUFBO0FBQUEsTUFHL0MsSUFBVyxRQUFLO0FBQ2QsZUFBTyxLQUFLO0FBQUEsTUFBQTtBQUFBLE1BSUUsb0JBQWlCO0FBQy9CLGNBQU0sa0JBQWlCO0FBQ2xCLGFBQUEsU0FBUyxLQUFLLFFBQVEsb0JBQW9CO0FBRzlDLFNBQUEsWUFBWSxZQUFZLE1BQU0sRUFBRSxRQUFRLENBQUMsTUFBTSxLQUFLLGNBQWMsQ0FBQyxDQUFDO0FBQUEsTUFBQTtBQUFBLE1BR3BELFdBQVcsbUJBQXVDO0FBQ25FLGNBQU0sV0FBVyxpQkFBaUI7QUFFbEMsWUFBSSxrQkFBa0IsSUFBSSxTQUFTLEtBQUssa0JBQWtCLElBQUksZUFBZSxHQUFHO0FBQzlFLGVBQUssVUFBVSxjQUFjLEtBQUssZ0JBQWdCLFVBQVUsR0FBRyxLQUFLLE9BQU87QUFBQSxRQUFBO0FBQUEsTUFDN0U7QUFBQSxNQUdpQix1QkFBb0I7O0FBQzlCLGlCQUFBQSxNQUFBLEtBQUssVUFBTCxnQkFBQUEsSUFBWSxhQUFZO0FBQUEsTUFBQTtBQUFBLE1BR2QsdUJBQW9COztBQUM5QixpQkFBQUEsTUFBQSxLQUFLLFVBQUwsZ0JBQUFBLElBQVksYUFBWTtBQUFBLE1BQUE7QUFBQSxNQUdkLHNCQUFtQjtBQUNwQyxZQUFJLEtBQUssZUFBZTtBQUN0QixlQUFLLGdCQUFnQjtBQUFBLFFBQUE7QUFBQSxNQUN2QjtBQUFBLE9BbkNGOzttQ0FGQyxhQUNBLFNBQVMsRUFBRSxNQUFNLFFBQUEsQ0FBUyxDQUFDO0FBQ1osbUJBQUEsSUFBQSxNQUFBLDJCQUFBLEVBQUEsTUFBQSxZQUFBLE1BQUEsaUJBQUEsUUFBQSxPQUFBLFNBQUEsT0FBQSxRQUFBLEVBQUEsS0FBQSxDQUFBLFFBQUEsbUJBQUEsS0FBQSxLQUFBLENBQUEsUUFBQSxJQUFBLGVBQUEsS0FBQSxDQUFBLEtBQUEsVUFBQTtBQUFBLFlBQUEsZ0JBQStCO0FBQUEsV0FBQSxVQUFBLGFBQUEsNkJBQUEsZ0NBQUE7O1VBUGxDO0FBQUE7QUE2Q1IsU0FBQTtBQUNUOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OyJ9
@@ -28,7 +28,7 @@ export declare class SbbClockElement extends LitElement {
28
28
  private _moveHoursHandFn;
29
29
  /** Callback function for minutes hand. */
30
30
  private _moveMinutesHandFn;
31
- protected willUpdate(changedProperties: PropertyValues<this>): Promise<void>;
31
+ protected willUpdate(changedProperties: PropertyValues<this>): void;
32
32
  protected firstUpdated(changedProperties: PropertyValues<this>): Promise<void>;
33
33
  disconnectedCallback(): void;
34
34
  private _handlePageVisibilityChange;
@@ -1 +1 @@
1
- {"version":3,"file":"clock.d.ts","sourceRoot":"","sources":["../../../../src/elements/clock/clock.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAkB,UAAU,EAAE,MAAM,KAAK,CAAC;AAIjD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAC;AA2CrD;;GAEG;AACH,qBAEM,eAAgB,SAAQ,UAAU;IACtC,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;;OAGG;IACH,SAA4B,GAAG,EAAE,OAAO,GAAG,IAAI,CAAQ;IAEvD,kCAAkC;IAClC,OAAO,CAAC,eAAe,CAAe;IAEtC,oCAAoC;IACpC,OAAO,CAAC,iBAAiB,CAAe;IAExC,oCAAoC;IACpC,OAAO,CAAC,iBAAiB,CAAe;IAExC,wCAAwC;IACxC,OAAO,CAAC,MAAM,CAAU;IAExB,0CAA0C;IAC1C,OAAO,CAAC,QAAQ,CAAU;IAE1B,0CAA0C;IAC1C,OAAO,CAAC,QAAQ,CAAU;IAE1B,0CAA0C;IAC1C,OAAO,CAAC,aAAa,CAAC,CAAiC;IAEvD,wCAAwC;IACxC,OAAO,CAAC,gBAAgB,CAAqC;IAE7D,0CAA0C;IAC1C,OAAO,CAAC,kBAAkB,CAAuC;cAExC,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;cAQlE,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAS7E,oBAAoB,IAAI,IAAI;IAK5C,OAAO,CAAC,2BAA2B,CAMjC;YAEY,sBAAsB;IAUpC,6FAA6F;YAC/E,WAAW;IAsBzB,sDAAsD;YACxC,UAAU;IAcxB,uEAAuE;IACvE,OAAO,CAAC,yBAAyB;IA4CjC,yGAAyG;IACzG,OAAO,CAAC,kBAAkB;IAW1B,sDAAsD;IACtD,OAAO,CAAC,eAAe;IAOvB,6CAA6C;IAC7C,OAAO,CAAC,cAAc;IAYtB,+CAA+C;IAC/C,OAAO,CAAC,gBAAgB;IAaxB,OAAO,CAAC,sBAAsB;IAK9B;;;;OAIG;IACH,OAAO,CAAC,0BAA0B;IAWlC,OAAO,CAAC,qBAAqB;IAO7B,OAAO,CAAC,2BAA2B;IAMnC,OAAO,CAAC,6BAA6B;cAOlB,MAAM,IAAI,cAAc;CA4B5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,WAAW,EAAE,eAAe,CAAC;KAC9B;CACF"}
1
+ {"version":3,"file":"clock.d.ts","sourceRoot":"","sources":["../../../../src/elements/clock/clock.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAkB,UAAU,EAAE,MAAM,KAAK,CAAC;AAIjD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAC;AA2CrD;;GAEG;AACH,qBAEM,eAAgB,SAAQ,UAAU;IACtC,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;;OAGG;IACH,SAA4B,GAAG,EAAE,OAAO,GAAG,IAAI,CAAQ;IAEvD,kCAAkC;IAClC,OAAO,CAAC,eAAe,CAAe;IAEtC,oCAAoC;IACpC,OAAO,CAAC,iBAAiB,CAAe;IAExC,oCAAoC;IACpC,OAAO,CAAC,iBAAiB,CAAe;IAExC,wCAAwC;IACxC,OAAO,CAAC,MAAM,CAAU;IAExB,0CAA0C;IAC1C,OAAO,CAAC,QAAQ,CAAU;IAE1B,0CAA0C;IAC1C,OAAO,CAAC,QAAQ,CAAU;IAE1B,0CAA0C;IAC1C,OAAO,CAAC,aAAa,CAAC,CAAiC;IAEvD,wCAAwC;IACxC,OAAO,CAAC,gBAAgB,CAAqC;IAE7D,0CAA0C;IAC1C,OAAO,CAAC,kBAAkB,CAAuC;cAE9C,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAQnD,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAS7E,oBAAoB,IAAI,IAAI;IAK5C,OAAO,CAAC,2BAA2B,CAMjC;YAEY,sBAAsB;IAUpC,6FAA6F;YAC/E,WAAW;IAsBzB,sDAAsD;YACxC,UAAU;IAcxB,uEAAuE;IACvE,OAAO,CAAC,yBAAyB;IA4CjC,yGAAyG;IACzG,OAAO,CAAC,kBAAkB;IAW1B,sDAAsD;IACtD,OAAO,CAAC,eAAe;IAOvB,6CAA6C;IAC7C,OAAO,CAAC,cAAc;IAYtB,+CAA+C;IAC/C,OAAO,CAAC,gBAAgB;IAaxB,OAAO,CAAC,sBAAsB;IAK9B;;;;OAIG;IACH,OAAO,CAAC,0BAA0B;IAWlC,OAAO,CAAC,qBAAqB;IAO7B,OAAO,CAAC,2BAA2B;IAMnC,OAAO,CAAC,6BAA6B;cAOlB,MAAM,IAAI,cAAc;CA4B5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,WAAW,EAAE,eAAe,CAAC;KAC9B;CACF"}
@@ -177,10 +177,10 @@ let SbbClockElement = (() => {
177
177
  set now(value) {
178
178
  __privateSet(this, _now_accessor_storage, value);
179
179
  }
180
- async willUpdate(changedProperties) {
180
+ willUpdate(changedProperties) {
181
181
  super.willUpdate(changedProperties);
182
182
  if (!isServer && changedProperties.has("now")) {
183
- await this._startOrConfigureClock();
183
+ this._startOrConfigureClock();
184
184
  }
185
185
  }
186
186
  async firstUpdated(changedProperties) {
@@ -366,4 +366,4 @@ let SbbClockElement = (() => {
366
366
  export {
367
367
  SbbClockElement
368
368
  };
369
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"clock.js","sources":["../../../src/elements/clock/assets/sbb_clock_face.svg?raw","../../../src/elements/clock/assets/sbb_clock_hours.svg?raw","../../../src/elements/clock/assets/sbb_clock_minutes.svg?raw","../../../src/elements/clock/assets/sbb_clock_seconds.svg?raw","../../../src/elements/clock/clock.ts"],"sourcesContent":["export default \"<svg focusable=\\\"false\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" viewBox=\\\"0 0 105 105\\\"><g class=\\\"face\\\"><circle fill=\\\"#FFF\\\" cx=\\\"52.5\\\" cy=\\\"52.5\\\" r=\\\"52.5\\\"/><path d=\\\"M50.75 4h3.5v12h-3.5zM50.75 89h3.5v12h-3.5zM75.233 9.623l3.03 1.75-6 10.392-3.03-1.75zM32.734 83.233l3.03 1.75-6 10.392-3.03-1.75zM93.628 26.732l1.75 3.031-10.392 6-1.75-3.03zM20.017 69.234l1.75 3.031-10.392 6-1.75-3.03zM101 50.75v3.5H89v-3.5zM16 50.75v3.5H4v-3.5zM95.379 75.232l-1.75 3.031-10.392-6 1.75-3.03zM21.766 32.734l-1.75 3.031-10.392-6 1.75-3.03zM78.267 93.63l-3.03 1.75-6-10.393 3.03-1.75zM35.766 20.015l-3.03 1.75-6-10.392 3.03-1.75z\\\"/><g><path d=\\\"M56.873 4.19l1.392.147-.366 3.48-1.392-.145zM47.101 97.177l1.393.146-.366 3.481-1.392-.146zM61.896 4.914l1.37.29-.728 3.424-1.37-.29zM42.458 96.366l1.37.29-.728 3.424-1.37-.291zM66.825 6.157l1.332.432-1.082 3.33-1.331-.434zM37.931 95.085l1.332.432-1.082 3.33-1.331-.433zM71.584 7.906l1.28.569-1.424 3.197-1.28-.57zM33.56 93.32l1.278.569-1.423 3.197-1.28-.57zM80.44 12.852l1.133.823-2.058 2.831-1.132-.823zM25.481 88.494l1.133.822-2.057 2.832-1.133-.823zM84.43 15.986l1.04.937-2.342 2.6-1.04-.936zM21.87 85.469l1.04.936-2.341 2.601-1.04-.937zM88.072 19.522l.937 1.04-2.6 2.343-.937-1.04zM18.593 82.088l.937 1.04-2.601 2.342-.937-1.04zM91.328 23.425l.823 1.133-2.832 2.057-.823-1.132zM15.684 78.385l.823 1.132-2.832 2.058-.822-1.133zM96.52 32.128l.57 1.279-3.198 1.423-.57-1.278zM11.109 70.161l.569 1.279-3.197 1.423-.57-1.279zM98.407 36.85l.433 1.332-3.33 1.081-.432-1.331zM9.483 65.74l.432 1.33-3.329 1.082-.432-1.331zM99.795 41.726l.291 1.37-3.423.727-.29-1.37zM8.34 61.17l.292 1.37-3.424.728-.29-1.37zM100.66 46.73l.146 1.393-3.48.366-.147-1.392zM7.674 56.506l.146 1.392-3.48.366-.147-1.392zM100.811 56.873l-.146 1.392-3.48-.365.145-1.393zM7.821 47.101l-.146 1.392-3.48-.365.145-1.393zM100.09 61.895l-.291 1.369-3.424-.728.291-1.369zM8.631 42.46l-.291 1.37-3.423-.728.29-1.37zM98.84 66.827l-.432 1.331-3.329-1.081.433-1.332zM9.918 37.93l-.433 1.331-3.329-1.082.433-1.331zM97.098 71.585l-.569 1.28-3.197-1.424.57-1.28zM11.677 33.558l-.57 1.28-3.197-1.424.57-1.279zM92.149 80.439l-.823 1.133-2.832-2.058.823-1.132zM16.506 25.482l-.823 1.133-2.831-2.057.823-1.133zM89.017 84.431l-.937 1.04-2.6-2.341.936-1.04zM19.528 21.869l-.936 1.04-2.601-2.342.936-1.04zM85.48 88.076l-1.041.936-2.342-2.6 1.04-.937zM22.91 18.59l-1.04.937-2.341-2.601 1.04-.937zM81.574 91.328l-1.133.823-2.057-2.831 1.132-.823zM26.617 15.684l-1.133.823-2.057-2.832 1.132-.823zM72.873 96.524l-1.279.57-1.423-3.198 1.278-.57zM34.838 11.105l-1.279.57-1.423-3.198 1.279-.57zM68.151 98.405l-1.331.432-1.082-3.329 1.332-.432zM39.259 9.485l-1.332.433-1.081-3.33 1.331-.432zM63.272 99.799l-1.369.29-.728-3.422 1.37-.291zM43.83 8.337l-1.369.291-.727-3.423 1.37-.291zM58.27 100.662l-1.393.146-.366-3.48 1.393-.147zM48.494 7.672l-1.392.147-.366-3.481 1.392-.147z\\\"/></g></g></svg>\\n\"","export default \"<svg focusable=\\\"false\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" viewBox=\\\"0 0 105 105\\\"><path id=\\\"mod_clock_svg_hours\\\" d=\\\"M55.7 64.5h-6.4l.6-44h5.2z\\\"/></svg>\\n\"","export default \"<svg focusable=\\\"false\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" viewBox=\\\"0 0 105 105\\\"><path d=\\\"M55.1,64.5h-5.2l0.8-58h3.6L55.1,64.5z\\\"/></svg>\\n\"","export default \"<svg focusable=\\\"false\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" viewBox=\\\"0 0 105 105\\\"><path d=\\\"M57.8,21.3c0-2.9-2.4-5.2-5.2-5.2s-5.3,2.3-5.3,5.2c0,2.7,2,4.8,4.5,5.2V69h1.5V26.5C55.8,26.2,57.8,24,57.8,21.3z\\\"/></svg>\\n\"","import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, isServer, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport type { SbbTime } from '../core/interfaces.js';\n\nimport clockFaceSVG from './assets/sbb_clock_face.svg?raw';\nimport clockHandleHoursSVG from './assets/sbb_clock_hours.svg?raw';\nimport clockHandleMinutesSVG from './assets/sbb_clock_minutes.svg?raw';\nimport clockHandleSecondsSVG from './assets/sbb_clock_seconds.svg?raw';\nimport style from './clock.scss?lit&inline';\n\n/** Number of hours on the clock face. */\nconst TOTAL_HOURS_ON_CLOCK_FACE = 12;\n\n/** Number of minutes on the clock face. */\nconst TOTAL_MINUTES_ON_CLOCK_FACE = 60;\n\n/** Number of seconds on the clock face. */\nconst TOTAL_SECONDS_ON_CLOCK_FACE = 60;\n\n/** Timeout for the clock start. */\nconst INITIAL_TIMEOUT_DURATION = 50;\n\n/** Angle in a single rotation. */\nconst FULL_ANGLE = 360;\n\n/** Angle between two consecutive hours: 360/12, means a full rotation / number of hours in a rotation. */\nconst HOURS_ANGLE = 30;\n\n/** Angle between two consecutive minutes: 360/60, means a full rotation / number of minutes in one hour. */\nconst MINUTES_ANGLE = 6;\n\n/** Angle between two consecutive seconds for SBB clock custom behavior. */\nconst SBB_SECONDS_ANGLE = 360 / 58.5;\n\n/** Number of seconds in a minute. */\nconst SECONDS_IN_A_MINUTE = 60;\n\n/** Number of seconds in an hour. */\nconst SECONDS_IN_AN_HOUR = 3600;\n\nconst ADD_EVENT_LISTENER_OPTIONS: AddEventListenerOptions = {\n  once: true,\n  passive: true,\n};\n\n/**\n * It displays an analog clock with the classic SBB face.\n */\nexport\n@customElement('sbb-clock')\nclass SbbClockElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /**\n   * Define a specific time which the clock should show statically.\n   * @param value HH:MM:ss\n   */\n  @property() public accessor now: SbbTime | null = null;\n\n  /** Reference to the hour hand. */\n  private _clockHandHours!: HTMLElement;\n\n  /** Reference to the minute hand. */\n  private _clockHandMinutes!: HTMLElement;\n\n  /** Reference to the second hand. */\n  private _clockHandSeconds!: HTMLElement;\n\n  /** Hours value for the current date. */\n  private _hours!: number;\n\n  /** Minutes value for the current date. */\n  private _minutes!: number;\n\n  /** Seconds value for the current date. */\n  private _seconds!: number;\n\n  /** Move the minutes hand every minute. */\n  private _handMovement?: ReturnType<typeof setInterval>;\n\n  /** Callback function for hours hand. */\n  private _moveHoursHandFn = (): void => this._moveHoursHand();\n\n  /** Callback function for minutes hand. */\n  private _moveMinutesHandFn = (): void => this._moveMinutesHand();\n\n  protected override async willUpdate(changedProperties: PropertyValues<this>): Promise<void> {\n    super.willUpdate(changedProperties);\n\n    if (!isServer && changedProperties.has('now')) {\n      await this._startOrConfigureClock();\n    }\n  }\n\n  protected override async firstUpdated(changedProperties: PropertyValues<this>): Promise<void> {\n    super.firstUpdated(changedProperties);\n\n    if (!isServer) {\n      document.addEventListener('visibilitychange', this._handlePageVisibilityChange, false);\n      await this._startOrConfigureClock();\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._removeEventListeners();\n  }\n\n  private _handlePageVisibilityChange = async (): Promise<void> => {\n    if (document.visibilityState === 'hidden') {\n      await this._stopClock();\n    } else if (!this.now) {\n      await this._startClock();\n    }\n  };\n\n  private async _startOrConfigureClock(): Promise<void> {\n    if (this.now) {\n      await this._stopClock();\n      this._resetSecondsHandAnimation();\n      this._setHandsStartingPosition();\n    } else {\n      await this._startClock();\n    }\n  }\n\n  /** Starts the clock by defining the hands starting position then starting the animations. */\n  private async _startClock(): Promise<void> {\n    this._clockHandHours?.addEventListener(\n      'animationend',\n      this._moveHoursHandFn,\n      ADD_EVENT_LISTENER_OPTIONS,\n    );\n    this._clockHandSeconds?.addEventListener(\n      'animationend',\n      this._moveMinutesHandFn,\n      ADD_EVENT_LISTENER_OPTIONS,\n    );\n\n    await new Promise<void>((resolve) =>\n      setTimeout(() => {\n        this._setHandsStartingPosition();\n\n        this.style?.setProperty('--sbb-clock-animation-play-state', 'running');\n        resolve();\n      }, INITIAL_TIMEOUT_DURATION),\n    );\n  }\n\n  /** Stops the clock by removing all the animations. */\n  private async _stopClock(): Promise<void> {\n    clearInterval(this._handMovement);\n\n    this._removeSecondsAnimationStyles();\n    this._removeHoursAnimationStyles();\n\n    this._clockHandHours?.removeEventListener('animationend', this._moveHoursHandFn);\n    this._clockHandSeconds?.removeEventListener('animationend', this._moveMinutesHandFn);\n\n    this._clockHandMinutes?.classList.add('sbb-clock__hand-minutes--no-transition');\n\n    this.style?.setProperty('--sbb-clock-animation-play-state', 'paused');\n  }\n\n  /** Set the starting position for the three hands on the clock face. */\n  private _setHandsStartingPosition(): void {\n    this._assignCurrentTime();\n    const remainingSeconds = TOTAL_SECONDS_ON_CLOCK_FACE - this._seconds;\n    const remainingMinutes = TOTAL_MINUTES_ON_CLOCK_FACE - this._minutes;\n    const remainingHours = TOTAL_HOURS_ON_CLOCK_FACE - this._hours;\n\n    let hoursAnimationDuration = 0;\n    let hasRemainingMinutesOrSeconds = 0;\n\n    if (remainingSeconds > 0) {\n      hoursAnimationDuration += remainingSeconds;\n      hasRemainingMinutesOrSeconds = 1;\n    }\n\n    if (remainingMinutes > 0) {\n      hoursAnimationDuration +=\n        (remainingMinutes - hasRemainingMinutesOrSeconds) * SECONDS_IN_A_MINUTE;\n      hasRemainingMinutesOrSeconds = 1;\n    }\n\n    if (remainingHours > 0) {\n      hoursAnimationDuration +=\n        (remainingHours - hasRemainingMinutesOrSeconds) * SECONDS_IN_AN_HOUR;\n    }\n\n    this.style?.setProperty(\n      '--sbb-clock-hours-animation-start-angle',\n      `${Math.ceil(this._hours * HOURS_ANGLE + this._minutes / 2)}deg`,\n    );\n    this.style?.setProperty('--sbb-clock-hours-animation-duration', `${hoursAnimationDuration}s`);\n    this.style?.setProperty(\n      '--sbb-clock-seconds-animation-start-angle',\n      `${Math.ceil(this._seconds * SBB_SECONDS_ANGLE)}deg`,\n    );\n    this.style?.setProperty('--sbb-clock-seconds-animation-duration', `${remainingSeconds}s`);\n\n    this._setMinutesHand();\n\n    this._clockHandSeconds?.classList.add('sbb-clock__hand-seconds--initial-minute');\n    this._clockHandHours?.classList.add('sbb-clock__hand-hours--initial-hour');\n\n    this.toggleAttribute('data-initialized', true);\n  }\n\n  /** Given the current date, calculates the hh/mm/ss values and the hh/mm/ss left to the next midnight. */\n  private _assignCurrentTime(): void {\n    const date = this.now ? null : new Date();\n    const [hours, minutes, seconds] = date\n      ? [date.getHours(), date.getMinutes(), date.getSeconds()]\n      : this.now!.split(':').map((p) => +p);\n\n    this._hours = hours % 12;\n    this._minutes = minutes;\n    this._seconds = seconds;\n  }\n\n  /** Set the starting position for the minutes hand. */\n  private _setMinutesHand(): void {\n    this._clockHandMinutes?.style.setProperty(\n      'transform',\n      `rotateZ(${Math.ceil(this._minutes * MINUTES_ANGLE)}deg)`,\n    );\n  }\n\n  /** Move the hours hand to the next value. */\n  private _moveHoursHand(): void {\n    this._removeHoursAnimationStyles();\n\n    let hoursAngle = Math.ceil(this._hours * HOURS_ANGLE + this._minutes / 2);\n\n    if (hoursAngle >= FULL_ANGLE) {\n      hoursAngle -= FULL_ANGLE;\n    }\n\n    this._clockHandHours?.style.setProperty('transform', `rotateZ(${hoursAngle}deg)`);\n  }\n\n  /** Move the minutes hand to the next value. */\n  private _moveMinutesHand(): void {\n    this._clockHandSeconds?.removeEventListener('animationend', this._moveMinutesHandFn);\n\n    this._removeSecondsAnimationStyles();\n\n    this._addMinutesAndSetHands();\n\n    this._handMovement = setInterval(\n      () => this._addMinutesAndSetHands(),\n      TOTAL_SECONDS_ON_CLOCK_FACE * 1000,\n    );\n  }\n\n  private _addMinutesAndSetHands(): void {\n    this._minutes++;\n    this._setMinutesHand();\n  }\n\n  /**\n   * Removing animation by overriding with empty string,\n   * then triggering a reflow and re add original animation by removing override.\n   * @private\n   */\n  private _resetSecondsHandAnimation(): void {\n    if (!this._clockHandSeconds) {\n      return;\n    }\n    this._clockHandSeconds.style.animation = '';\n    // Hack to trigger reflow\n    // eslint-disable-next-line @typescript-eslint/no-unused-expressions\n    this._clockHandSeconds.offsetHeight;\n    this._clockHandSeconds.style.removeProperty('animation');\n  }\n\n  private _removeEventListeners(): void {\n    document?.removeEventListener('visibilitychange', this._handlePageVisibilityChange);\n    this._clockHandHours?.removeEventListener('animationend', this._moveHoursHandFn);\n    this._clockHandSeconds?.removeEventListener('animationend', this._moveMinutesHandFn);\n    clearInterval(this._handMovement);\n  }\n\n  private _removeHoursAnimationStyles(): void {\n    this._clockHandHours?.classList.remove('sbb-clock__hand-hours--initial-hour');\n    this.style.removeProperty('--sbb-clock-hours-animation-start-angle');\n    this.style.removeProperty('--sbb-clock-hours-animation-duration');\n  }\n\n  private _removeSecondsAnimationStyles(): void {\n    this._clockHandSeconds?.classList.remove('sbb-clock__hand-seconds--initial-minute');\n    this._clockHandMinutes?.classList.remove('sbb-clock__hand-minutes--no-transition');\n    this.style.removeProperty('--sbb-clock-seconds-animation-start-angle');\n    this.style.removeProperty('--sbb-clock-seconds-animation-duration');\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-clock\">\n        <span class=\"sbb-clock__face\" .innerHTML=${clockFaceSVG}></span>\n        <span\n          class=\"sbb-clock__hand-hours\"\n          .innerHTML=${clockHandleHoursSVG}\n          ${ref((e?: Element): void => {\n            this._clockHandHours = e as HTMLSpanElement;\n          })}\n        ></span>\n        <span\n          class=\"sbb-clock__hand-minutes sbb-clock__hand-minutes--no-transition\"\n          .innerHTML=${clockHandleMinutesSVG}\n          ${ref((el?: Element): void => {\n            this._clockHandMinutes = el as HTMLSpanElement;\n          })}\n        ></span>\n        <span\n          class=\"sbb-clock__hand-seconds\"\n          .innerHTML=${clockHandleSecondsSVG}\n          ${ref((el?: Element): void => {\n            this._clockHandSeconds = el as HTMLSpanElement;\n          })}\n        ></span>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-clock': SbbClockElement;\n  }\n}\n"],"names":["_a"],"mappings":"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"}
369
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"clock.js","sources":["../../../src/elements/clock/assets/sbb_clock_face.svg?raw","../../../src/elements/clock/assets/sbb_clock_hours.svg?raw","../../../src/elements/clock/assets/sbb_clock_minutes.svg?raw","../../../src/elements/clock/assets/sbb_clock_seconds.svg?raw","../../../src/elements/clock/clock.ts"],"sourcesContent":["export default \"<svg focusable=\\\"false\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" viewBox=\\\"0 0 105 105\\\"><g class=\\\"face\\\"><circle fill=\\\"#FFF\\\" cx=\\\"52.5\\\" cy=\\\"52.5\\\" r=\\\"52.5\\\"/><path d=\\\"M50.75 4h3.5v12h-3.5zM50.75 89h3.5v12h-3.5zM75.233 9.623l3.03 1.75-6 10.392-3.03-1.75zM32.734 83.233l3.03 1.75-6 10.392-3.03-1.75zM93.628 26.732l1.75 3.031-10.392 6-1.75-3.03zM20.017 69.234l1.75 3.031-10.392 6-1.75-3.03zM101 50.75v3.5H89v-3.5zM16 50.75v3.5H4v-3.5zM95.379 75.232l-1.75 3.031-10.392-6 1.75-3.03zM21.766 32.734l-1.75 3.031-10.392-6 1.75-3.03zM78.267 93.63l-3.03 1.75-6-10.393 3.03-1.75zM35.766 20.015l-3.03 1.75-6-10.392 3.03-1.75z\\\"/><g><path d=\\\"M56.873 4.19l1.392.147-.366 3.48-1.392-.145zM47.101 97.177l1.393.146-.366 3.481-1.392-.146zM61.896 4.914l1.37.29-.728 3.424-1.37-.29zM42.458 96.366l1.37.29-.728 3.424-1.37-.291zM66.825 6.157l1.332.432-1.082 3.33-1.331-.434zM37.931 95.085l1.332.432-1.082 3.33-1.331-.433zM71.584 7.906l1.28.569-1.424 3.197-1.28-.57zM33.56 93.32l1.278.569-1.423 3.197-1.28-.57zM80.44 12.852l1.133.823-2.058 2.831-1.132-.823zM25.481 88.494l1.133.822-2.057 2.832-1.133-.823zM84.43 15.986l1.04.937-2.342 2.6-1.04-.936zM21.87 85.469l1.04.936-2.341 2.601-1.04-.937zM88.072 19.522l.937 1.04-2.6 2.343-.937-1.04zM18.593 82.088l.937 1.04-2.601 2.342-.937-1.04zM91.328 23.425l.823 1.133-2.832 2.057-.823-1.132zM15.684 78.385l.823 1.132-2.832 2.058-.822-1.133zM96.52 32.128l.57 1.279-3.198 1.423-.57-1.278zM11.109 70.161l.569 1.279-3.197 1.423-.57-1.279zM98.407 36.85l.433 1.332-3.33 1.081-.432-1.331zM9.483 65.74l.432 1.33-3.329 1.082-.432-1.331zM99.795 41.726l.291 1.37-3.423.727-.29-1.37zM8.34 61.17l.292 1.37-3.424.728-.29-1.37zM100.66 46.73l.146 1.393-3.48.366-.147-1.392zM7.674 56.506l.146 1.392-3.48.366-.147-1.392zM100.811 56.873l-.146 1.392-3.48-.365.145-1.393zM7.821 47.101l-.146 1.392-3.48-.365.145-1.393zM100.09 61.895l-.291 1.369-3.424-.728.291-1.369zM8.631 42.46l-.291 1.37-3.423-.728.29-1.37zM98.84 66.827l-.432 1.331-3.329-1.081.433-1.332zM9.918 37.93l-.433 1.331-3.329-1.082.433-1.331zM97.098 71.585l-.569 1.28-3.197-1.424.57-1.28zM11.677 33.558l-.57 1.28-3.197-1.424.57-1.279zM92.149 80.439l-.823 1.133-2.832-2.058.823-1.132zM16.506 25.482l-.823 1.133-2.831-2.057.823-1.133zM89.017 84.431l-.937 1.04-2.6-2.341.936-1.04zM19.528 21.869l-.936 1.04-2.601-2.342.936-1.04zM85.48 88.076l-1.041.936-2.342-2.6 1.04-.937zM22.91 18.59l-1.04.937-2.341-2.601 1.04-.937zM81.574 91.328l-1.133.823-2.057-2.831 1.132-.823zM26.617 15.684l-1.133.823-2.057-2.832 1.132-.823zM72.873 96.524l-1.279.57-1.423-3.198 1.278-.57zM34.838 11.105l-1.279.57-1.423-3.198 1.279-.57zM68.151 98.405l-1.331.432-1.082-3.329 1.332-.432zM39.259 9.485l-1.332.433-1.081-3.33 1.331-.432zM63.272 99.799l-1.369.29-.728-3.422 1.37-.291zM43.83 8.337l-1.369.291-.727-3.423 1.37-.291zM58.27 100.662l-1.393.146-.366-3.48 1.393-.147zM48.494 7.672l-1.392.147-.366-3.481 1.392-.147z\\\"/></g></g></svg>\\n\"","export default \"<svg focusable=\\\"false\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" viewBox=\\\"0 0 105 105\\\"><path id=\\\"mod_clock_svg_hours\\\" d=\\\"M55.7 64.5h-6.4l.6-44h5.2z\\\"/></svg>\\n\"","export default \"<svg focusable=\\\"false\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" viewBox=\\\"0 0 105 105\\\"><path d=\\\"M55.1,64.5h-5.2l0.8-58h3.6L55.1,64.5z\\\"/></svg>\\n\"","export default \"<svg focusable=\\\"false\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" viewBox=\\\"0 0 105 105\\\"><path d=\\\"M57.8,21.3c0-2.9-2.4-5.2-5.2-5.2s-5.3,2.3-5.3,5.2c0,2.7,2,4.8,4.5,5.2V69h1.5V26.5C55.8,26.2,57.8,24,57.8,21.3z\\\"/></svg>\\n\"","import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, isServer, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport type { SbbTime } from '../core/interfaces.js';\n\nimport clockFaceSVG from './assets/sbb_clock_face.svg?raw';\nimport clockHandleHoursSVG from './assets/sbb_clock_hours.svg?raw';\nimport clockHandleMinutesSVG from './assets/sbb_clock_minutes.svg?raw';\nimport clockHandleSecondsSVG from './assets/sbb_clock_seconds.svg?raw';\nimport style from './clock.scss?lit&inline';\n\n/** Number of hours on the clock face. */\nconst TOTAL_HOURS_ON_CLOCK_FACE = 12;\n\n/** Number of minutes on the clock face. */\nconst TOTAL_MINUTES_ON_CLOCK_FACE = 60;\n\n/** Number of seconds on the clock face. */\nconst TOTAL_SECONDS_ON_CLOCK_FACE = 60;\n\n/** Timeout for the clock start. */\nconst INITIAL_TIMEOUT_DURATION = 50;\n\n/** Angle in a single rotation. */\nconst FULL_ANGLE = 360;\n\n/** Angle between two consecutive hours: 360/12, means a full rotation / number of hours in a rotation. */\nconst HOURS_ANGLE = 30;\n\n/** Angle between two consecutive minutes: 360/60, means a full rotation / number of minutes in one hour. */\nconst MINUTES_ANGLE = 6;\n\n/** Angle between two consecutive seconds for SBB clock custom behavior. */\nconst SBB_SECONDS_ANGLE = 360 / 58.5;\n\n/** Number of seconds in a minute. */\nconst SECONDS_IN_A_MINUTE = 60;\n\n/** Number of seconds in an hour. */\nconst SECONDS_IN_AN_HOUR = 3600;\n\nconst ADD_EVENT_LISTENER_OPTIONS: AddEventListenerOptions = {\n  once: true,\n  passive: true,\n};\n\n/**\n * It displays an analog clock with the classic SBB face.\n */\nexport\n@customElement('sbb-clock')\nclass SbbClockElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /**\n   * Define a specific time which the clock should show statically.\n   * @param value HH:MM:ss\n   */\n  @property() public accessor now: SbbTime | null = null;\n\n  /** Reference to the hour hand. */\n  private _clockHandHours!: HTMLElement;\n\n  /** Reference to the minute hand. */\n  private _clockHandMinutes!: HTMLElement;\n\n  /** Reference to the second hand. */\n  private _clockHandSeconds!: HTMLElement;\n\n  /** Hours value for the current date. */\n  private _hours!: number;\n\n  /** Minutes value for the current date. */\n  private _minutes!: number;\n\n  /** Seconds value for the current date. */\n  private _seconds!: number;\n\n  /** Move the minutes hand every minute. */\n  private _handMovement?: ReturnType<typeof setInterval>;\n\n  /** Callback function for hours hand. */\n  private _moveHoursHandFn = (): void => this._moveHoursHand();\n\n  /** Callback function for minutes hand. */\n  private _moveMinutesHandFn = (): void => this._moveMinutesHand();\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (!isServer && changedProperties.has('now')) {\n      this._startOrConfigureClock();\n    }\n  }\n\n  protected override async firstUpdated(changedProperties: PropertyValues<this>): Promise<void> {\n    super.firstUpdated(changedProperties);\n\n    if (!isServer) {\n      document.addEventListener('visibilitychange', this._handlePageVisibilityChange, false);\n      await this._startOrConfigureClock();\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._removeEventListeners();\n  }\n\n  private _handlePageVisibilityChange = async (): Promise<void> => {\n    if (document.visibilityState === 'hidden') {\n      await this._stopClock();\n    } else if (!this.now) {\n      await this._startClock();\n    }\n  };\n\n  private async _startOrConfigureClock(): Promise<void> {\n    if (this.now) {\n      await this._stopClock();\n      this._resetSecondsHandAnimation();\n      this._setHandsStartingPosition();\n    } else {\n      await this._startClock();\n    }\n  }\n\n  /** Starts the clock by defining the hands starting position then starting the animations. */\n  private async _startClock(): Promise<void> {\n    this._clockHandHours?.addEventListener(\n      'animationend',\n      this._moveHoursHandFn,\n      ADD_EVENT_LISTENER_OPTIONS,\n    );\n    this._clockHandSeconds?.addEventListener(\n      'animationend',\n      this._moveMinutesHandFn,\n      ADD_EVENT_LISTENER_OPTIONS,\n    );\n\n    await new Promise<void>((resolve) =>\n      setTimeout(() => {\n        this._setHandsStartingPosition();\n\n        this.style?.setProperty('--sbb-clock-animation-play-state', 'running');\n        resolve();\n      }, INITIAL_TIMEOUT_DURATION),\n    );\n  }\n\n  /** Stops the clock by removing all the animations. */\n  private async _stopClock(): Promise<void> {\n    clearInterval(this._handMovement);\n\n    this._removeSecondsAnimationStyles();\n    this._removeHoursAnimationStyles();\n\n    this._clockHandHours?.removeEventListener('animationend', this._moveHoursHandFn);\n    this._clockHandSeconds?.removeEventListener('animationend', this._moveMinutesHandFn);\n\n    this._clockHandMinutes?.classList.add('sbb-clock__hand-minutes--no-transition');\n\n    this.style?.setProperty('--sbb-clock-animation-play-state', 'paused');\n  }\n\n  /** Set the starting position for the three hands on the clock face. */\n  private _setHandsStartingPosition(): void {\n    this._assignCurrentTime();\n    const remainingSeconds = TOTAL_SECONDS_ON_CLOCK_FACE - this._seconds;\n    const remainingMinutes = TOTAL_MINUTES_ON_CLOCK_FACE - this._minutes;\n    const remainingHours = TOTAL_HOURS_ON_CLOCK_FACE - this._hours;\n\n    let hoursAnimationDuration = 0;\n    let hasRemainingMinutesOrSeconds = 0;\n\n    if (remainingSeconds > 0) {\n      hoursAnimationDuration += remainingSeconds;\n      hasRemainingMinutesOrSeconds = 1;\n    }\n\n    if (remainingMinutes > 0) {\n      hoursAnimationDuration +=\n        (remainingMinutes - hasRemainingMinutesOrSeconds) * SECONDS_IN_A_MINUTE;\n      hasRemainingMinutesOrSeconds = 1;\n    }\n\n    if (remainingHours > 0) {\n      hoursAnimationDuration +=\n        (remainingHours - hasRemainingMinutesOrSeconds) * SECONDS_IN_AN_HOUR;\n    }\n\n    this.style?.setProperty(\n      '--sbb-clock-hours-animation-start-angle',\n      `${Math.ceil(this._hours * HOURS_ANGLE + this._minutes / 2)}deg`,\n    );\n    this.style?.setProperty('--sbb-clock-hours-animation-duration', `${hoursAnimationDuration}s`);\n    this.style?.setProperty(\n      '--sbb-clock-seconds-animation-start-angle',\n      `${Math.ceil(this._seconds * SBB_SECONDS_ANGLE)}deg`,\n    );\n    this.style?.setProperty('--sbb-clock-seconds-animation-duration', `${remainingSeconds}s`);\n\n    this._setMinutesHand();\n\n    this._clockHandSeconds?.classList.add('sbb-clock__hand-seconds--initial-minute');\n    this._clockHandHours?.classList.add('sbb-clock__hand-hours--initial-hour');\n\n    this.toggleAttribute('data-initialized', true);\n  }\n\n  /** Given the current date, calculates the hh/mm/ss values and the hh/mm/ss left to the next midnight. */\n  private _assignCurrentTime(): void {\n    const date = this.now ? null : new Date();\n    const [hours, minutes, seconds] = date\n      ? [date.getHours(), date.getMinutes(), date.getSeconds()]\n      : this.now!.split(':').map((p) => +p);\n\n    this._hours = hours % 12;\n    this._minutes = minutes;\n    this._seconds = seconds;\n  }\n\n  /** Set the starting position for the minutes hand. */\n  private _setMinutesHand(): void {\n    this._clockHandMinutes?.style.setProperty(\n      'transform',\n      `rotateZ(${Math.ceil(this._minutes * MINUTES_ANGLE)}deg)`,\n    );\n  }\n\n  /** Move the hours hand to the next value. */\n  private _moveHoursHand(): void {\n    this._removeHoursAnimationStyles();\n\n    let hoursAngle = Math.ceil(this._hours * HOURS_ANGLE + this._minutes / 2);\n\n    if (hoursAngle >= FULL_ANGLE) {\n      hoursAngle -= FULL_ANGLE;\n    }\n\n    this._clockHandHours?.style.setProperty('transform', `rotateZ(${hoursAngle}deg)`);\n  }\n\n  /** Move the minutes hand to the next value. */\n  private _moveMinutesHand(): void {\n    this._clockHandSeconds?.removeEventListener('animationend', this._moveMinutesHandFn);\n\n    this._removeSecondsAnimationStyles();\n\n    this._addMinutesAndSetHands();\n\n    this._handMovement = setInterval(\n      () => this._addMinutesAndSetHands(),\n      TOTAL_SECONDS_ON_CLOCK_FACE * 1000,\n    );\n  }\n\n  private _addMinutesAndSetHands(): void {\n    this._minutes++;\n    this._setMinutesHand();\n  }\n\n  /**\n   * Removing animation by overriding with empty string,\n   * then triggering a reflow and re add original animation by removing override.\n   * @private\n   */\n  private _resetSecondsHandAnimation(): void {\n    if (!this._clockHandSeconds) {\n      return;\n    }\n    this._clockHandSeconds.style.animation = '';\n    // Hack to trigger reflow\n    // eslint-disable-next-line @typescript-eslint/no-unused-expressions\n    this._clockHandSeconds.offsetHeight;\n    this._clockHandSeconds.style.removeProperty('animation');\n  }\n\n  private _removeEventListeners(): void {\n    document?.removeEventListener('visibilitychange', this._handlePageVisibilityChange);\n    this._clockHandHours?.removeEventListener('animationend', this._moveHoursHandFn);\n    this._clockHandSeconds?.removeEventListener('animationend', this._moveMinutesHandFn);\n    clearInterval(this._handMovement);\n  }\n\n  private _removeHoursAnimationStyles(): void {\n    this._clockHandHours?.classList.remove('sbb-clock__hand-hours--initial-hour');\n    this.style.removeProperty('--sbb-clock-hours-animation-start-angle');\n    this.style.removeProperty('--sbb-clock-hours-animation-duration');\n  }\n\n  private _removeSecondsAnimationStyles(): void {\n    this._clockHandSeconds?.classList.remove('sbb-clock__hand-seconds--initial-minute');\n    this._clockHandMinutes?.classList.remove('sbb-clock__hand-minutes--no-transition');\n    this.style.removeProperty('--sbb-clock-seconds-animation-start-angle');\n    this.style.removeProperty('--sbb-clock-seconds-animation-duration');\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-clock\">\n        <span class=\"sbb-clock__face\" .innerHTML=${clockFaceSVG}></span>\n        <span\n          class=\"sbb-clock__hand-hours\"\n          .innerHTML=${clockHandleHoursSVG}\n          ${ref((e?: Element): void => {\n            this._clockHandHours = e as HTMLSpanElement;\n          })}\n        ></span>\n        <span\n          class=\"sbb-clock__hand-minutes sbb-clock__hand-minutes--no-transition\"\n          .innerHTML=${clockHandleMinutesSVG}\n          ${ref((el?: Element): void => {\n            this._clockHandMinutes = el as HTMLSpanElement;\n          })}\n        ></span>\n        <span\n          class=\"sbb-clock__hand-seconds\"\n          .innerHTML=${clockHandleSecondsSVG}\n          ${ref((el?: Element): void => {\n            this._clockHandSeconds = el as HTMLSpanElement;\n          })}\n        ></span>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-clock': SbbClockElement;\n  }\n}\n"],"names":["_a"],"mappings":"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"}
@@ -1,8 +1,13 @@
1
1
  import { CSSResultGroup, LitElement, PropertyValues, TemplateResult } from 'lit';
2
+ declare const SbbStickyBarElement_base: import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbUpdateSchedulerMixinType> & typeof LitElement;
2
3
  /**
3
4
  * A container that sticks to the bottom of the page if slotted into `sbb-container`.
4
5
  *
5
6
  * @slot - Use the unnamed slot to add content to the sticky bar.
7
+ * @event {CustomEvent<void>} willStick - Emits when the animation from normal content flow to `position: sticky` starts. Can be canceled.
8
+ * @event {CustomEvent<void>} didStick - Emits when the animation from normal content flow to `position: sticky` ends.
9
+ * @event {CustomEvent<void>} willUnstick - Emits when the animation from `position: sticky` to normal content flow starts. Can be canceled.
10
+ * @event {CustomEvent<void>} didUnstick - Emits when the animation from `position: sticky` to normal content flow ends.
6
11
  * @cssprop [--sbb-sticky-bar-padding-block=var(--sbb-spacing-responsive-xs)] - Block padding of the sticky bar.
7
12
  * @cssprop [--sbb-sticky-bar-bottom-overlapping-height=0px] - Define an additional area where
8
13
  * the sticky bar overlaps the following content on the bottom.
@@ -10,15 +15,36 @@ import { CSSResultGroup, LitElement, PropertyValues, TemplateResult } from 'lit'
10
15
  * @cssprop [--sbb-sticky-bar-z-index] - To specify a custom stack order,
11
16
  * the `z-index` can be overridden by defining this CSS variable.
12
17
  */
13
- export declare class SbbStickyBarElement extends LitElement {
18
+ export declare class SbbStickyBarElement extends SbbStickyBarElement_base {
14
19
  static styles: CSSResultGroup;
20
+ static readonly events: {
21
+ readonly willStick: "willStick";
22
+ readonly didStick: "didStick";
23
+ readonly willUnstick: "willUnstick";
24
+ readonly didUnstick: "didUnstick";
25
+ };
15
26
  /** Color of the container, like transparent, white etc. */
16
27
  accessor color: 'white' | 'milk' | null;
28
+ /** The state of the component. */
29
+ private set _state(value);
30
+ private get _state();
31
+ private _willStick;
32
+ private _didStick;
33
+ private _willUnstick;
34
+ private _didUnstick;
17
35
  private _intersector?;
18
36
  private _observer;
19
37
  connectedCallback(): void;
38
+ disconnectedCallback(): void;
20
39
  protected firstUpdated(changedProperties: PropertyValues<this>): void;
21
- private _toggleShadowVisibility;
40
+ private _detectStickyState;
41
+ /** Animates from normal content flow position to `position: sticky`. */
42
+ stick(): void;
43
+ /** Animates `position: sticky` to normal content flow position. */
44
+ unstick(): void;
45
+ private _stickyCallback;
46
+ private _unstickyCallback;
47
+ private _onAnimationEnd;
22
48
  protected render(): TemplateResult;
23
49
  }
24
50
  declare global {
@@ -26,4 +52,5 @@ declare global {
26
52
  'sbb-sticky-bar': SbbStickyBarElement;
27
53
  }
28
54
  }
55
+ export {};
29
56
  //# sourceMappingURL=sticky-bar.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"sticky-bar.d.ts","sourceRoot":"","sources":["../../../../../src/elements/container/sticky-bar/sticky-bar.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,cAAc,EAEnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAOb;;;;;;;;;;GAUG;AACH,qBAKM,mBAAoB,SAAQ,UAAU;IAC1C,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,2DAA2D;IAC3D,SAA6C,KAAK,EAAE,OAAO,GAAG,MAAM,GAAG,IAAI,CAAQ;IAEnF,OAAO,CAAC,YAAY,CAAC,CAAkB;IACvC,OAAO,CAAC,SAAS,CAKd;IAEa,iBAAiB,IAAI,IAAI;cAYtB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAU9E,OAAO,CAAC,uBAAuB;cAOZ,MAAM,IAAI,cAAc;CAU5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,mBAAmB,CAAC;KACvC;CACF"}
1
+ {"version":3,"file":"sticky-bar.d.ts","sourceRoot":"","sources":["../../../../../src/elements/container/sticky-bar/sticky-bar.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,cAAc,EAEnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;;AAWb;;;;;;;;;;;;;;GAcG;AACH,qBAKM,mBAAoB,SAAQ,wBAAmC;IACnE,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,gBAAuB,MAAM;;;;;MAKlB;IAEX,2DAA2D;IAC3D,SAA6C,KAAK,EAAE,OAAO,GAAG,MAAM,GAAG,IAAI,CAAQ;IAEnF,kCAAkC;IAClC,OAAO,KAAK,MAAM,QAEjB;IACD,OAAO,KAAK,MAAM,GAEjB;IAED,OAAO,CAAC,UAAU,CAA8E;IAChG,OAAO,CAAC,SAAS,CAA6E;IAC9F,OAAO,CAAC,YAAY,CAGlB;IACF,OAAO,CAAC,WAAW,CAA+E;IAElG,OAAO,CAAC,YAAY,CAAC,CAAkB;IACvC,OAAO,CAAC,SAAS,CAKd;IAEa,iBAAiB,IAAI,IAAI;IAgBzB,oBAAoB,IAAI,IAAI;cAMzB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAU9E,OAAO,CAAC,kBAAkB;IA+B1B,wEAAwE;IACjE,KAAK,IAAI,IAAI;IAWpB,mEAAmE;IAC5D,OAAO,IAAI,IAAI;IAYtB,OAAO,CAAC,eAAe;IAKvB,OAAO,CAAC,iBAAiB;IAKzB,OAAO,CAAC,eAAe;cAWJ,MAAM,IAAI,cAAc;CAU5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,mBAAmB,CAAC;KACvC;CACF"}
@@ -7,9 +7,11 @@ var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot
7
7
  var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
8
8
  import { __runInitializers, __esDecorate } from "tslib";
9
9
  import { IntersectionController } from "@lit-labs/observers/intersection-controller.js";
10
- import { css, html, LitElement } from "lit";
10
+ import { css, LitElement, html } from "lit";
11
11
  import { customElement, property } from "lit/decorators.js";
12
12
  import { hostAttributes } from "../core/decorators.js";
13
+ import { EventEmitter } from "../core/eventing.js";
14
+ import { SbbUpdateSchedulerMixin } from "../core/mixins.js";
13
15
  const style = css`*,
14
16
  ::before,
15
17
  ::after {
@@ -17,7 +19,10 @@ const style = css`*,
17
19
  }
18
20
 
19
21
  :host {
22
+ --sbb-sticky-bar-position: sticky;
20
23
  --sbb-sticky-bar-padding-block: var(--sbb-spacing-responsive-xs);
24
+ --sbb-sticky-bar-border-radius: var(--sbb-border-radius-8x);
25
+ --sbb-sticky-bar-animation-easing: var(--sbb-animation-easing);
21
26
  --sbb-sticky-bar-fade-in-animation-duration: var(
22
27
  --sbb-disable-animation-zero-time,
23
28
  var(--sbb-animation-duration-5x)
@@ -26,31 +31,71 @@ const style = css`*,
26
31
  --sbb-disable-animation-zero-time,
27
32
  var(--sbb-animation-duration-2x)
28
33
  );
29
- --sbb-sticky-bar-animation-easing: var(--sbb-animation-easing);
30
- --sbb-sticky-bar-border-radius: var(--sbb-border-radius-8x);
34
+ --sbb-sticky-bar-slide-vertically-animation-duration: var(
35
+ --sbb-disable-animation-zero-duration,
36
+ var(--sbb-animation-duration-4x)
37
+ );
38
+ --sbb-sticky-bar-slide-vertically-animation-easing: ease-out;
39
+ --sbb-sticky-bar-slide-vertically-animation-delay: 0s;
40
+ --sbb-sticky-bar-slide-vertically-animation-name: unset;
41
+ --_sbb-sticky-bar-background-animation-duration: var(
42
+ --sbb-sticky-bar-fade-out-animation-duration
43
+ );
44
+ --_sbb-sticky-bar-intersector-background-color: transparent;
45
+ --_sbb-sticky-bar-forced-colors-border: none;
31
46
  display: contents;
32
47
  }
33
48
 
34
- :host([data-sticking]) {
49
+ :host([data-sticking]:not([data-state=unsticky])) {
35
50
  --sbb-sticky-bar-sticky-background-color: var(
36
51
  --sbb-container-background-color,
37
52
  var(--sbb-color-white)
38
53
  );
54
+ --_sbb-sticky-bar-intersector-background-color: var(--sbb-sticky-bar-sticky-background-color);
55
+ --_sbb-sticky-bar-background-animation-duration: var(--sbb-sticky-bar-fade-in-animation-duration);
56
+ }
57
+ @media (forced-colors: active) {
58
+ :host([data-sticking]:not([data-state=unsticky])) {
59
+ --_sbb-sticky-bar-forced-colors-border: var(--sbb-border-width-1x) solid CanvasText;
60
+ }
39
61
  }
40
62
 
41
- :host([data-sticking][color=white]) {
63
+ :host([data-sticking]:not([data-state=unsticky])[color=white]) {
42
64
  --sbb-sticky-bar-sticky-background-color: var(--sbb-color-white);
43
65
  }
44
66
 
45
- :host([data-sticking][color=milk]) {
67
+ :host([data-sticking]:not([data-state=unsticky])[color=milk]) {
46
68
  --sbb-sticky-bar-sticky-background-color: var(--sbb-color-milk);
47
69
  }
48
70
 
71
+ :host(:is([data-sticking]:is([data-slide-vertically], [data-state=sticking], [data-state=unsticking]),
72
+ [data-state=unsticky])) {
73
+ --_sbb-sticky-bar-background-animation-duration: 0s;
74
+ }
75
+
76
+ :host([data-sticking]:is([data-slide-vertically]:not([data-state=unsticky], [data-state=unsticking]),
77
+ [data-state=sticking])) {
78
+ --sbb-sticky-bar-slide-vertically-animation-name: slide-in;
79
+ }
80
+
81
+ :host([data-sticking][data-state=unsticking]) {
82
+ --sbb-sticky-bar-slide-vertically-animation-name: slide-out;
83
+ }
84
+
85
+ :host(:is(:not([data-initialized]), [data-state=unsticky])) {
86
+ --sbb-sticky-bar-position: relative;
87
+ }
88
+
49
89
  .sbb-sticky-bar__wrapper {
50
- position: sticky;
90
+ position: var(--sbb-sticky-bar-position);
51
91
  inset-block-end: 0;
52
92
  display: block;
53
93
  z-index: var(--sbb-sticky-bar-z-index);
94
+ animation-name: var(--sbb-sticky-bar-slide-vertically-animation-name);
95
+ animation-duration: var(--sbb-sticky-bar-slide-vertically-animation-duration);
96
+ animation-timing-function: var(--sbb-sticky-bar-slide-vertically-animation-easing);
97
+ animation-delay: var(--sbb-sticky-bar-slide-vertically-animation-delay);
98
+ animation-fill-mode: backwards;
54
99
  }
55
100
  .sbb-sticky-bar__wrapper::after, .sbb-sticky-bar__wrapper::before {
56
101
  content: "";
@@ -75,18 +120,10 @@ const style = css`*,
75
120
  }
76
121
  .sbb-sticky-bar__wrapper::after {
77
122
  background-color: var(--sbb-sticky-bar-sticky-background-color, transparent);
78
- transition: background-color var(--sbb-sticky-bar-fade-out-animation-duration) var(--sbb-sticky-bar-animation-easing);
79
123
  border-start-start-radius: var(--sbb-sticky-bar-border-radius);
80
124
  border-start-end-radius: var(--sbb-sticky-bar-border-radius);
81
- }
82
- :host([data-sticking]) .sbb-sticky-bar__wrapper::after {
83
- transition-duration: var(--sbb-sticky-bar-fade-in-animation-duration);
84
- }
85
- @media (forced-colors: active) {
86
- :host([data-sticking]) .sbb-sticky-bar__wrapper::after {
87
- border-block-start: var(--sbb-border-width-1x) solid CanvasText;
88
- border-radius: 0;
89
- }
125
+ transition: background-color var(--_sbb-sticky-bar-background-animation-duration) var(--sbb-sticky-bar-animation-easing);
126
+ border: var(--_sbb-sticky-bar-forced-colors-border);
90
127
  }
91
128
 
92
129
  .sbb-sticky-bar {
@@ -101,12 +138,11 @@ const style = css`*,
101
138
  z-index: -1;
102
139
  border-start-start-radius: var(--sbb-sticky-bar-border-radius);
103
140
  border-start-end-radius: var(--sbb-sticky-bar-border-radius);
104
- transition: box-shadow var(--sbb-sticky-bar-fade-out-animation-duration) var(--sbb-sticky-bar-animation-easing);
141
+ transition: box-shadow var(--_sbb-sticky-bar-background-animation-duration) var(--sbb-sticky-bar-animation-easing);
105
142
  clip-path: polygon(-50% calc(-1 * var(--sbb-shadow-elevation-level-11-shadow-1-blur)), 150% calc(-1 * var(--sbb-shadow-elevation-level-11-shadow-1-blur)), 150% 50%, -50% 50%);
106
143
  }
107
- :host([data-sticking]) .sbb-sticky-bar::before {
144
+ :host([data-sticking]:not([data-state=unsticky])) .sbb-sticky-bar::before {
108
145
  box-shadow: var(--sbb-shadow-elevation-level-11-shadow-2-offset-x) var(--sbb-shadow-elevation-level-11-shadow-2-offset-y) var(--sbb-shadow-elevation-level-11-shadow-2-blur) var(--sbb-shadow-elevation-level-11-shadow-2-spread) var(--sbb-shadow-elevation-level-11-soft-2-color), var(--sbb-shadow-elevation-level-11-shadow-1-offset-x) var(--sbb-shadow-elevation-level-11-shadow-1-offset-y) var(--sbb-shadow-elevation-level-11-shadow-1-blur) var(--sbb-shadow-elevation-level-11-shadow-1-spread) var(--sbb-shadow-elevation-level-11-soft-1-color);
109
- transition-duration: var(--sbb-sticky-bar-fade-in-animation-duration);
110
146
  }
111
147
  :host(:not([data-expanded])) .sbb-sticky-bar {
112
148
  padding-inline: var(--sbb-layout-base-offset-responsive);
@@ -131,13 +167,26 @@ const style = css`*,
131
167
  position: absolute;
132
168
  width: 100%;
133
169
  height: calc(var(--sbb-sticky-bar-bottom-overlapping-height, 0) + 1px);
134
- background-color: transparent;
170
+ background-color: var(--_sbb-sticky-bar-intersector-background-color);
135
171
  pointer-events: none;
136
- transition: background-color var(--sbb-sticky-bar-fade-out-animation-duration) var(--sbb-sticky-bar-animation-easing);
172
+ transition: background-color var(--_sbb-sticky-bar-background-animation-duration) var(--sbb-sticky-bar-animation-easing);
173
+ }
174
+
175
+ @keyframes slide-in {
176
+ from {
177
+ transform: translateY(100%);
178
+ }
179
+ to {
180
+ transform: translateY(0%);
181
+ }
137
182
  }
138
- :host([data-sticking]) .sbb-sticky-bar__intersector::after {
139
- transition-duration: var(--sbb-sticky-bar-fade-in-animation-duration);
140
- background-color: var(--sbb-sticky-bar-sticky-background-color);
183
+ @keyframes slide-out {
184
+ from {
185
+ transform: translateY(0%);
186
+ }
187
+ to {
188
+ transform: translateY(100%);
189
+ }
141
190
  }`;
142
191
  let SbbStickyBarElement = (() => {
143
192
  var _color_accessor_storage, _a;
@@ -147,21 +196,24 @@ let SbbStickyBarElement = (() => {
147
196
  let _classDescriptor;
148
197
  let _classExtraInitializers = [];
149
198
  let _classThis;
150
- let _classSuper = LitElement;
199
+ let _classSuper = SbbUpdateSchedulerMixin(LitElement);
151
200
  let _color_decorators;
152
201
  let _color_initializers = [];
153
202
  let _color_extraInitializers = [];
154
- _a = class extends _classSuper {
203
+ var SbbStickyBarElement2 = (_a = class extends _classSuper {
155
204
  constructor() {
156
205
  super(...arguments);
157
206
  __privateAdd(this, _color_accessor_storage);
158
207
  __privateSet(this, _color_accessor_storage, __runInitializers(this, _color_initializers, null));
159
- this._intersector = __runInitializers(this, _color_extraInitializers);
208
+ this._willStick = (__runInitializers(this, _color_extraInitializers), new EventEmitter(this, SbbStickyBarElement2.events.willStick));
209
+ this._didStick = new EventEmitter(this, SbbStickyBarElement2.events.didStick);
210
+ this._willUnstick = new EventEmitter(this, SbbStickyBarElement2.events.willUnstick);
211
+ this._didUnstick = new EventEmitter(this, SbbStickyBarElement2.events.didUnstick);
160
212
  this._observer = new IntersectionController(this, {
161
213
  // Although `this` is observed, we have to postpone observing
162
214
  // into firstUpdated() to achieve a correct initial state.
163
215
  target: null,
164
- callback: (entries) => this._toggleShadowVisibility(entries[0])
216
+ callback: (entries) => this._detectStickyState(entries[0])
165
217
  });
166
218
  }
167
219
  /** Color of the container, like transparent, white etc. */
@@ -171,8 +223,17 @@ let SbbStickyBarElement = (() => {
171
223
  set color(value) {
172
224
  __privateSet(this, _color_accessor_storage, value);
173
225
  }
226
+ /** The state of the component. */
227
+ set _state(state) {
228
+ this.setAttribute("data-state", state);
229
+ }
230
+ get _state() {
231
+ return this.getAttribute("data-state");
232
+ }
174
233
  connectedCallback() {
175
234
  super.connectedCallback();
235
+ this._state = "sticky";
236
+ this.startUpdate();
176
237
  const container = this.closest("sbb-container");
177
238
  if (container) {
178
239
  this.toggleAttribute("data-expanded", container.expanded);
@@ -181,6 +242,10 @@ let SbbStickyBarElement = (() => {
181
242
  this._observer.observe(this._intersector);
182
243
  }
183
244
  }
245
+ disconnectedCallback() {
246
+ super.disconnectedCallback();
247
+ this.toggleAttribute("data-initialized", false);
248
+ }
184
249
  firstUpdated(changedProperties) {
185
250
  super.firstUpdated(changedProperties);
186
251
  if (!this._intersector) {
@@ -189,12 +254,55 @@ let SbbStickyBarElement = (() => {
189
254
  }
190
255
  this._observer.observe(this);
191
256
  }
192
- _toggleShadowVisibility(entry) {
193
- this.toggleAttribute("data-sticking", !entry.isIntersecting && entry.boundingClientRect.top > 0);
257
+ _detectStickyState(entry) {
258
+ var _a2;
259
+ this.toggleAttribute("data-initialized", true);
260
+ const isSticky = !entry.isIntersecting && entry.boundingClientRect.top > 0;
261
+ const intersectorRect = (_a2 = this._intersector) == null ? void 0 : _a2.getBoundingClientRect();
262
+ const stickyBarRect = this.shadowRoot.querySelector(".sbb-sticky-bar__wrapper").getBoundingClientRect();
263
+ const HEIGHT_TOLERANCE = 30;
264
+ this.toggleAttribute("data-slide-vertically", isSticky && this._intersector && Math.abs(intersectorRect.bottom - stickyBarRect.bottom) > HEIGHT_TOLERANCE);
265
+ this.toggleAttribute("data-sticking", isSticky);
266
+ this.completeUpdate();
267
+ }
268
+ /** Animates from normal content flow position to `position: sticky`. */
269
+ stick() {
270
+ if (this._state !== "unsticky" || !this._willStick.emit()) {
271
+ return;
272
+ }
273
+ this._state = "sticking";
274
+ if (!this.hasAttribute("data-sticking")) {
275
+ this._stickyCallback();
276
+ }
277
+ }
278
+ /** Animates `position: sticky` to normal content flow position. */
279
+ unstick() {
280
+ if (this._state !== "sticky" || !this._willUnstick.emit()) {
281
+ return;
282
+ }
283
+ this._state = "unsticking";
284
+ if (!this.hasAttribute("data-sticking")) {
285
+ this._unstickyCallback();
286
+ }
287
+ }
288
+ _stickyCallback() {
289
+ this._state = "sticky";
290
+ this._didStick.emit();
291
+ }
292
+ _unstickyCallback() {
293
+ this._didUnstick.emit();
294
+ this._state = "unsticky";
295
+ }
296
+ _onAnimationEnd(event) {
297
+ if ((this._state === "sticking" || this._state === "sticky") && event.animationName === "slide-in") {
298
+ this._stickyCallback();
299
+ } else if (this._state === "unsticking" && event.animationName === "slide-out") {
300
+ this._unstickyCallback();
301
+ }
194
302
  }
195
303
  render() {
196
304
  return html`
197
- <div class="sbb-sticky-bar__wrapper">
305
+ <div class="sbb-sticky-bar__wrapper" @animationend=${this._onAnimationEnd}>
198
306
  <div class="sbb-sticky-bar">
199
307
  <slot></slot>
200
308
  </div>
@@ -209,12 +317,17 @@ let SbbStickyBarElement = (() => {
209
317
  obj.color = value;
210
318
  } }, metadata: _metadata }, _color_initializers, _color_extraInitializers);
211
319
  __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
212
- _classThis = _classDescriptor.value;
320
+ SbbStickyBarElement2 = _classThis = _classDescriptor.value;
213
321
  if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
214
- })(), _a.styles = style, __runInitializers(_classThis, _classExtraInitializers), _a;
215
- return _classThis;
322
+ })(), _a.styles = style, _a.events = {
323
+ willStick: "willStick",
324
+ didStick: "didStick",
325
+ willUnstick: "willUnstick",
326
+ didUnstick: "didUnstick"
327
+ }, __runInitializers(_classThis, _classExtraInitializers), _a);
328
+ return SbbStickyBarElement2 = _classThis;
216
329
  })();
217
330
  export {
218
331
  SbbStickyBarElement
219
332
  };
220
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RpY2t5LWJhci5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2NvbnRhaW5lci9zdGlja3ktYmFyL3N0aWNreS1iYXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW50ZXJzZWN0aW9uQ29udHJvbGxlciB9IGZyb20gJ0BsaXQtbGFicy9vYnNlcnZlcnMvaW50ZXJzZWN0aW9uLWNvbnRyb2xsZXIuanMnO1xuaW1wb3J0IHtcbiAgdHlwZSBDU1NSZXN1bHRHcm91cCxcbiAgaHRtbCxcbiAgTGl0RWxlbWVudCxcbiAgdHlwZSBQcm9wZXJ0eVZhbHVlcyxcbiAgdHlwZSBUZW1wbGF0ZVJlc3VsdCxcbn0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBob3N0QXR0cmlidXRlcyB9IGZyb20gJy4uLy4uL2NvcmUvZGVjb3JhdG9ycy5qcyc7XG5cbmltcG9ydCBzdHlsZSBmcm9tICcuL3N0aWNreS1iYXIuc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBBIGNvbnRhaW5lciB0aGF0IHN0aWNrcyB0byB0aGUgYm90dG9tIG9mIHRoZSBwYWdlIGlmIHNsb3R0ZWQgaW50byBgc2JiLWNvbnRhaW5lcmAuXG4gKlxuICogQHNsb3QgLSBVc2UgdGhlIHVubmFtZWQgc2xvdCB0byBhZGQgY29udGVudCB0byB0aGUgc3RpY2t5IGJhci5cbiAqIEBjc3Nwcm9wIFstLXNiYi1zdGlja3ktYmFyLXBhZGRpbmctYmxvY2s9dmFyKC0tc2JiLXNwYWNpbmctcmVzcG9uc2l2ZS14cyldIC0gQmxvY2sgcGFkZGluZyBvZiB0aGUgc3RpY2t5IGJhci5cbiAqIEBjc3Nwcm9wIFstLXNiYi1zdGlja3ktYmFyLWJvdHRvbS1vdmVybGFwcGluZy1oZWlnaHQ9MHB4XSAtIERlZmluZSBhbiBhZGRpdGlvbmFsIGFyZWEgd2hlcmVcbiAqIHRoZSBzdGlja3kgYmFyIG92ZXJsYXBzIHRoZSBmb2xsb3dpbmcgY29udGVudCBvbiB0aGUgYm90dG9tLlxuICogVGhpcyBhcmVhIGJlY29tZXMgdmlzaWJsZSB3aGVuIHRoZSBzdGlja3kgYmFyIHRyYW5zaXRpb25zIGZyb20gc3RpY2t5IHRvIHRoZSBub3JtYWwgZG9jdW1lbnQgZmxvdy5cbiAqIEBjc3Nwcm9wIFstLXNiYi1zdGlja3ktYmFyLXotaW5kZXhdIC0gVG8gc3BlY2lmeSBhIGN1c3RvbSBzdGFjayBvcmRlcixcbiAqIHRoZSBgei1pbmRleGAgY2FuIGJlIG92ZXJyaWRkZW4gYnkgZGVmaW5pbmcgdGhpcyBDU1MgdmFyaWFibGUuXG4gKi9cbmV4cG9ydFxuQGN1c3RvbUVsZW1lbnQoJ3NiYi1zdGlja3ktYmFyJylcbkBob3N0QXR0cmlidXRlcyh7XG4gIHNsb3Q6ICdzdGlja3ktYmFyJyxcbn0pXG5jbGFzcyBTYmJTdGlja3lCYXJFbGVtZW50IGV4dGVuZHMgTGl0RWxlbWVudCB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IHN0eWxlO1xuXG4gIC8qKiBDb2xvciBvZiB0aGUgY29udGFpbmVyLCBsaWtlIHRyYW5zcGFyZW50LCB3aGl0ZSBldGMuICovXG4gIEBwcm9wZXJ0eSh7IHJlZmxlY3Q6IHRydWUgfSkgcHVibGljIGFjY2Vzc29yIGNvbG9yOiAnd2hpdGUnIHwgJ21pbGsnIHwgbnVsbCA9IG51bGw7XG5cbiAgcHJpdmF0ZSBfaW50ZXJzZWN0b3I/OiBIVE1MU3BhbkVsZW1lbnQ7XG4gIHByaXZhdGUgX29ic2VydmVyID0gbmV3IEludGVyc2VjdGlvbkNvbnRyb2xsZXIodGhpcywge1xuICAgIC8vIEFsdGhvdWdoIGB0aGlzYCBpcyBvYnNlcnZlZCwgd2UgaGF2ZSB0byBwb3N0cG9uZSBvYnNlcnZpbmdcbiAgICAvLyBpbnRvIGZpcnN0VXBkYXRlZCgpIHRvIGFjaGlldmUgYSBjb3JyZWN0IGluaXRpYWwgc3RhdGUuXG4gICAgdGFyZ2V0OiBudWxsLFxuICAgIGNhbGxiYWNrOiAoZW50cmllcykgPT4gdGhpcy5fdG9nZ2xlU2hhZG93VmlzaWJpbGl0eShlbnRyaWVzWzBdKSxcbiAgfSk7XG5cbiAgcHVibGljIG92ZXJyaWRlIGNvbm5lY3RlZENhbGxiYWNrKCk6IHZvaWQge1xuICAgIHN1cGVyLmNvbm5lY3RlZENhbGxiYWNrKCk7XG5cbiAgICBjb25zdCBjb250YWluZXIgPSB0aGlzLmNsb3Nlc3QoJ3NiYi1jb250YWluZXInKTtcbiAgICBpZiAoY29udGFpbmVyKSB7XG4gICAgICB0aGlzLnRvZ2dsZUF0dHJpYnV0ZSgnZGF0YS1leHBhbmRlZCcsIGNvbnRhaW5lci5leHBhbmRlZCk7XG4gICAgfVxuICAgIGlmICh0aGlzLl9pbnRlcnNlY3Rvcikge1xuICAgICAgdGhpcy5fb2JzZXJ2ZXIub2JzZXJ2ZSh0aGlzLl9pbnRlcnNlY3Rvcik7XG4gICAgfVxuICB9XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIGZpcnN0VXBkYXRlZChjaGFuZ2VkUHJvcGVydGllczogUHJvcGVydHlWYWx1ZXM8dGhpcz4pOiB2b2lkIHtcbiAgICBzdXBlci5maXJzdFVwZGF0ZWQoY2hhbmdlZFByb3BlcnRpZXMpO1xuXG4gICAgaWYgKCF0aGlzLl9pbnRlcnNlY3Rvcikge1xuICAgICAgdGhpcy5faW50ZXJzZWN0b3IgPSB0aGlzLnNoYWRvd1Jvb3QhLnF1ZXJ5U2VsZWN0b3IoJy5zYmItc3RpY2t5LWJhcl9faW50ZXJzZWN0b3InKSE7XG4gICAgICB0aGlzLl9vYnNlcnZlci5vYnNlcnZlKHRoaXMuX2ludGVyc2VjdG9yKTtcbiAgICB9XG4gICAgdGhpcy5fb2JzZXJ2ZXIub2JzZXJ2ZSh0aGlzKTtcbiAgfVxuXG4gIHByaXZhdGUgX3RvZ2dsZVNoYWRvd1Zpc2liaWxpdHkoZW50cnk6IEludGVyc2VjdGlvbk9ic2VydmVyRW50cnkpOiB2b2lkIHtcbiAgICB0aGlzLnRvZ2dsZUF0dHJpYnV0ZShcbiAgICAgICdkYXRhLXN0aWNraW5nJyxcbiAgICAgICFlbnRyeS5pc0ludGVyc2VjdGluZyAmJiBlbnRyeS5ib3VuZGluZ0NsaWVudFJlY3QudG9wID4gMCxcbiAgICApO1xuICB9XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgcmV0dXJuIGh0bWxgXG4gICAgICA8ZGl2IGNsYXNzPVwic2JiLXN0aWNreS1iYXJfX3dyYXBwZXJcIj5cbiAgICAgICAgPGRpdiBjbGFzcz1cInNiYi1zdGlja3ktYmFyXCI+XG4gICAgICAgICAgPHNsb3Q+PC9zbG90PlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cInNiYi1zdGlja3ktYmFyX19pbnRlcnNlY3RvclwiPjwvZGl2PlxuICAgIGA7XG4gIH1cbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi1zdGlja3ktYmFyJzogU2JiU3RpY2t5QmFyRWxlbWVudDtcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztJQThCTSx1QkFBbUIsTUFBQTs7QUFKeEIsTUFBQSxtQkFBQSxDQUFBLGNBQWMsZ0JBQWdCLEdBQzlCLGVBQWU7QUFBQSxJQUNkLE1BQU07QUFBQSxFQUFBLENBQ1AsQ0FBQzs7OztvQkFDZ0M7Ozs7QUFBUixFQUFBLG1CQUFRLFlBQVU7QUFBQTs7QUFJYjtBQUFnQix5QkFBQSx5QkFBQSxrQkFBQSxNQUFBLHFCQUFpQyxJQUFJO0FBRTFFLFdBQUEsZUFBK0Isa0JBQUEsTUFBQSx3QkFBQTtBQUMvQixXQUFBLFlBQVksSUFBSSx1QkFBdUIsTUFBTTtBQUFBO0FBQUE7QUFBQSxRQUduRCxRQUFRO0FBQUEsUUFDUixVQUFVLENBQUMsWUFBWSxLQUFLLHdCQUF3QixRQUFRLENBQUMsQ0FBQztBQUFBLE1BQUEsQ0FDL0Q7QUFBQSxJQUFBO0FBQUE7QUFBQSxJQVI0QixJQUFnQixRQUFzQztBQUFBLGFBQUEsbUJBQUE7QUFBQSxJQUFBO0FBQUEsSUFBdEQsSUFBZ0IsTUFBc0MsT0FBQTtBQUFBLHlCQUFBLHlCQUFBO0FBQUEsSUFBQTtBQUFBLElBVW5FLG9CQUFpQjtBQUMvQixZQUFNLGtCQUFpQjtBQUVqQixZQUFBLFlBQVksS0FBSyxRQUFRLGVBQWU7QUFDOUMsVUFBSSxXQUFXO0FBQ1IsYUFBQSxnQkFBZ0IsaUJBQWlCLFVBQVUsUUFBUTtBQUFBLE1BQUE7QUFFMUQsVUFBSSxLQUFLLGNBQWM7QUFDaEIsYUFBQSxVQUFVLFFBQVEsS0FBSyxZQUFZO0FBQUEsTUFBQTtBQUFBLElBQzFDO0FBQUEsSUFHaUIsYUFBYSxtQkFBdUM7QUFDckUsWUFBTSxhQUFhLGlCQUFpQjtBQUVoQyxVQUFBLENBQUMsS0FBSyxjQUFjO0FBQ3RCLGFBQUssZUFBZSxLQUFLLFdBQVksY0FBYyw4QkFBOEI7QUFDNUUsYUFBQSxVQUFVLFFBQVEsS0FBSyxZQUFZO0FBQUEsTUFBQTtBQUVyQyxXQUFBLFVBQVUsUUFBUSxJQUFJO0FBQUEsSUFBQTtBQUFBLElBR3JCLHdCQUF3QixPQUFnQztBQUN6RCxXQUFBLGdCQUNILGlCQUNBLENBQUMsTUFBTSxrQkFBa0IsTUFBTSxtQkFBbUIsTUFBTSxDQUFDO0FBQUEsSUFBQTtBQUFBLElBSTFDLFNBQU07QUFDaEIsYUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsSUFBQTtBQUFBLEtBeENvQjs7QUFBNUIsd0JBQUEsQ0FBQSxTQUFTLEVBQUUsU0FBUyxLQUFNLENBQUEsQ0FBQztBQUFpQixpQkFBQSxJQUFBLE1BQUEsbUJBQUEsRUFBQSxNQUFBLFlBQUEsTUFBQSxTQUFBLFFBQUEsT0FBQSxTQUFBLE9BQUEsUUFBQSxFQUFBLEtBQUEsQ0FBQSxRQUFBLFdBQUEsS0FBQSxLQUFBLENBQUEsUUFBQSxJQUFBLE9BQUEsS0FBQSxDQUFBLEtBQUEsVUFBQTtBQUFBLFVBQUEsUUFBc0M7QUFBQSxTQUFBLFVBQUEsYUFBQSxxQkFBQSx3QkFBQTtBQUpyRixpQkFxREMsTUFBQSxtQkFBQSxFQUFBLE9BQUEsV0FBQSxHQUFBLGtCQUFBLEVBQUEsTUFBQSxTQUFBLE1BQUEsV0FBQSxNQUFBLFVBQUEsVUFBQSxHQUFBLE1BQUEsdUJBQUE7OztRQXBEd0IsR0FBTSxTQUFtQixPQUQ1QyxrQkFBbUIsWUFBQSx1QkFBQSxHQUFDOzs7In0=
333
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"sticky-bar.js","sources":["../../../../src/elements/container/sticky-bar/sticky-bar.ts"],"sourcesContent":["import { IntersectionController } from '@lit-labs/observers/intersection-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  LitElement,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { hostAttributes } from '../../core/decorators.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport { SbbUpdateSchedulerMixin } from '../../core/mixins.js';\n\nimport style from './sticky-bar.scss?lit&inline';\n\ntype StickyState = 'sticking' | 'sticky' | 'unsticking' | 'unsticky';\n\n/**\n * A container that sticks to the bottom of the page if slotted into `sbb-container`.\n *\n * @slot - Use the unnamed slot to add content to the sticky bar.\n * @event {CustomEvent<void>} willStick - Emits when the animation from normal content flow to `position: sticky` starts. Can be canceled.\n * @event {CustomEvent<void>} didStick - Emits when the animation from normal content flow to `position: sticky` ends.\n * @event {CustomEvent<void>} willUnstick - Emits when the animation from `position: sticky` to normal content flow starts. Can be canceled.\n * @event {CustomEvent<void>} didUnstick - Emits when the animation from `position: sticky` to normal content flow ends.\n * @cssprop [--sbb-sticky-bar-padding-block=var(--sbb-spacing-responsive-xs)] - Block padding of the sticky bar.\n * @cssprop [--sbb-sticky-bar-bottom-overlapping-height=0px] - Define an additional area where\n * the sticky bar overlaps the following content on the bottom.\n * This area becomes visible when the sticky bar transitions from sticky to the normal document flow.\n * @cssprop [--sbb-sticky-bar-z-index] - To specify a custom stack order,\n * the `z-index` can be overridden by defining this CSS variable.\n */\nexport\n@customElement('sbb-sticky-bar')\n@hostAttributes({\n  slot: 'sticky-bar',\n})\nclass SbbStickyBarElement extends SbbUpdateSchedulerMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n\n  public static readonly events = {\n    willStick: 'willStick',\n    didStick: 'didStick',\n    willUnstick: 'willUnstick',\n    didUnstick: 'didUnstick',\n  } as const;\n\n  /** Color of the container, like transparent, white etc. */\n  @property({ reflect: true }) public accessor color: 'white' | 'milk' | null = null;\n\n  /** The state of the component. */\n  private set _state(state: StickyState) {\n    this.setAttribute('data-state', state);\n  }\n  private get _state(): StickyState {\n    return this.getAttribute('data-state') as StickyState;\n  }\n\n  private _willStick: EventEmitter = new EventEmitter(this, SbbStickyBarElement.events.willStick);\n  private _didStick: EventEmitter = new EventEmitter(this, SbbStickyBarElement.events.didStick);\n  private _willUnstick: EventEmitter = new EventEmitter(\n    this,\n    SbbStickyBarElement.events.willUnstick,\n  );\n  private _didUnstick: EventEmitter = new EventEmitter(this, SbbStickyBarElement.events.didUnstick);\n\n  private _intersector?: HTMLSpanElement;\n  private _observer = new IntersectionController(this, {\n    // Although `this` is observed, we have to postpone observing\n    // into firstUpdated() to achieve a correct initial state.\n    target: null,\n    callback: (entries) => this._detectStickyState(entries[0]),\n  });\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this._state = 'sticky';\n\n    // Sticky bar needs to be hidden until first observer callback\n    this.startUpdate();\n\n    const container = this.closest('sbb-container');\n    if (container) {\n      this.toggleAttribute('data-expanded', container.expanded);\n    }\n    if (this._intersector) {\n      this._observer.observe(this._intersector);\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n\n    this.toggleAttribute('data-initialized', false);\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    if (!this._intersector) {\n      this._intersector = this.shadowRoot!.querySelector('.sbb-sticky-bar__intersector')!;\n      this._observer.observe(this._intersector);\n    }\n    this._observer.observe(this);\n  }\n\n  private _detectStickyState(entry: IntersectionObserverEntry): void {\n    this.toggleAttribute('data-initialized', true);\n\n    const isSticky = !entry.isIntersecting && entry.boundingClientRect.top > 0;\n\n    // To optimize the visual perception of the sticky bar, we have certain cases (e.g. on page load)\n    // where we want the sticky bar to slide in from the bottom.\n    // To decide whether to slide in from the bottom up,\n    // we check how far away the sticky bar is from the intersector element. When scrolling fast, the\n    // difference can vary slightly. To account for this we add a height tolerance.\n    // This value was found by trial and error.\n    const intersectorRect = this._intersector?.getBoundingClientRect();\n    const stickyBarRect = this.shadowRoot!.querySelector(\n      '.sbb-sticky-bar__wrapper',\n    )!.getBoundingClientRect();\n    const HEIGHT_TOLERANCE = 30;\n\n    this.toggleAttribute(\n      'data-slide-vertically',\n      isSticky &&\n        this._intersector &&\n        Math.abs(intersectorRect!.bottom - stickyBarRect.bottom) > HEIGHT_TOLERANCE,\n    );\n\n    // Toggling data-sticking has to be after data-slide-vertically (prevents background color transition)\n    this.toggleAttribute('data-sticking', isSticky);\n\n    // Sticky bar needs to be hidden until first observer callback\n    this.completeUpdate();\n  }\n\n  /** Animates from normal content flow position to `position: sticky`. */\n  public stick(): void {\n    if (this._state !== 'unsticky' || !this._willStick.emit()) {\n      return;\n    }\n\n    this._state = 'sticking';\n    if (!this.hasAttribute('data-sticking')) {\n      this._stickyCallback();\n    }\n  }\n\n  /** Animates `position: sticky` to normal content flow position. */\n  public unstick(): void {\n    if (this._state !== 'sticky' || !this._willUnstick.emit()) {\n      return;\n    }\n\n    this._state = 'unsticking';\n\n    if (!this.hasAttribute('data-sticking')) {\n      this._unstickyCallback();\n    }\n  }\n\n  private _stickyCallback(): void {\n    this._state = 'sticky';\n    this._didStick.emit();\n  }\n\n  private _unstickyCallback(): void {\n    this._didUnstick.emit();\n    this._state = 'unsticky';\n  }\n\n  private _onAnimationEnd(event: AnimationEvent): void {\n    if (\n      (this._state === 'sticking' || this._state === 'sticky') &&\n      event.animationName === 'slide-in'\n    ) {\n      this._stickyCallback();\n    } else if (this._state === 'unsticking' && event.animationName === 'slide-out') {\n      this._unstickyCallback();\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-sticky-bar__wrapper\" @animationend=${this._onAnimationEnd}>\n        <div class=\"sbb-sticky-bar\">\n          <slot></slot>\n        </div>\n      </div>\n      <div class=\"sbb-sticky-bar__intersector\"></div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-sticky-bar': SbbStickyBarElement;\n  }\n}\n"],"names":["SbbStickyBarElement","_a"],"mappings":"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"}