@sbb-esta/lyne-elements 1.0.0 → 1.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (234) hide show
  1. package/accordion/accordion.d.ts +1 -1
  2. package/accordion/accordion.d.ts.map +1 -1
  3. package/alert/alert/alert.d.ts +1 -1
  4. package/alert/alert/alert.d.ts.map +1 -1
  5. package/button/common/button-common.d.ts.map +1 -1
  6. package/button/mini-button.js +5 -5
  7. package/calendar/calendar.d.ts +3 -1
  8. package/calendar/calendar.d.ts.map +1 -1
  9. package/calendar.js +62 -52
  10. package/card/common/card-action-common.d.ts.map +1 -1
  11. package/checkbox/common/checkbox-common.d.ts.map +1 -1
  12. package/clock/clock.d.ts +19 -13
  13. package/clock/clock.d.ts.map +1 -1
  14. package/clock.js +93 -87
  15. package/core/decorators/host-attributes.d.ts.map +1 -1
  16. package/core/eventing/throttle.d.ts.map +1 -1
  17. package/core/i18n/i18n.d.ts +1 -3
  18. package/core/i18n/i18n.d.ts.map +1 -1
  19. package/core/i18n.js +91 -127
  20. package/core/mixins/disabled-mixin.d.ts.map +1 -1
  21. package/core/mixins/form-associated-checkbox-mixin.d.ts.map +1 -1
  22. package/core/mixins/form-associated-mixin.d.ts.map +1 -1
  23. package/core/mixins/hydration-mixin.d.ts +2 -8
  24. package/core/mixins/hydration-mixin.d.ts.map +1 -1
  25. package/core/mixins/named-slot-list-mixin.d.ts.map +1 -1
  26. package/core/mixins/negative-mixin.d.ts.map +1 -1
  27. package/core/mixins/panel-mixin.d.ts.map +1 -1
  28. package/core/mixins/required-mixin.d.ts.map +1 -1
  29. package/core/mixins/update-scheduler-mixin.d.ts.map +1 -1
  30. package/core/mixins.js +133 -148
  31. package/core/observers/intersection-observer.d.ts +1 -1
  32. package/core/styles/_index.scss +1 -0
  33. package/core/styles/mixins/buttons.scss +1 -1
  34. package/core/styles/mixins/table.scss +148 -0
  35. package/core/styles/standard-theme.scss +1 -0
  36. package/core/styles/table.scss +56 -0
  37. package/core/testing/private.d.ts +0 -1
  38. package/core/testing/private.d.ts.map +1 -1
  39. package/core/testing/wait-for-render.d.ts +1 -1
  40. package/core/testing/wait-for-render.d.ts.map +1 -1
  41. package/core/testing.js +40 -37
  42. package/custom-elements.json +498 -997
  43. package/datepicker/datepicker-next-day.js +5 -5
  44. package/datepicker/datepicker-previous-day.js +1 -1
  45. package/datepicker/datepicker-toggle.js +7 -7
  46. package/development/accordion/accordion.d.ts +1 -1
  47. package/development/accordion/accordion.d.ts.map +1 -1
  48. package/development/accordion.js +7 -1
  49. package/development/action-group.js +7 -1
  50. package/development/alert/alert/alert.d.ts +1 -1
  51. package/development/alert/alert/alert.d.ts.map +1 -1
  52. package/development/alert/alert-group.js +7 -1
  53. package/development/alert/alert.js +7 -1
  54. package/development/autocomplete.js +7 -1
  55. package/development/breadcrumb/breadcrumb-group.js +7 -1
  56. package/development/breadcrumb/breadcrumb.js +7 -1
  57. package/development/button/common/button-common.d.ts.map +1 -1
  58. package/development/button/common.js +7 -1
  59. package/development/button/mini-button.js +8 -2
  60. package/development/calendar/calendar.d.ts +3 -1
  61. package/development/calendar/calendar.d.ts.map +1 -1
  62. package/development/calendar.js +18 -2
  63. package/development/card/card-badge.js +7 -1
  64. package/development/card/card.js +7 -1
  65. package/development/card/common/card-action-common.d.ts.map +1 -1
  66. package/development/card/common.js +7 -1
  67. package/development/checkbox/checkbox-group.js +7 -1
  68. package/development/checkbox/checkbox.js +7 -1
  69. package/development/checkbox/common/checkbox-common.d.ts.map +1 -1
  70. package/development/checkbox/common.js +7 -1
  71. package/development/chip.js +7 -1
  72. package/development/clock/clock.d.ts +19 -13
  73. package/development/clock/clock.d.ts.map +1 -1
  74. package/development/clock.js +103 -94
  75. package/development/container/container.js +7 -1
  76. package/development/container/sticky-bar.js +7 -1
  77. package/development/core/decorators/host-attributes.d.ts.map +1 -1
  78. package/development/core/eventing/throttle.d.ts.map +1 -1
  79. package/development/core/i18n/i18n.d.ts +1 -3
  80. package/development/core/i18n/i18n.d.ts.map +1 -1
  81. package/development/core/i18n.js +5 -43
  82. package/development/core/mixins/disabled-mixin.d.ts.map +1 -1
  83. package/development/core/mixins/form-associated-checkbox-mixin.d.ts.map +1 -1
  84. package/development/core/mixins/form-associated-mixin.d.ts.map +1 -1
  85. package/development/core/mixins/hydration-mixin.d.ts +2 -8
  86. package/development/core/mixins/hydration-mixin.d.ts.map +1 -1
  87. package/development/core/mixins/named-slot-list-mixin.d.ts.map +1 -1
  88. package/development/core/mixins/negative-mixin.d.ts.map +1 -1
  89. package/development/core/mixins/panel-mixin.d.ts.map +1 -1
  90. package/development/core/mixins/required-mixin.d.ts.map +1 -1
  91. package/development/core/mixins/update-scheduler-mixin.d.ts.map +1 -1
  92. package/development/core/mixins.js +39 -50
  93. package/development/core/observers/intersection-observer.d.ts +1 -1
  94. package/development/core/testing/private.d.ts +0 -1
  95. package/development/core/testing/private.d.ts.map +1 -1
  96. package/development/core/testing/wait-for-render.d.ts +1 -1
  97. package/development/core/testing/wait-for-render.d.ts.map +1 -1
  98. package/development/core/testing.js +6 -2
  99. package/development/datepicker/datepicker-next-day.js +8 -2
  100. package/development/datepicker/datepicker-previous-day.js +8 -2
  101. package/development/datepicker/datepicker-toggle.js +7 -2
  102. package/development/datepicker/datepicker.js +7 -1
  103. package/development/dialog/dialog-actions.js +7 -1
  104. package/development/dialog/dialog-content.js +7 -1
  105. package/development/dialog/dialog-title.js +7 -1
  106. package/development/dialog/dialog.js +7 -1
  107. package/development/divider.js +7 -1
  108. package/development/expansion-panel/expansion-panel-content.js +7 -1
  109. package/development/expansion-panel/expansion-panel-header.js +7 -1
  110. package/development/expansion-panel/expansion-panel.js +7 -1
  111. package/development/file-selector.js +7 -1
  112. package/development/footer.js +7 -1
  113. package/development/form-error.js +7 -1
  114. package/development/form-field/form-field-clear.js +8 -2
  115. package/development/form-field/form-field.js +7 -1
  116. package/development/header/common/header-action-common.d.ts.map +1 -1
  117. package/development/header/common.js +7 -1
  118. package/development/header/header.js +7 -1
  119. package/development/icon/icon-name-mixin.d.ts.map +1 -1
  120. package/development/icon/icon-request.d.ts.map +1 -1
  121. package/development/icon.js +14 -13
  122. package/development/image.js +7 -1
  123. package/development/journey-header.js +7 -1
  124. package/development/lead-container.js +7 -1
  125. package/development/link/common/block-link-common.d.ts.map +1 -1
  126. package/development/link/common/inline-link-common.d.ts.map +1 -1
  127. package/development/link/common/link-common.d.ts.map +1 -1
  128. package/development/link/common.js +19 -1
  129. package/development/link-list.js +7 -1
  130. package/development/loading-indicator.js +7 -1
  131. package/development/logo.js +7 -1
  132. package/development/map-container.js +7 -1
  133. package/development/menu/common/menu-action-common.d.ts.map +1 -1
  134. package/development/menu/common.js +7 -1
  135. package/development/menu/menu.js +7 -1
  136. package/development/message.js +7 -1
  137. package/development/navigation/common/navigation-action-common.d.ts.map +1 -1
  138. package/development/navigation/common.js +7 -1
  139. package/development/navigation/navigation-list.js +7 -1
  140. package/development/navigation/navigation-marker.js +7 -1
  141. package/development/navigation/navigation-section.js +7 -1
  142. package/development/navigation/navigation.js +7 -1
  143. package/development/notification.js +8 -1
  144. package/development/option/optgroup/optgroup.d.ts +2 -0
  145. package/development/option/optgroup/optgroup.d.ts.map +1 -1
  146. package/development/option/optgroup.js +21 -4
  147. package/development/option/option/option.d.ts +6 -5
  148. package/development/option/option/option.d.ts.map +1 -1
  149. package/development/option/option.js +53 -29
  150. package/development/overlay.js +7 -1
  151. package/development/popover/popover-trigger.js +8 -2
  152. package/development/popover/popover.js +7 -1
  153. package/development/radio-button/common/radio-button-common.d.ts.map +1 -1
  154. package/development/radio-button/common.js +7 -1
  155. package/development/radio-button/radio-button-group.js +7 -1
  156. package/development/radio-button/radio-button.js +7 -1
  157. package/development/screen-reader-only.js +7 -1
  158. package/development/select.js +7 -1
  159. package/development/selection-expansion-panel.js +7 -1
  160. package/development/signet.js +7 -1
  161. package/development/skiplink-list.js +7 -1
  162. package/development/slider.js +7 -1
  163. package/development/status.js +7 -1
  164. package/development/stepper/step-label.js +7 -1
  165. package/development/stepper/step.js +7 -1
  166. package/development/stepper/stepper.js +7 -1
  167. package/development/table/table-wrapper/table-wrapper.d.ts +24 -0
  168. package/development/table/table-wrapper/table-wrapper.d.ts.map +1 -0
  169. package/development/table/table-wrapper.d.ts +2 -0
  170. package/development/table/table-wrapper.d.ts.map +1 -0
  171. package/development/table/table-wrapper.js +130 -0
  172. package/development/table.d.ts +2 -0
  173. package/development/table.d.ts.map +1 -0
  174. package/development/table.js +2 -0
  175. package/development/tabs/tab-group/tab-group.d.ts +4 -7
  176. package/development/tabs/tab-group/tab-group.d.ts.map +1 -1
  177. package/development/tabs/tab-group.js +69 -73
  178. package/development/tabs/tab-label.js +7 -1
  179. package/development/tabs/tab.js +7 -1
  180. package/development/tag/tag-group.js +7 -1
  181. package/development/tag/tag.js +7 -1
  182. package/development/teaser.js +7 -1
  183. package/development/time-input.js +7 -1
  184. package/development/timetable-occupancy-icon.js +7 -1
  185. package/development/timetable-occupancy.js +7 -1
  186. package/development/title.js +13 -1
  187. package/development/toast.js +7 -1
  188. package/development/toggle/toggle-option.js +7 -1
  189. package/development/toggle/toggle.js +7 -1
  190. package/development/toggle-check/toggle-check.d.ts +2 -2
  191. package/development/toggle-check/toggle-check.d.ts.map +1 -1
  192. package/development/toggle-check.js +7 -1
  193. package/development/train/train-blocked-passage.js +7 -1
  194. package/development/train/train-formation.js +7 -1
  195. package/development/train/train-wagon.js +7 -1
  196. package/development/train/train.js +7 -1
  197. package/development/visual-checkbox.js +9 -3
  198. package/form-field/form-field-clear.js +1 -1
  199. package/header/common/header-action-common.d.ts.map +1 -1
  200. package/icon/icon-name-mixin.d.ts.map +1 -1
  201. package/icon/icon-request.d.ts.map +1 -1
  202. package/icon.js +86 -86
  203. package/index.d.ts +2 -0
  204. package/index.js +2 -0
  205. package/link/common/block-link-common.d.ts.map +1 -1
  206. package/link/common/inline-link-common.d.ts.map +1 -1
  207. package/link/common/link-common.d.ts.map +1 -1
  208. package/menu/common/menu-action-common.d.ts.map +1 -1
  209. package/navigation/common/navigation-action-common.d.ts.map +1 -1
  210. package/notification.js +1 -1
  211. package/option/optgroup/optgroup.d.ts +2 -0
  212. package/option/optgroup/optgroup.d.ts.map +1 -1
  213. package/option/optgroup.js +24 -21
  214. package/option/option/option.d.ts +6 -5
  215. package/option/option/option.d.ts.map +1 -1
  216. package/option/option.js +72 -69
  217. package/package.json +11 -1
  218. package/popover/popover-trigger.js +1 -1
  219. package/radio-button/common/radio-button-common.d.ts.map +1 -1
  220. package/standard-theme.css +196 -0
  221. package/table/table-wrapper/table-wrapper.d.ts +24 -0
  222. package/table/table-wrapper/table-wrapper.d.ts.map +1 -0
  223. package/table/table-wrapper.d.ts +2 -0
  224. package/table/table-wrapper.d.ts.map +1 -0
  225. package/table/table-wrapper.js +39 -0
  226. package/table.d.ts +2 -0
  227. package/table.d.ts.map +1 -0
  228. package/table.js +1 -0
  229. package/tabs/tab-group/tab-group.d.ts +4 -7
  230. package/tabs/tab-group/tab-group.d.ts.map +1 -1
  231. package/tabs/tab-group.js +80 -81
  232. package/toggle-check/toggle-check.d.ts +2 -2
  233. package/toggle-check/toggle-check.d.ts.map +1 -1
  234. package/visual-checkbox.js +4 -4
@@ -1,4 +1,4 @@
1
- import { css, LitElement, html } from "lit";
1
+ import { css, LitElement, isServer, html } from "lit";
2
2
  import { property, customElement } from "lit/decorators.js";
3
3
  import { ref } from "lit/directives/ref.js";
4
4
  const clockFaceSVG = '<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';
@@ -19,6 +19,12 @@ const style = css`/**
19
19
  * }
20
20
  */
21
21
  /** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
22
+ /*
23
+ * SBB table mixin
24
+ * Notes:
25
+ * We cannot use \`border-collapse\` because it is not compatible with the \`border-radius\` property.
26
+ * Therefore, we have to build the grid avoiding double borders.
27
+ */
22
28
  *,
23
29
  ::before,
24
30
  ::after {
@@ -163,64 +169,75 @@ let SbbClockElement = class extends LitElement {
163
169
  this.now = null;
164
170
  this._moveHoursHandFn = () => this._moveHoursHand();
165
171
  this._moveMinutesHandFn = () => this._moveMinutesHand();
172
+ this._handlePageVisibilityChange = async () => {
173
+ if (document.visibilityState === "hidden") {
174
+ await this._stopClock();
175
+ } else if (!this.now) {
176
+ await this._startClock();
177
+ }
178
+ };
166
179
  }
167
- willUpdate(changedProperties) {
180
+ async willUpdate(changedProperties) {
168
181
  super.willUpdate(changedProperties);
169
- if (changedProperties.has("now")) {
170
- if (this.now) {
171
- this._removeSecondsAnimationStyles();
172
- this._removeHoursAnimationStyles();
173
- this._stopClock();
174
- } else {
175
- this._startClock();
176
- }
182
+ if (!isServer && changedProperties.has("now")) {
183
+ await this._startOrConfigureClock();
184
+ }
185
+ }
186
+ async firstUpdated(changedProperties) {
187
+ super.firstUpdated(changedProperties);
188
+ if (!isServer) {
189
+ document.addEventListener("visibilitychange", this._handlePageVisibilityChange, false);
190
+ await this._startOrConfigureClock();
177
191
  }
178
192
  }
179
- async _handlePageVisibilityChange() {
180
- if (document.visibilityState === "hidden") {
193
+ disconnectedCallback() {
194
+ super.disconnectedCallback();
195
+ this._removeEventListeners();
196
+ }
197
+ async _startOrConfigureClock() {
198
+ if (this.now) {
181
199
  await this._stopClock();
182
- } else if (!this.now) {
200
+ this._resetSecondsHandAnimation();
201
+ this._setHandsStartingPosition();
202
+ } else {
183
203
  await this._startClock();
184
204
  }
185
205
  }
186
- _addEventListeners() {
187
- document.addEventListener("visibilitychange", () => this._handlePageVisibilityChange(), false);
188
- }
189
- _removeEventListeners() {
206
+ /** Starts the clock by defining the hands starting position then starting the animations. */
207
+ async _startClock() {
190
208
  var _a, _b;
191
- document.removeEventListener(
192
- "visibilitychange",
193
- () => this._handlePageVisibilityChange(),
194
- false
209
+ (_a = this._clockHandHours) == null ? void 0 : _a.addEventListener(
210
+ "animationend",
211
+ this._moveHoursHandFn,
212
+ ADD_EVENT_LISTENER_OPTIONS
213
+ );
214
+ (_b = this._clockHandSeconds) == null ? void 0 : _b.addEventListener(
215
+ "animationend",
216
+ this._moveMinutesHandFn,
217
+ ADD_EVENT_LISTENER_OPTIONS
218
+ );
219
+ await new Promise(
220
+ () => setTimeout(() => {
221
+ var _a2;
222
+ this._setHandsStartingPosition();
223
+ (_a2 = this.style) == null ? void 0 : _a2.setProperty("--sbb-clock-animation-play-state", "running");
224
+ }, INITIAL_TIMEOUT_DURATION)
195
225
  );
226
+ }
227
+ /** Stops the clock by removing all the animations. */
228
+ async _stopClock() {
229
+ var _a, _b, _c, _d;
230
+ clearInterval(this._handMovement);
231
+ this._removeSecondsAnimationStyles();
232
+ this._removeHoursAnimationStyles();
196
233
  (_a = this._clockHandHours) == null ? void 0 : _a.removeEventListener("animationend", this._moveHoursHandFn);
197
234
  (_b = this._clockHandSeconds) == null ? void 0 : _b.removeEventListener("animationend", this._moveMinutesHandFn);
198
- clearInterval(this._handMovement);
199
- }
200
- _removeHoursAnimationStyles() {
201
- var _a;
202
- (_a = this._clockHandHours) == null ? void 0 : _a.classList.remove("sbb-clock__hand-hours--initial-hour");
203
- this.style.removeProperty("--sbb-clock-hours-animation-start-angle");
204
- this.style.removeProperty("--sbb-clock-hours-animation-duration");
205
- }
206
- _removeSecondsAnimationStyles() {
207
- var _a, _b;
208
- (_a = this._clockHandSeconds) == null ? void 0 : _a.classList.remove("sbb-clock__hand-seconds--initial-minute");
209
- (_b = this._clockHandMinutes) == null ? void 0 : _b.classList.remove("sbb-clock__hand-minutes--no-transition");
210
- this.style.removeProperty("--sbb-clock-seconds-animation-start-angle");
211
- this.style.removeProperty("--sbb-clock-seconds-animation-duration");
212
- }
213
- /** Given the current date, calculates the hh/mm/ss values and the hh/mm/ss left to the next midnight. */
214
- _assignCurrentTime() {
215
- const date = this.now ? null : /* @__PURE__ */ new Date();
216
- const [hours, minutes, seconds] = date ? [date.getHours(), date.getMinutes(), date.getSeconds()] : this.now.split(":").map((p) => +p);
217
- this._hours = hours % 12;
218
- this._minutes = minutes;
219
- this._seconds = seconds;
235
+ (_c = this._clockHandMinutes) == null ? void 0 : _c.classList.add("sbb-clock__hand-minutes--no-transition");
236
+ (_d = this.style) == null ? void 0 : _d.setProperty("--sbb-clock-animation-play-state", "paused");
220
237
  }
221
238
  /** Set the starting position for the three hands on the clock face. */
222
239
  _setHandsStartingPosition() {
223
- var _a, _b;
240
+ var _a, _b, _c, _d, _e, _f;
224
241
  this._assignCurrentTime();
225
242
  const remainingSeconds = TOTAL_SECONDS_ON_CLOCK_FACE - this._seconds;
226
243
  const remainingMinutes = TOTAL_MINUTES_ON_CLOCK_FACE - this._minutes;
@@ -238,22 +255,29 @@ let SbbClockElement = class extends LitElement {
238
255
  if (remainingHours > 0) {
239
256
  hoursAnimationDuration += (remainingHours - hasRemainingMinutesOrSeconds) * SECONDS_IN_AN_HOUR;
240
257
  }
241
- this.style.setProperty(
258
+ (_a = this.style) == null ? void 0 : _a.setProperty(
242
259
  "--sbb-clock-hours-animation-start-angle",
243
260
  `${Math.ceil(this._hours * HOURS_ANGLE + this._minutes / 2)}deg`
244
261
  );
245
- this.style.setProperty("--sbb-clock-hours-animation-duration", `${hoursAnimationDuration}s`);
246
- this.style.setProperty(
262
+ (_b = this.style) == null ? void 0 : _b.setProperty("--sbb-clock-hours-animation-duration", `${hoursAnimationDuration}s`);
263
+ (_c = this.style) == null ? void 0 : _c.setProperty(
247
264
  "--sbb-clock-seconds-animation-start-angle",
248
265
  `${Math.ceil(this._seconds * SBB_SECONDS_ANGLE)}deg`
249
266
  );
250
- this.style.setProperty("--sbb-clock-seconds-animation-duration", `${remainingSeconds}s`);
267
+ (_d = this.style) == null ? void 0 : _d.setProperty("--sbb-clock-seconds-animation-duration", `${remainingSeconds}s`);
251
268
  this._setMinutesHand();
252
- (_a = this._clockHandSeconds) == null ? void 0 : _a.classList.add("sbb-clock__hand-seconds--initial-minute");
253
- (_b = this._clockHandHours) == null ? void 0 : _b.classList.add("sbb-clock__hand-hours--initial-hour");
254
- this.style.setProperty("--sbb-clock-animation-play-state", "running");
269
+ (_e = this._clockHandSeconds) == null ? void 0 : _e.classList.add("sbb-clock__hand-seconds--initial-minute");
270
+ (_f = this._clockHandHours) == null ? void 0 : _f.classList.add("sbb-clock__hand-hours--initial-hour");
255
271
  this.toggleAttribute("data-initialized", true);
256
272
  }
273
+ /** Given the current date, calculates the hh/mm/ss values and the hh/mm/ss left to the next midnight. */
274
+ _assignCurrentTime() {
275
+ const date = this.now ? null : /* @__PURE__ */ new Date();
276
+ const [hours, minutes, seconds] = date ? [date.getHours(), date.getMinutes(), date.getSeconds()] : this.now.split(":").map((p) => +p);
277
+ this._hours = hours % 12;
278
+ this._minutes = minutes;
279
+ this._seconds = seconds;
280
+ }
257
281
  /** Set the starting position for the minutes hand. */
258
282
  _setMinutesHand() {
259
283
  var _a;
@@ -287,53 +311,38 @@ let SbbClockElement = class extends LitElement {
287
311
  this._minutes++;
288
312
  this._setMinutesHand();
289
313
  }
290
- /** Stops the clock by removing all the animations. */
291
- async _stopClock() {
292
- var _a, _b, _c, _d, _e;
293
- clearInterval(this._handMovement);
294
- if (this.now) {
295
- this._setHandsStartingPosition();
296
- await new Promise((resolve) => setTimeout(resolve));
297
- (_a = this._clockHandSeconds) == null ? void 0 : _a.classList.add("sbb-clock__hand-seconds--initial-minute");
298
- (_b = this._clockHandHours) == null ? void 0 : _b.classList.add("sbb-clock__hand-hours--initial-hour");
299
- } else {
300
- this._removeSecondsAnimationStyles();
301
- this._removeHoursAnimationStyles();
314
+ /**
315
+ * Removing animation by overriding with empty string,
316
+ * then triggering a reflow and re add original animation by removing override.
317
+ * @private
318
+ */
319
+ _resetSecondsHandAnimation() {
320
+ if (!this._clockHandSeconds) {
321
+ return;
302
322
  }
303
- (_c = this._clockHandHours) == null ? void 0 : _c.removeEventListener("animationend", this._moveHoursHandFn);
304
- (_d = this._clockHandSeconds) == null ? void 0 : _d.removeEventListener("animationend", this._moveMinutesHandFn);
305
- (_e = this._clockHandMinutes) == null ? void 0 : _e.classList.add("sbb-clock__hand-minutes--no-transition");
306
- this.style.setProperty("--sbb-clock-animation-play-state", "paused");
323
+ this._clockHandSeconds.style.animation = "";
324
+ this._clockHandSeconds.offsetHeight;
325
+ this._clockHandSeconds.style.removeProperty("animation");
307
326
  }
308
- /** Starts the clock by defining the hands starting position then starting the animations. */
309
- async _startClock() {
327
+ _removeEventListeners() {
310
328
  var _a, _b;
311
- (_a = this._clockHandHours) == null ? void 0 : _a.addEventListener(
312
- "animationend",
313
- this._moveHoursHandFn,
314
- ADD_EVENT_LISTENER_OPTIONS
315
- );
316
- (_b = this._clockHandSeconds) == null ? void 0 : _b.addEventListener(
317
- "animationend",
318
- this._moveMinutesHandFn,
319
- ADD_EVENT_LISTENER_OPTIONS
320
- );
321
- await new Promise(
322
- () => setTimeout(() => this._setHandsStartingPosition(), INITIAL_TIMEOUT_DURATION)
323
- );
329
+ document == null ? void 0 : document.removeEventListener("visibilitychange", this._handlePageVisibilityChange);
330
+ (_a = this._clockHandHours) == null ? void 0 : _a.removeEventListener("animationend", this._moveHoursHandFn);
331
+ (_b = this._clockHandSeconds) == null ? void 0 : _b.removeEventListener("animationend", this._moveMinutesHandFn);
332
+ clearInterval(this._handMovement);
324
333
  }
325
- async firstUpdated(changedProperties) {
326
- super.firstUpdated(changedProperties);
327
- this._addEventListeners();
328
- if (this.now) {
329
- await this._stopClock();
330
- } else {
331
- await this._startClock();
332
- }
334
+ _removeHoursAnimationStyles() {
335
+ var _a;
336
+ (_a = this._clockHandHours) == null ? void 0 : _a.classList.remove("sbb-clock__hand-hours--initial-hour");
337
+ this.style.removeProperty("--sbb-clock-hours-animation-start-angle");
338
+ this.style.removeProperty("--sbb-clock-hours-animation-duration");
333
339
  }
334
- disconnectedCallback() {
335
- super.disconnectedCallback();
336
- this._removeEventListeners();
340
+ _removeSecondsAnimationStyles() {
341
+ var _a, _b;
342
+ (_a = this._clockHandSeconds) == null ? void 0 : _a.classList.remove("sbb-clock__hand-seconds--initial-minute");
343
+ (_b = this._clockHandMinutes) == null ? void 0 : _b.classList.remove("sbb-clock__hand-minutes--no-transition");
344
+ this.style.removeProperty("--sbb-clock-seconds-animation-start-angle");
345
+ this.style.removeProperty("--sbb-clock-seconds-animation-duration");
337
346
  }
338
347
  render() {
339
348
  return html`
@@ -374,4 +383,4 @@ SbbClockElement = __decorateClass([
374
383
  export {
375
384
  SbbClockElement
376
385
  };
377
- //# 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, 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 */\n@customElement('sbb-clock')\nexport class 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 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  /** 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  /** Move the minutes hand every minute. */\n  private _handMovement?: ReturnType<typeof setInterval>;\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('now')) {\n      if (this.now) {\n        this._removeSecondsAnimationStyles();\n        this._removeHoursAnimationStyles();\n        this._stopClock();\n      } else {\n        this._startClock();\n      }\n    }\n  }\n\n  private async _handlePageVisibilityChange(): 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 _addEventListeners(): void {\n    document.addEventListener('visibilitychange', () => this._handlePageVisibilityChange(), false);\n  }\n\n  private _removeEventListeners(): void {\n    document.removeEventListener(\n      'visibilitychange',\n      () => this._handlePageVisibilityChange(),\n      false,\n    );\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  /** 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 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    this.style.setProperty('--sbb-clock-animation-play-state', 'running');\n\n    this.toggleAttribute('data-initialized', true);\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  /** Stops the clock by removing all the animations. */\n  private async _stopClock(): Promise<void> {\n    clearInterval(this._handMovement);\n\n    if (this.now) {\n      this._setHandsStartingPosition();\n\n      // Wait a tick to before animation is added. Otherwise, the animation gets not completely\n      // removed which can lead to a mispositioned seconds hand.\n      await new Promise((resolve) => setTimeout(resolve));\n\n      this._clockHandSeconds?.classList.add('sbb-clock__hand-seconds--initial-minute');\n      this._clockHandHours?.classList.add('sbb-clock__hand-hours--initial-hour');\n    } else {\n      this._removeSecondsAnimationStyles();\n      this._removeHoursAnimationStyles();\n    }\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  /** 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(() =>\n      setTimeout(() => this._setHandsStartingPosition(), INITIAL_TIMEOUT_DURATION),\n    );\n  }\n\n  protected override async firstUpdated(changedProperties: PropertyValues<this>): Promise<void> {\n    super.firstUpdated(changedProperties);\n\n    this._addEventListeners();\n\n    if (this.now) {\n      await this._stopClock();\n    } else {\n      await this._startClock();\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._removeEventListeners();\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":[],"mappings":"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"}
386
+ //# 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 */\n@customElement('sbb-clock')\nexport class 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 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  /** 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  /** Move the minutes hand every minute. */\n  private _handMovement?: ReturnType<typeof setInterval>;\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(() =>\n      setTimeout(() => {\n        this._setHandsStartingPosition();\n\n        this.style?.setProperty('--sbb-clock-animation-play-state', 'running');\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    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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"}
@@ -15,6 +15,12 @@ const style = css`@charset "UTF-8";
15
15
  * }
16
16
  */
17
17
  /** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
18
+ /*
19
+ * SBB table mixin
20
+ * Notes:
21
+ * We cannot use \`border-collapse\` because it is not compatible with the \`border-radius\` property.
22
+ * Therefore, we have to build the grid avoiding double borders.
23
+ */
18
24
  *,
19
25
  ::before,
20
26
  ::after {
@@ -111,4 +117,4 @@ SbbContainerElement = __decorateClass([
111
117
  export {
112
118
  SbbContainerElement
113
119
  };
114
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFpbmVyLmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMvY29udGFpbmVyL2NvbnRhaW5lci9jb250YWluZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdHlwZSBDU1NSZXN1bHRHcm91cCxcbiAgaHRtbCxcbiAgTGl0RWxlbWVudCxcbiAgdHlwZSBQcm9wZXJ0eVZhbHVlcyxcbiAgdHlwZSBUZW1wbGF0ZVJlc3VsdCxcbn0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9jb250YWluZXIuc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBJdCBkaXNwbGF5cyBpdHMgY29udGVudCB3aXRoIHRoZSBkZWZhdWx0IHBhZ2Ugc3BhY2luZy5cbiAqXG4gKiBAc2xvdCAtIFVzZSB0aGUgdW5uYW1lZCBzbG90IHRvIGFkZCBhbnl0aGluZyB0byB0aGUgY29udGFpbmVyLlxuICogQHNsb3Qgc3RpY2t5LWJhciAtIFRoZSBzbG90IHVzZWQgYnkgdGhlIHNiYi1zdGlja3ktYmFyIGNvbXBvbmVudC5cbiAqL1xuQGN1c3RvbUVsZW1lbnQoJ3NiYi1jb250YWluZXInKVxuZXhwb3J0IGNsYXNzIFNiYkNvbnRhaW5lckVsZW1lbnQgZXh0ZW5kcyBMaXRFbGVtZW50IHtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gc3R5bGU7XG5cbiAgLyoqIFdoZXRoZXIgdGhlIGNvbnRhaW5lciBpcyBleHBhbmRlZC4gKi9cbiAgQHByb3BlcnR5KHsgdHlwZTogQm9vbGVhbiwgcmVmbGVjdDogdHJ1ZSB9KSBwdWJsaWMgZXhwYW5kZWQgPSBmYWxzZTtcblxuICAvKiogV2hldGhlciB0aGUgYmFja2dyb3VuZCBjb2xvciBpcyBzaG93biBvbiBmdWxsIGNvbnRhaW5lciB3aWR0aCBvbiBsYXJnZSBzY3JlZW5zLiAqL1xuICBAcHJvcGVydHkoeyB0eXBlOiBCb29sZWFuLCByZWZsZWN0OiB0cnVlLCBhdHRyaWJ1dGU6ICdiYWNrZ3JvdW5kLWV4cGFuZGVkJyB9KVxuICBwdWJsaWMgYmFja2dyb3VuZEV4cGFuZGVkID0gZmFsc2U7XG5cbiAgLyoqIENvbG9yIG9mIHRoZSBjb250YWluZXIsIGxpa2UgdHJhbnNwYXJlbnQsIHdoaXRlIGV0Yy4gKi9cbiAgQHByb3BlcnR5KHsgcmVmbGVjdDogdHJ1ZSB9KSBwdWJsaWMgY29sb3I6ICd0cmFuc3BhcmVudCcgfCAnd2hpdGUnIHwgJ21pbGsnID0gJ3doaXRlJztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgd2lsbFVwZGF0ZShjaGFuZ2VkUHJvcGVydGllczogUHJvcGVydHlWYWx1ZXM8dGhpcz4pOiB2b2lkIHtcbiAgICBzdXBlci53aWxsVXBkYXRlKGNoYW5nZWRQcm9wZXJ0aWVzKTtcblxuICAgIGlmIChjaGFuZ2VkUHJvcGVydGllcy5oYXMoJ2V4cGFuZGVkJykpIHtcbiAgICAgIHRoaXMucXVlcnlTZWxlY3Rvcj8uKCdzYmItc3RpY2t5LWJhcicpPy50b2dnbGVBdHRyaWJ1dGUoJ2RhdGEtZXhwYW5kZWQnLCB0aGlzLmV4cGFuZGVkKTtcbiAgICB9XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGBcbiAgICAgIDxkaXYgY2xhc3M9XCJzYmItY29udGFpbmVyXCI+XG4gICAgICAgIDxzbG90Pjwvc2xvdD5cbiAgICAgIDwvZGl2PlxuICAgICAgPHNsb3QgbmFtZT1cInN0aWNreS1iYXJcIj48L3Nsb3Q+XG4gICAgYDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLWNvbnRhaW5lcic6IFNiYkNvbnRhaW5lckVsZW1lbnQ7XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQWtCYSxJQUFBLHNCQUFOLGNBQWtDLFdBQVc7QUFBQSxFQUE3QyxjQUFBO0FBQUEsVUFBQSxHQUFBLFNBQUE7QUFJdUMsU0FBTyxXQUFXO0FBSTlELFNBQU8scUJBQXFCO0FBR0MsU0FBTyxRQUEwQztBQUFBLEVBQUE7QUFBQSxFQUUzRCxXQUFXLG1CQUErQzs7QUFDM0UsVUFBTSxXQUFXLGlCQUFpQjtBQUU5QixRQUFBLGtCQUFrQixJQUFJLFVBQVUsR0FBRztBQUNyQyx1QkFBSyxrQkFBTCw4QkFBcUIsc0JBQXJCLG1CQUF3QyxnQkFBZ0IsaUJBQWlCLEtBQUs7QUFBQSxJQUNoRjtBQUFBLEVBQ0Y7QUFBQSxFQUVtQixTQUF5QjtBQUNuQyxXQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBTVQ7QUFDRjtBQTdCYSxvQkFDWSxTQUF5QjtBQUdHLGdCQUFBO0FBQUEsRUFBbEQsU0FBUyxFQUFFLE1BQU0sU0FBUyxTQUFTLE1BQU07QUFBQSxHQUovQixvQkFJd0MsV0FBQSxZQUFBLENBQUE7QUFJNUMsZ0JBQUE7QUFBQSxFQUROLFNBQVMsRUFBRSxNQUFNLFNBQVMsU0FBUyxNQUFNLFdBQVcsdUJBQXVCO0FBQUEsR0FQakUsb0JBUUosV0FBQSxzQkFBQSxDQUFBO0FBRzZCLGdCQUFBO0FBQUEsRUFBbkMsU0FBUyxFQUFFLFNBQVMsTUFBTTtBQUFBLEdBWGhCLG9CQVd5QixXQUFBLFNBQUEsQ0FBQTtBQVh6QixzQkFBTixnQkFBQTtBQUFBLEVBRE4sY0FBYyxlQUFlO0FBQUEsR0FDakIsbUJBQUE7In0=
120
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFpbmVyLmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMvY29udGFpbmVyL2NvbnRhaW5lci9jb250YWluZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdHlwZSBDU1NSZXN1bHRHcm91cCxcbiAgaHRtbCxcbiAgTGl0RWxlbWVudCxcbiAgdHlwZSBQcm9wZXJ0eVZhbHVlcyxcbiAgdHlwZSBUZW1wbGF0ZVJlc3VsdCxcbn0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9jb250YWluZXIuc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBJdCBkaXNwbGF5cyBpdHMgY29udGVudCB3aXRoIHRoZSBkZWZhdWx0IHBhZ2Ugc3BhY2luZy5cbiAqXG4gKiBAc2xvdCAtIFVzZSB0aGUgdW5uYW1lZCBzbG90IHRvIGFkZCBhbnl0aGluZyB0byB0aGUgY29udGFpbmVyLlxuICogQHNsb3Qgc3RpY2t5LWJhciAtIFRoZSBzbG90IHVzZWQgYnkgdGhlIHNiYi1zdGlja3ktYmFyIGNvbXBvbmVudC5cbiAqL1xuQGN1c3RvbUVsZW1lbnQoJ3NiYi1jb250YWluZXInKVxuZXhwb3J0IGNsYXNzIFNiYkNvbnRhaW5lckVsZW1lbnQgZXh0ZW5kcyBMaXRFbGVtZW50IHtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gc3R5bGU7XG5cbiAgLyoqIFdoZXRoZXIgdGhlIGNvbnRhaW5lciBpcyBleHBhbmRlZC4gKi9cbiAgQHByb3BlcnR5KHsgdHlwZTogQm9vbGVhbiwgcmVmbGVjdDogdHJ1ZSB9KSBwdWJsaWMgZXhwYW5kZWQgPSBmYWxzZTtcblxuICAvKiogV2hldGhlciB0aGUgYmFja2dyb3VuZCBjb2xvciBpcyBzaG93biBvbiBmdWxsIGNvbnRhaW5lciB3aWR0aCBvbiBsYXJnZSBzY3JlZW5zLiAqL1xuICBAcHJvcGVydHkoeyB0eXBlOiBCb29sZWFuLCByZWZsZWN0OiB0cnVlLCBhdHRyaWJ1dGU6ICdiYWNrZ3JvdW5kLWV4cGFuZGVkJyB9KVxuICBwdWJsaWMgYmFja2dyb3VuZEV4cGFuZGVkID0gZmFsc2U7XG5cbiAgLyoqIENvbG9yIG9mIHRoZSBjb250YWluZXIsIGxpa2UgdHJhbnNwYXJlbnQsIHdoaXRlIGV0Yy4gKi9cbiAgQHByb3BlcnR5KHsgcmVmbGVjdDogdHJ1ZSB9KSBwdWJsaWMgY29sb3I6ICd0cmFuc3BhcmVudCcgfCAnd2hpdGUnIHwgJ21pbGsnID0gJ3doaXRlJztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgd2lsbFVwZGF0ZShjaGFuZ2VkUHJvcGVydGllczogUHJvcGVydHlWYWx1ZXM8dGhpcz4pOiB2b2lkIHtcbiAgICBzdXBlci53aWxsVXBkYXRlKGNoYW5nZWRQcm9wZXJ0aWVzKTtcblxuICAgIGlmIChjaGFuZ2VkUHJvcGVydGllcy5oYXMoJ2V4cGFuZGVkJykpIHtcbiAgICAgIHRoaXMucXVlcnlTZWxlY3Rvcj8uKCdzYmItc3RpY2t5LWJhcicpPy50b2dnbGVBdHRyaWJ1dGUoJ2RhdGEtZXhwYW5kZWQnLCB0aGlzLmV4cGFuZGVkKTtcbiAgICB9XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGBcbiAgICAgIDxkaXYgY2xhc3M9XCJzYmItY29udGFpbmVyXCI+XG4gICAgICAgIDxzbG90Pjwvc2xvdD5cbiAgICAgIDwvZGl2PlxuICAgICAgPHNsb3QgbmFtZT1cInN0aWNreS1iYXJcIj48L3Nsb3Q+XG4gICAgYDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLWNvbnRhaW5lcic6IFNiYkNvbnRhaW5lckVsZW1lbnQ7XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQWtCYSxJQUFBLHNCQUFOLGNBQWtDLFdBQVc7QUFBQSxFQUE3QyxjQUFBO0FBQUEsVUFBQSxHQUFBLFNBQUE7QUFJdUMsU0FBTyxXQUFXO0FBSTlELFNBQU8scUJBQXFCO0FBR0MsU0FBTyxRQUEwQztBQUFBLEVBQUE7QUFBQSxFQUUzRCxXQUFXLG1CQUErQzs7QUFDM0UsVUFBTSxXQUFXLGlCQUFpQjtBQUU5QixRQUFBLGtCQUFrQixJQUFJLFVBQVUsR0FBRztBQUNyQyx1QkFBSyxrQkFBTCw4QkFBcUIsc0JBQXJCLG1CQUF3QyxnQkFBZ0IsaUJBQWlCLEtBQUs7QUFBQSxJQUNoRjtBQUFBLEVBQ0Y7QUFBQSxFQUVtQixTQUF5QjtBQUNuQyxXQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBTVQ7QUFDRjtBQTdCYSxvQkFDWSxTQUF5QjtBQUdHLGdCQUFBO0FBQUEsRUFBbEQsU0FBUyxFQUFFLE1BQU0sU0FBUyxTQUFTLE1BQU07QUFBQSxHQUovQixvQkFJd0MsV0FBQSxZQUFBLENBQUE7QUFJNUMsZ0JBQUE7QUFBQSxFQUROLFNBQVMsRUFBRSxNQUFNLFNBQVMsU0FBUyxNQUFNLFdBQVcsdUJBQXVCO0FBQUEsR0FQakUsb0JBUUosV0FBQSxzQkFBQSxDQUFBO0FBRzZCLGdCQUFBO0FBQUEsRUFBbkMsU0FBUyxFQUFFLFNBQVMsTUFBTTtBQUFBLEdBWGhCLG9CQVd5QixXQUFBLFNBQUEsQ0FBQTtBQVh6QixzQkFBTixnQkFBQTtBQUFBLEVBRE4sY0FBYyxlQUFlO0FBQUEsR0FDakIsbUJBQUE7In0=
@@ -16,6 +16,12 @@ const style = css`/**
16
16
  * }
17
17
  */
18
18
  /** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
19
+ /*
20
+ * SBB table mixin
21
+ * Notes:
22
+ * We cannot use \`border-collapse\` because it is not compatible with the \`border-radius\` property.
23
+ * Therefore, we have to build the grid avoiding double borders.
24
+ */
19
25
  *,
20
26
  ::before,
21
27
  ::after {
@@ -217,4 +223,4 @@ SbbStickyBarElement = __decorateClass([
217
223
  export {
218
224
  SbbStickyBarElement
219
225
  };
220
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RpY2t5LWJhci5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2NvbnRhaW5lci9zdGlja3ktYmFyL3N0aWNreS1iYXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdHlwZSBDU1NSZXN1bHRHcm91cCxcbiAgaHRtbCxcbiAgTGl0RWxlbWVudCxcbiAgdHlwZSBQcm9wZXJ0eVZhbHVlcyxcbiAgdHlwZSBUZW1wbGF0ZVJlc3VsdCxcbn0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBob3N0QXR0cmlidXRlcyB9IGZyb20gJy4uLy4uL2NvcmUvZGVjb3JhdG9ycy5qcyc7XG5pbXBvcnQgeyBBZ25vc3RpY0ludGVyc2VjdGlvbk9ic2VydmVyIH0gZnJvbSAnLi4vLi4vY29yZS9vYnNlcnZlcnMuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9zdGlja3ktYmFyLnNjc3M/bGl0JmlubGluZSc7XG5cbi8qKlxuICogQSBjb250YWluZXIgdGhhdCBzdGlja3MgdG8gdGhlIGJvdHRvbSBvZiB0aGUgcGFnZSBpZiBzbG90dGVkIGludG8gYHNiYi1jb250YWluZXJgLlxuICpcbiAqIEBzbG90IC0gVXNlIHRoZSB1bm5hbWVkIHNsb3QgdG8gYWRkIGNvbnRlbnQgdG8gdGhlIHN0aWNreSBiYXIuXG4gKiBAY3NzcHJvcCBbLS1zYmItc3RpY2t5LWJhci1wYWRkaW5nLWJsb2NrPXZhcigtLXNiYi1zcGFjaW5nLXJlc3BvbnNpdmUteHMpXSAtIEJsb2NrIHBhZGRpbmcgb2YgdGhlIHN0aWNreSBiYXIuXG4gKiBAY3NzcHJvcCBbLS1zYmItc3RpY2t5LWJhci1ib3R0b20tb3ZlcmxhcHBpbmctaGVpZ2h0PTBweF0gLSBEZWZpbmUgYW4gYWRkaXRpb25hbCBhcmVhIHdoZXJlXG4gKiB0aGUgc3RpY2t5IGJhciBvdmVybGFwcyB0aGUgZm9sbG93aW5nIGNvbnRlbnQgb24gdGhlIGJvdHRvbS5cbiAqIFRoaXMgYXJlYSBiZWNvbWVzIHZpc2libGUgd2hlbiB0aGUgc3RpY2t5IGJhciB0cmFuc2l0aW9ucyBmcm9tIHN0aWNreSB0byB0aGUgbm9ybWFsIGRvY3VtZW50IGZsb3cuXG4gKiBAY3NzcHJvcCBbLS1zYmItc3RpY2t5LWJhci16LWluZGV4XSAtIFRvIHNwZWNpZnkgYSBjdXN0b20gc3RhY2sgb3JkZXIsXG4gKiB0aGUgYHotaW5kZXhgIGNhbiBiZSBvdmVycmlkZGVuIGJ5IGRlZmluaW5nIHRoaXMgQ1NTIHZhcmlhYmxlLlxuICovXG5AY3VzdG9tRWxlbWVudCgnc2JiLXN0aWNreS1iYXInKVxuQGhvc3RBdHRyaWJ1dGVzKHtcbiAgc2xvdDogJ3N0aWNreS1iYXInLFxufSlcbmV4cG9ydCBjbGFzcyBTYmJTdGlja3lCYXJFbGVtZW50IGV4dGVuZHMgTGl0RWxlbWVudCB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IHN0eWxlO1xuXG4gIC8qKiBDb2xvciBvZiB0aGUgY29udGFpbmVyLCBsaWtlIHRyYW5zcGFyZW50LCB3aGl0ZSBldGMuICovXG4gIEBwcm9wZXJ0eSh7IHJlZmxlY3Q6IHRydWUgfSkgcHVibGljIGNvbG9yPzogJ3doaXRlJyB8ICdtaWxrJztcblxuICBwcml2YXRlIF9pbnRlcnNlY3Rvcj86IEhUTUxTcGFuRWxlbWVudDtcbiAgcHJpdmF0ZSBfb2JzZXJ2ZXIgPSBuZXcgQWdub3N0aWNJbnRlcnNlY3Rpb25PYnNlcnZlcigoZW50cmllcykgPT5cbiAgICB0aGlzLl90b2dnbGVTaGFkb3dWaXNpYmlsaXR5KGVudHJpZXNbMF0pLFxuICApO1xuXG4gIHB1YmxpYyBvdmVycmlkZSBjb25uZWN0ZWRDYWxsYmFjaygpOiB2b2lkIHtcbiAgICBzdXBlci5jb25uZWN0ZWRDYWxsYmFjaygpO1xuXG4gICAgY29uc3QgY29udGFpbmVyID0gdGhpcy5jbG9zZXN0KCdzYmItY29udGFpbmVyJyk7XG4gICAgaWYgKGNvbnRhaW5lcikge1xuICAgICAgdGhpcy50b2dnbGVBdHRyaWJ1dGUoJ2RhdGEtZXhwYW5kZWQnLCBjb250YWluZXIuZXhwYW5kZWQpO1xuICAgIH1cbiAgICBpZiAodGhpcy5faW50ZXJzZWN0b3IpIHtcbiAgICAgIHRoaXMuX29ic2VydmVyLm9ic2VydmUodGhpcy5faW50ZXJzZWN0b3IpO1xuICAgIH1cbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSBmaXJzdFVwZGF0ZWQoY2hhbmdlZFByb3BlcnRpZXM6IFByb3BlcnR5VmFsdWVzPHRoaXM+KTogdm9pZCB7XG4gICAgc3VwZXIuZmlyc3RVcGRhdGVkKGNoYW5nZWRQcm9wZXJ0aWVzKTtcblxuICAgIGlmICghdGhpcy5faW50ZXJzZWN0b3IpIHtcbiAgICAgIHRoaXMuX2ludGVyc2VjdG9yID0gdGhpcy5zaGFkb3dSb290IS5xdWVyeVNlbGVjdG9yKCcuc2JiLXN0aWNreS1iYXJfX2ludGVyc2VjdG9yJykhO1xuICAgICAgdGhpcy5fb2JzZXJ2ZXIub2JzZXJ2ZSh0aGlzLl9pbnRlcnNlY3Rvcik7XG4gICAgfVxuICAgIHRoaXMuX29ic2VydmVyLm9ic2VydmUodGhpcyk7XG4gIH1cblxuICBwcml2YXRlIF90b2dnbGVTaGFkb3dWaXNpYmlsaXR5KGVudHJ5OiBJbnRlcnNlY3Rpb25PYnNlcnZlckVudHJ5KTogdm9pZCB7XG4gICAgdGhpcy50b2dnbGVBdHRyaWJ1dGUoXG4gICAgICAnZGF0YS1zdGlja2luZycsXG4gICAgICAhZW50cnkuaXNJbnRlcnNlY3RpbmcgJiYgZW50cnkuYm91bmRpbmdDbGllbnRSZWN0LnRvcCA+IDAsXG4gICAgKTtcbiAgfVxuXG4gIHB1YmxpYyBvdmVycmlkZSBkaXNjb25uZWN0ZWRDYWxsYmFjaygpOiB2b2lkIHtcbiAgICBzdXBlci5kaXNjb25uZWN0ZWRDYWxsYmFjaygpO1xuICAgIHRoaXMuX29ic2VydmVyLmRpc2Nvbm5lY3QoKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSByZW5kZXIoKTogVGVtcGxhdGVSZXN1bHQge1xuICAgIHJldHVybiBodG1sYFxuICAgICAgPGRpdiBjbGFzcz1cInNiYi1zdGlja3ktYmFyX193cmFwcGVyXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJzYmItc3RpY2t5LWJhclwiPlxuICAgICAgICAgIDxzbG90Pjwvc2xvdD5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJzYmItc3RpY2t5LWJhcl9faW50ZXJzZWN0b3JcIj48L2Rpdj5cbiAgICBgO1xuICB9XG59XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgaW50ZXJmYWNlIEhUTUxFbGVtZW50VGFnTmFtZU1hcCB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuICAgICdzYmItc3RpY2t5LWJhcic6IFNiYlN0aWNreUJhckVsZW1lbnQ7XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBNkJhLElBQUEsc0JBQU4sY0FBa0MsV0FBVztBQUFBLEVBQTdDLGNBQUE7QUFBQSxVQUFBLEdBQUEsU0FBQTtBQU9MLFNBQVEsWUFBWSxJQUFJO0FBQUEsTUFBNkIsQ0FBQyxZQUNwRCxLQUFLLHdCQUF3QixRQUFRLENBQUMsQ0FBQztBQUFBLElBQUE7QUFBQSxFQUN6QztBQUFBLEVBRWdCLG9CQUEwQjtBQUN4QyxVQUFNLGtCQUFrQjtBQUVsQixVQUFBLFlBQVksS0FBSyxRQUFRLGVBQWU7QUFDOUMsUUFBSSxXQUFXO0FBQ1IsV0FBQSxnQkFBZ0IsaUJBQWlCLFVBQVUsUUFBUTtBQUFBLElBQzFEO0FBQ0EsUUFBSSxLQUFLLGNBQWM7QUFDaEIsV0FBQSxVQUFVLFFBQVEsS0FBSyxZQUFZO0FBQUEsSUFDMUM7QUFBQSxFQUNGO0FBQUEsRUFFbUIsYUFBYSxtQkFBK0M7QUFDN0UsVUFBTSxhQUFhLGlCQUFpQjtBQUVoQyxRQUFBLENBQUMsS0FBSyxjQUFjO0FBQ3RCLFdBQUssZUFBZSxLQUFLLFdBQVksY0FBYyw4QkFBOEI7QUFDNUUsV0FBQSxVQUFVLFFBQVEsS0FBSyxZQUFZO0FBQUEsSUFDMUM7QUFDSyxTQUFBLFVBQVUsUUFBUSxJQUFJO0FBQUEsRUFDN0I7QUFBQSxFQUVRLHdCQUF3QixPQUF3QztBQUNqRSxTQUFBO0FBQUEsTUFDSDtBQUFBLE1BQ0EsQ0FBQyxNQUFNLGtCQUFrQixNQUFNLG1CQUFtQixNQUFNO0FBQUEsSUFBQTtBQUFBLEVBRTVEO0FBQUEsRUFFZ0IsdUJBQTZCO0FBQzNDLFVBQU0scUJBQXFCO0FBQzNCLFNBQUssVUFBVTtFQUNqQjtBQUFBLEVBRW1CLFNBQXlCO0FBQ25DLFdBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBUVQ7QUFDRjtBQXZEYSxvQkFDWSxTQUF5QjtBQUdaLGdCQUFBO0FBQUEsRUFBbkMsU0FBUyxFQUFFLFNBQVMsTUFBTTtBQUFBLEdBSmhCLG9CQUl5QixXQUFBLFNBQUEsQ0FBQTtBQUp6QixzQkFBTixnQkFBQTtBQUFBLEVBSk4sY0FBYyxnQkFBZ0I7QUFBQSxFQUM5QixlQUFlO0FBQUEsSUFDZCxNQUFNO0FBQUEsRUFBQSxDQUNQO0FBQUEsR0FDWSxtQkFBQTsifQ==
226
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RpY2t5LWJhci5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2NvbnRhaW5lci9zdGlja3ktYmFyL3N0aWNreS1iYXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdHlwZSBDU1NSZXN1bHRHcm91cCxcbiAgaHRtbCxcbiAgTGl0RWxlbWVudCxcbiAgdHlwZSBQcm9wZXJ0eVZhbHVlcyxcbiAgdHlwZSBUZW1wbGF0ZVJlc3VsdCxcbn0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBob3N0QXR0cmlidXRlcyB9IGZyb20gJy4uLy4uL2NvcmUvZGVjb3JhdG9ycy5qcyc7XG5pbXBvcnQgeyBBZ25vc3RpY0ludGVyc2VjdGlvbk9ic2VydmVyIH0gZnJvbSAnLi4vLi4vY29yZS9vYnNlcnZlcnMuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9zdGlja3ktYmFyLnNjc3M/bGl0JmlubGluZSc7XG5cbi8qKlxuICogQSBjb250YWluZXIgdGhhdCBzdGlja3MgdG8gdGhlIGJvdHRvbSBvZiB0aGUgcGFnZSBpZiBzbG90dGVkIGludG8gYHNiYi1jb250YWluZXJgLlxuICpcbiAqIEBzbG90IC0gVXNlIHRoZSB1bm5hbWVkIHNsb3QgdG8gYWRkIGNvbnRlbnQgdG8gdGhlIHN0aWNreSBiYXIuXG4gKiBAY3NzcHJvcCBbLS1zYmItc3RpY2t5LWJhci1wYWRkaW5nLWJsb2NrPXZhcigtLXNiYi1zcGFjaW5nLXJlc3BvbnNpdmUteHMpXSAtIEJsb2NrIHBhZGRpbmcgb2YgdGhlIHN0aWNreSBiYXIuXG4gKiBAY3NzcHJvcCBbLS1zYmItc3RpY2t5LWJhci1ib3R0b20tb3ZlcmxhcHBpbmctaGVpZ2h0PTBweF0gLSBEZWZpbmUgYW4gYWRkaXRpb25hbCBhcmVhIHdoZXJlXG4gKiB0aGUgc3RpY2t5IGJhciBvdmVybGFwcyB0aGUgZm9sbG93aW5nIGNvbnRlbnQgb24gdGhlIGJvdHRvbS5cbiAqIFRoaXMgYXJlYSBiZWNvbWVzIHZpc2libGUgd2hlbiB0aGUgc3RpY2t5IGJhciB0cmFuc2l0aW9ucyBmcm9tIHN0aWNreSB0byB0aGUgbm9ybWFsIGRvY3VtZW50IGZsb3cuXG4gKiBAY3NzcHJvcCBbLS1zYmItc3RpY2t5LWJhci16LWluZGV4XSAtIFRvIHNwZWNpZnkgYSBjdXN0b20gc3RhY2sgb3JkZXIsXG4gKiB0aGUgYHotaW5kZXhgIGNhbiBiZSBvdmVycmlkZGVuIGJ5IGRlZmluaW5nIHRoaXMgQ1NTIHZhcmlhYmxlLlxuICovXG5AY3VzdG9tRWxlbWVudCgnc2JiLXN0aWNreS1iYXInKVxuQGhvc3RBdHRyaWJ1dGVzKHtcbiAgc2xvdDogJ3N0aWNreS1iYXInLFxufSlcbmV4cG9ydCBjbGFzcyBTYmJTdGlja3lCYXJFbGVtZW50IGV4dGVuZHMgTGl0RWxlbWVudCB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IHN0eWxlO1xuXG4gIC8qKiBDb2xvciBvZiB0aGUgY29udGFpbmVyLCBsaWtlIHRyYW5zcGFyZW50LCB3aGl0ZSBldGMuICovXG4gIEBwcm9wZXJ0eSh7IHJlZmxlY3Q6IHRydWUgfSkgcHVibGljIGNvbG9yPzogJ3doaXRlJyB8ICdtaWxrJztcblxuICBwcml2YXRlIF9pbnRlcnNlY3Rvcj86IEhUTUxTcGFuRWxlbWVudDtcbiAgcHJpdmF0ZSBfb2JzZXJ2ZXIgPSBuZXcgQWdub3N0aWNJbnRlcnNlY3Rpb25PYnNlcnZlcigoZW50cmllcykgPT5cbiAgICB0aGlzLl90b2dnbGVTaGFkb3dWaXNpYmlsaXR5KGVudHJpZXNbMF0pLFxuICApO1xuXG4gIHB1YmxpYyBvdmVycmlkZSBjb25uZWN0ZWRDYWxsYmFjaygpOiB2b2lkIHtcbiAgICBzdXBlci5jb25uZWN0ZWRDYWxsYmFjaygpO1xuXG4gICAgY29uc3QgY29udGFpbmVyID0gdGhpcy5jbG9zZXN0KCdzYmItY29udGFpbmVyJyk7XG4gICAgaWYgKGNvbnRhaW5lcikge1xuICAgICAgdGhpcy50b2dnbGVBdHRyaWJ1dGUoJ2RhdGEtZXhwYW5kZWQnLCBjb250YWluZXIuZXhwYW5kZWQpO1xuICAgIH1cbiAgICBpZiAodGhpcy5faW50ZXJzZWN0b3IpIHtcbiAgICAgIHRoaXMuX29ic2VydmVyLm9ic2VydmUodGhpcy5faW50ZXJzZWN0b3IpO1xuICAgIH1cbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSBmaXJzdFVwZGF0ZWQoY2hhbmdlZFByb3BlcnRpZXM6IFByb3BlcnR5VmFsdWVzPHRoaXM+KTogdm9pZCB7XG4gICAgc3VwZXIuZmlyc3RVcGRhdGVkKGNoYW5nZWRQcm9wZXJ0aWVzKTtcblxuICAgIGlmICghdGhpcy5faW50ZXJzZWN0b3IpIHtcbiAgICAgIHRoaXMuX2ludGVyc2VjdG9yID0gdGhpcy5zaGFkb3dSb290IS5xdWVyeVNlbGVjdG9yKCcuc2JiLXN0aWNreS1iYXJfX2ludGVyc2VjdG9yJykhO1xuICAgICAgdGhpcy5fb2JzZXJ2ZXIub2JzZXJ2ZSh0aGlzLl9pbnRlcnNlY3Rvcik7XG4gICAgfVxuICAgIHRoaXMuX29ic2VydmVyLm9ic2VydmUodGhpcyk7XG4gIH1cblxuICBwcml2YXRlIF90b2dnbGVTaGFkb3dWaXNpYmlsaXR5KGVudHJ5OiBJbnRlcnNlY3Rpb25PYnNlcnZlckVudHJ5KTogdm9pZCB7XG4gICAgdGhpcy50b2dnbGVBdHRyaWJ1dGUoXG4gICAgICAnZGF0YS1zdGlja2luZycsXG4gICAgICAhZW50cnkuaXNJbnRlcnNlY3RpbmcgJiYgZW50cnkuYm91bmRpbmdDbGllbnRSZWN0LnRvcCA+IDAsXG4gICAgKTtcbiAgfVxuXG4gIHB1YmxpYyBvdmVycmlkZSBkaXNjb25uZWN0ZWRDYWxsYmFjaygpOiB2b2lkIHtcbiAgICBzdXBlci5kaXNjb25uZWN0ZWRDYWxsYmFjaygpO1xuICAgIHRoaXMuX29ic2VydmVyLmRpc2Nvbm5lY3QoKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSByZW5kZXIoKTogVGVtcGxhdGVSZXN1bHQge1xuICAgIHJldHVybiBodG1sYFxuICAgICAgPGRpdiBjbGFzcz1cInNiYi1zdGlja3ktYmFyX193cmFwcGVyXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJzYmItc3RpY2t5LWJhclwiPlxuICAgICAgICAgIDxzbG90Pjwvc2xvdD5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJzYmItc3RpY2t5LWJhcl9faW50ZXJzZWN0b3JcIj48L2Rpdj5cbiAgICBgO1xuICB9XG59XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgaW50ZXJmYWNlIEhUTUxFbGVtZW50VGFnTmFtZU1hcCB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuICAgICdzYmItc3RpY2t5LWJhcic6IFNiYlN0aWNreUJhckVsZW1lbnQ7XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBNkJhLElBQUEsc0JBQU4sY0FBa0MsV0FBVztBQUFBLEVBQTdDLGNBQUE7QUFBQSxVQUFBLEdBQUEsU0FBQTtBQU9MLFNBQVEsWUFBWSxJQUFJO0FBQUEsTUFBNkIsQ0FBQyxZQUNwRCxLQUFLLHdCQUF3QixRQUFRLENBQUMsQ0FBQztBQUFBLElBQUE7QUFBQSxFQUN6QztBQUFBLEVBRWdCLG9CQUEwQjtBQUN4QyxVQUFNLGtCQUFrQjtBQUVsQixVQUFBLFlBQVksS0FBSyxRQUFRLGVBQWU7QUFDOUMsUUFBSSxXQUFXO0FBQ1IsV0FBQSxnQkFBZ0IsaUJBQWlCLFVBQVUsUUFBUTtBQUFBLElBQzFEO0FBQ0EsUUFBSSxLQUFLLGNBQWM7QUFDaEIsV0FBQSxVQUFVLFFBQVEsS0FBSyxZQUFZO0FBQUEsSUFDMUM7QUFBQSxFQUNGO0FBQUEsRUFFbUIsYUFBYSxtQkFBK0M7QUFDN0UsVUFBTSxhQUFhLGlCQUFpQjtBQUVoQyxRQUFBLENBQUMsS0FBSyxjQUFjO0FBQ3RCLFdBQUssZUFBZSxLQUFLLFdBQVksY0FBYyw4QkFBOEI7QUFDNUUsV0FBQSxVQUFVLFFBQVEsS0FBSyxZQUFZO0FBQUEsSUFDMUM7QUFDSyxTQUFBLFVBQVUsUUFBUSxJQUFJO0FBQUEsRUFDN0I7QUFBQSxFQUVRLHdCQUF3QixPQUF3QztBQUNqRSxTQUFBO0FBQUEsTUFDSDtBQUFBLE1BQ0EsQ0FBQyxNQUFNLGtCQUFrQixNQUFNLG1CQUFtQixNQUFNO0FBQUEsSUFBQTtBQUFBLEVBRTVEO0FBQUEsRUFFZ0IsdUJBQTZCO0FBQzNDLFVBQU0scUJBQXFCO0FBQzNCLFNBQUssVUFBVTtFQUNqQjtBQUFBLEVBRW1CLFNBQXlCO0FBQ25DLFdBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBUVQ7QUFDRjtBQXZEYSxvQkFDWSxTQUF5QjtBQUdaLGdCQUFBO0FBQUEsRUFBbkMsU0FBUyxFQUFFLFNBQVMsTUFBTTtBQUFBLEdBSmhCLG9CQUl5QixXQUFBLFNBQUEsQ0FBQTtBQUp6QixzQkFBTixnQkFBQTtBQUFBLEVBSk4sY0FBYyxnQkFBZ0I7QUFBQSxFQUM5QixlQUFlO0FBQUEsSUFDZCxNQUFNO0FBQUEsRUFBQSxDQUNQO0FBQUEsR0FDWSxtQkFBQTsifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"host-attributes.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/decorators/host-attributes.ts"],"names":[],"mappings":"AAAA,OAAO,EAAY,KAAK,eAAe,EAAE,MAAM,KAAK,CAAC;AAErD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAexD;;;;;;;;;;;;;;;;GAgBG;AACH,eAAO,MAAM,cAAc,eACZ,OAAO,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC,cAAc,oBAAoB,eAAe,CAAC,SAoBxF,CAAC"}
1
+ {"version":3,"file":"host-attributes.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/decorators/host-attributes.ts"],"names":[],"mappings":"AAAA,OAAO,EAAY,KAAK,eAAe,EAAE,MAAM,KAAK,CAAC;AAErD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAexD;;;;;;;;;;;;;;;;GAgBG;AACH,eAAO,MAAM,cAAc,eACZ,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC,cAAc,mBAAmB,CAAC,eAAe,CAAC,SAoBxF,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"throttle.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/eventing/throttle.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,QAAQ,uBAAwB,GAAG,EAAE,KAAK,GAAG,QAClD,CAAC,SACA,MAAM,KACZ,CAAC,CAAC,GAAG,IAAI,EAAE,WAAW,CAAC,CAAC,KAAK,QAAQ,WAAW,CAAC,CAAC,CAAC,CAerD,CAAC"}
1
+ {"version":3,"file":"throttle.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/eventing/throttle.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,QAAQ,GAAI,CAAC,SAAS,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,GAAG,QAClD,CAAC,SACA,MAAM,KACZ,CAAC,CAAC,GAAG,IAAI,EAAE,UAAU,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAerD,CAAC"}
@@ -24,9 +24,7 @@ export declare const i18nTravelhints: Record<string, string>;
24
24
  export declare const i18nRealTimeInfo: Record<string, string>;
25
25
  export declare const i18nTransferProcedures: Record<string, string>;
26
26
  export declare const i18nNew: Record<string, string>;
27
- export declare const i18nFromPlatform: Record<string, Record<string, string>>;
28
- export declare const i18nFromStand: Record<string, Record<string, string>>;
29
- export declare const i18nFromPier: Record<string, Record<string, string>>;
27
+ export declare const i18nFromPlatform: Record<string, string>;
30
28
  export declare const i18nSupersaver: Record<string, string>;
31
29
  export declare const i18nOccupancy: Record<SbbOccupancy, Record<SbbLanguage, string>>;
32
30
  export declare const i18nMeansOfTransport: Record<string, Record<string, string>>;
@@ -1 +1 @@
1
- {"version":3,"file":"i18n.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/i18n/i18n.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAElE,eAAO,MAAM,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKhD,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK9C,CAAC;AAEF,eAAO,MAAM,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK7C,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKlD,CAAC;AAEF,eAAO,MAAM,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAa5D,CAAC;AAEF,eAAO,MAAM,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK5C,CAAC;AAEF,eAAO,MAAM,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK7C,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKlD,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKjD,CAAC;AAEF,eAAO,MAAM,oBAAoB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKvD,CAAC;AAEF,eAAO,MAAM,0BAA0B,iBAAkB,MAAM,KAAG,OAAO,MAAM,EAAE,MAAM,CAetF,CAAC;AAEF,eAAO,MAAM,mBAAmB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKtD,CAAC;AAEF,eAAO,MAAM,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAmBrE,CAAC;AAEF,eAAO,MAAM,qCAAqC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKxE,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKhD,CAAC;AAEF,eAAO,MAAM,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CA6BrF,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CA6BnF,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAiBlF,CAAC;AAEF,eAAO,MAAM,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKrD,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKnD,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKlD,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKnD,CAAC;AAEF,eAAO,MAAM,sBAAsB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKzD,CAAC;AAEF,eAAO,MAAM,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK1C,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAanE,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAahE,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAa/D,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKjD,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,CAyB3E,CAAC;AAEF,eAAO,MAAM,oBAAoB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAmEvE,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK/C,CAAC;AAEF,eAAO,MAAM,0BAA0B,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK7D,CAAC;AAEF,eAAO,MAAM,0BAA0B,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK7D,CAAC;AAEF,eAAO,MAAM,4BAA4B,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK/D,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKjD,CAAC;AAEF,eAAO,MAAM,qBAAqB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKxD,CAAC;AAEF,eAAO,MAAM,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK7C,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKlD,CAAC;AAEF,eAAO,MAAM,mBAAmB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKtD,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKnD,CAAC;AAEF,eAAO,MAAM,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK7C,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKlD,CAAC;AAEF,eAAO,MAAM,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK5C,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKhD,CAAC;AAEF,eAAO,MAAM,iBAAiB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKpD,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK9C,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKlD,CAAC;AAEF,eAAO,MAAM,sBAAsB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKzD,CAAC;AAEF,eAAO,MAAM,yBAAyB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK5D,CAAC;AAEF,eAAO,MAAM,iBAAiB,cAAe,MAAM,KAAG,OAAO,MAAM,EAAE,MAAM,CAKzE,CAAC;AAEH,eAAO,MAAM,qBAAqB,cAAe,MAAM,KAAG,OAAO,MAAM,EAAE,MAAM,CAK7E,CAAC;AAEH,eAAO,MAAM,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK/C,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKnD,CAAC;AAEF,eAAO,MAAM,iBAAiB,gBAAiB,MAAM,KAAG,OAAO,MAAM,EAAE,MAAM,CAK3E,CAAC;AAEH,eAAO,MAAM,qBAAqB,gBAAiB,MAAM,KAAG,OAAO,MAAM,EAAE,MAAM,CAK/E,CAAC;AAEH,eAAO,MAAM,gBAAgB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKnD,CAAC;AAEF,eAAO,MAAM,yBAAyB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK5D,CAAC;AAEF,eAAO,MAAM,iBAAiB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKpD,CAAC;AAEF,eAAO,MAAM,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKrD,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKnD,CAAC;AAEF,eAAO,MAAM,uBAAuB,eAAgB,MAAM,KAAG,OAAO,MAAM,EAAE,MAAM,CAKhF,CAAC;AAEH,eAAO,MAAM,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK/C,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKhD,CAAC;AAEF,eAAO,MAAM,2BAA2B,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK9D,CAAC;AAEF,eAAO,MAAM,iCAAiC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKpE,CAAC;AAEF,eAAO,MAAM,mBAAmB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKtD,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKjD,CAAC;AAEF,eAAO,MAAM,2BAA2B,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK9D,CAAC;AAEF,eAAO,MAAM,6BAA6B,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAKhE,CAAC;AAEF,eAAO,MAAM,0BAA0B,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAK7D,CAAC;AAEF,eAAO,MAAM,iCAAiC,cAAe,MAAM,EAAE,KAAG,OAAO,MAAM,EAAE,MAAM,CAe5F,CAAC"}
1
+ {"version":3,"file":"i18n.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/i18n/i18n.ts"],"names":[],"mappings":"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"}