@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
@@ -0,0 +1,32 @@
1
+ import { ReactiveController, ReactiveControllerHost } from 'lit';
2
+ export declare const SbbMediaQueryForcedColors = "(forced-colors: active)";
3
+ export declare const SbbMediaQueryHover = "(any-hover: hover)";
4
+ export declare const SbbMediaQueryPointerCoarse = "(pointer: coarse)";
5
+ export declare const SbbMediaQueryBreakpointMediumAndAbove: string;
6
+ export declare const SbbMediaQueryBreakpointSmallAndBelow: string;
7
+ /**
8
+ * A callback, which is invoked when the associated media query match
9
+ * status changes.
10
+ */
11
+ export type SbbMediaMatcherHandler = (matches: boolean) => void;
12
+ /**
13
+ * This controller allows listening to media query changes.
14
+ *
15
+ * @example
16
+ * new SbbMediaMatcherController(this, {
17
+ * [SbbForcedColorsQuery]: (matches) => doSomething(matches),
18
+ * })
19
+ */
20
+ export declare class SbbMediaMatcherController implements ReactiveController {
21
+ private _queries;
22
+ constructor(host: ReactiveControllerHost, _queries: Record<string, SbbMediaMatcherHandler>);
23
+ /**
24
+ * Returns whether the given query matches. Returns null with SSR.
25
+ * @param query The query to check against.
26
+ * @returns Whether the query matches or null with SSR.
27
+ */
28
+ matches(query: string): boolean | null;
29
+ hostConnected(): void;
30
+ hostDisconnected(): void;
31
+ }
32
+ //# sourceMappingURL=media-matchers-controller.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"media-matchers-controller.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/controllers/media-matchers-controller.ts"],"names":[],"mappings":"AAKA,OAAO,EAAY,KAAK,kBAAkB,EAAE,KAAK,sBAAsB,EAAE,MAAM,KAAK,CAAC;AAKrF,eAAO,MAAM,yBAAyB,4BAA4B,CAAC;AACnE,eAAO,MAAM,kBAAkB,uBAAuB,CAAC;AACvD,eAAO,MAAM,0BAA0B,sBAAsB,CAAC;AAC9D,eAAO,MAAM,qCAAqC,QAAuD,CAAC;AAC1G,eAAO,MAAM,oCAAoC,QAAsD,CAAC;AAGxG;;;GAGG;AACH,MAAM,MAAM,sBAAsB,GAAG,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI,CAAC;AAehE;;;;;;;GAOG;AACH,qBAAa,yBAA0B,YAAW,kBAAkB;IAGhE,OAAO,CAAC,QAAQ;gBADhB,IAAI,EAAE,sBAAsB,EACpB,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,sBAAsB,CAAC;IAK1D;;;;OAIG;IACI,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,GAAG,IAAI;IAYtC,aAAa,IAAI,IAAI;IAoBrB,gBAAgB,IAAI,IAAI;CAWhC"}
@@ -1,5 +1,6 @@
1
1
  export * from './controllers/connected-abort-controller.js';
2
2
  export * from './controllers/inert-controller.js';
3
3
  export * from './controllers/language-controller.js';
4
+ export * from './controllers/media-matchers-controller.js';
4
5
  export * from './controllers/slot-state-controller.js';
5
6
  //# sourceMappingURL=controllers.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"controllers.d.ts","sourceRoot":"","sources":["../../../../src/elements/core/controllers.ts"],"names":[],"mappings":"AAAA,cAAc,6CAA6C,CAAC;AAC5D,cAAc,mCAAmC,CAAC;AAClD,cAAc,sCAAsC,CAAC;AACrD,cAAc,wCAAwC,CAAC"}
1
+ {"version":3,"file":"controllers.d.ts","sourceRoot":"","sources":["../../../../src/elements/core/controllers.ts"],"names":[],"mappings":"AAAA,cAAc,6CAA6C,CAAC;AAC5D,cAAc,mCAAmC,CAAC;AAClD,cAAc,sCAAsC,CAAC;AACrD,cAAc,4CAA4C,CAAC;AAC3D,cAAc,wCAAwC,CAAC"}
@@ -1,5 +1,6 @@
1
1
  import { isServer } from "lit";
2
2
  import { readConfig } from "./config.js";
3
+ import { S as SbbTypoScaleDefault, g as SbbBreakpointMediumMin, f as SbbBreakpointSmallMax } from "../sbb-tokens-BdGhUJjM.js";
3
4
  class SbbConnectedAbortController {
4
5
  get signal() {
5
6
  var _a;
@@ -167,6 +168,63 @@ _SbbLanguageController._observerConfig = {
167
168
  attributeOldValue: true
168
169
  };
169
170
  let SbbLanguageController = _SbbLanguageController;
171
+ const pxToRem = (px) => px / SbbTypoScaleDefault;
172
+ const SbbMediaQueryForcedColors = "(forced-colors: active)";
173
+ const SbbMediaQueryHover = "(any-hover: hover)";
174
+ const SbbMediaQueryPointerCoarse = "(pointer: coarse)";
175
+ const SbbMediaQueryBreakpointMediumAndAbove = `(min-width: ${pxToRem(SbbBreakpointMediumMin)}rem)`;
176
+ const SbbMediaQueryBreakpointSmallAndBelow = `(max-width: ${pxToRem(SbbBreakpointSmallMax)}rem)`;
177
+ const mediaQueryRegistry = /* @__PURE__ */ new Map();
178
+ class SbbMediaMatcherController {
179
+ constructor(host, _queries) {
180
+ this._queries = _queries;
181
+ host.addController(this);
182
+ }
183
+ /**
184
+ * Returns whether the given query matches. Returns null with SSR.
185
+ * @param query The query to check against.
186
+ * @returns Whether the query matches or null with SSR.
187
+ */
188
+ matches(query) {
189
+ if (isServer) {
190
+ return null;
191
+ }
192
+ const mediaQuery = mediaQueryRegistry.get(query);
193
+ if (mediaQuery) {
194
+ return mediaQuery.mediaQueryList.matches;
195
+ } else {
196
+ return matchMedia(query).matches;
197
+ }
198
+ }
199
+ hostConnected() {
200
+ if (isServer) {
201
+ return;
202
+ }
203
+ for (const [query, handler] of Object.entries(this._queries)) {
204
+ const mediaQuery = mediaQueryRegistry.get(query);
205
+ if (mediaQuery) {
206
+ mediaQuery.handlers.add(handler);
207
+ } else {
208
+ const mediaQueryList = matchMedia(query);
209
+ const handlers = /* @__PURE__ */ new Set([handler]);
210
+ const eventHandler = (e) => handlers.forEach((h) => h(e.matches));
211
+ mediaQueryList.addEventListener("change", eventHandler);
212
+ mediaQueryRegistry.set(query, { mediaQueryList, handlers, eventHandler });
213
+ }
214
+ }
215
+ }
216
+ hostDisconnected() {
217
+ for (const [query, handler] of Object.entries(this._queries)) {
218
+ const mediaQuery = mediaQueryRegistry.get(query);
219
+ if (mediaQuery) {
220
+ mediaQuery.handlers.delete(handler);
221
+ if (!mediaQuery.handlers.size) {
222
+ mediaQueryRegistry.delete(query);
223
+ }
224
+ }
225
+ }
226
+ }
227
+ }
170
228
  class SbbSlotStateController {
171
229
  constructor(_host, _onChangeCallback = null) {
172
230
  this._host = _host;
@@ -215,6 +273,12 @@ export {
215
273
  SbbConnectedAbortController,
216
274
  SbbInertController,
217
275
  SbbLanguageController,
276
+ SbbMediaMatcherController,
277
+ SbbMediaQueryBreakpointMediumAndAbove,
278
+ SbbMediaQueryBreakpointSmallAndBelow,
279
+ SbbMediaQueryForcedColors,
280
+ SbbMediaQueryHover,
281
+ SbbMediaQueryPointerCoarse,
218
282
  SbbSlotStateController
219
283
  };
220
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"controllers.js","sources":["../../../../src/elements/core/controllers/connected-abort-controller.ts","../../../../src/elements/core/controllers/inert-controller.ts","../../../../src/elements/core/controllers/language-controller.ts","../../../../src/elements/core/controllers/slot-state-controller.ts"],"sourcesContent":["import type { ReactiveController, ReactiveControllerHost } from 'lit';\n\nexport class SbbConnectedAbortController implements ReactiveController {\n  private _abortController?: AbortController = new AbortController();\n\n  public get signal(): AbortSignal | undefined {\n    return this._abortController?.signal;\n  }\n\n  public constructor(private _host: ReactiveControllerHost) {\n    this._host.addController(this);\n  }\n\n  public hostConnected(): void {\n    if (!this._abortController) {\n      this._abortController = new AbortController();\n    }\n  }\n\n  public hostDisconnected(): void {\n    this._abortController?.abort();\n    this._abortController = undefined;\n  }\n}\n","import type { ReactiveController, ReactiveControllerHost } from 'lit';\n\nimport type { SbbOpenCloseBaseElement } from '../base-elements/open-close-base-element.js';\n\nconst IGNORED_ELEMENTS = ['script', 'head', 'template', 'style'];\nconst inertElements = new Set<HTMLElement>();\nconst inertOverlays = new Set<HTMLElement>();\n\nexport class SbbInertController implements ReactiveController {\n  public constructor(\n    private _host: ReactiveControllerHost & SbbOpenCloseBaseElement,\n    private _inertElements = inertElements,\n    private _inertOverlays = inertOverlays,\n  ) {\n    this._host.addController?.(this);\n  }\n\n  public hostConnected(): void {\n    if (this._host.isOpen) {\n      this.activate();\n    }\n  }\n\n  public hostDisconnected(): void {\n    if (this._inertOverlays.has(this._host)) {\n      this.deactivate();\n    }\n  }\n\n  /** Applies inert state to every other element on the page except the overlay. */\n  public activate(): void {\n    // Remove inert state from previous opened overlay\n    if (this._inertOverlays.size) {\n      this._removeInertAttributes();\n    }\n\n    this._inertOverlays.add(this._host);\n    this._addInertAttributes();\n  }\n\n  /** Removes inert state. */\n  public deactivate(): void {\n    if (this._currentOverlay() !== this._host) {\n      // If e.g. a component gets disconnected, it could be that it is not the top most.\n      // In this case, we can directly remove it, as there is currently no inert state applied.\n      if (this._inertOverlays.has(this._host)) {\n        this._inertOverlays.delete(this._host);\n      } else if (import.meta.env.DEV) {\n        console.warn(\n          'Trying to remove inert state of an overlay which never had an applied inert state.',\n          this._host,\n        );\n      }\n\n      return;\n    }\n\n    this._removeInertAttributes();\n    this._inertOverlays.delete(this._host);\n\n    // If there is as previous opened overlay, set its inert state again.\n    if (this._inertOverlays.size) {\n      this._addInertAttributes();\n    }\n  }\n\n  private _currentOverlay(): HTMLElement | null {\n    return [...this._inertOverlays].pop() ?? null;\n  }\n\n  private _removeInertAttributes(): void {\n    this._inertElements.forEach((element: HTMLElement): void => {\n      if (!element) {\n        return;\n      }\n\n      if (element.hasAttribute('data-sbb-inert')) {\n        element.inert = false;\n        element.removeAttribute('data-sbb-inert');\n      }\n\n      if (element.hasAttribute('data-sbb-aria-hidden')) {\n        element.removeAttribute('aria-hidden');\n        element.removeAttribute('data-sbb-aria-hidden');\n      }\n    });\n    this._inertElements.clear();\n  }\n\n  private _addInertAttributes(): void {\n    let element: Element | null = this._currentOverlay();\n\n    while (element !== document.documentElement && element !== null) {\n      Array.from((element?.parentElement ?? element?.getRootNode())?.childNodes ?? [])\n        .filter(\n          (child): child is HTMLElement =>\n            child !== element &&\n            child instanceof window.HTMLElement &&\n            !IGNORED_ELEMENTS.includes(child.localName),\n        )\n        .forEach((element) => {\n          this._inertElements.add(element);\n\n          if (!element.inert) {\n            element.inert = true;\n            element.toggleAttribute('data-sbb-inert', true);\n          }\n\n          if (!element.hasAttribute('aria-hidden')) {\n            element.setAttribute('aria-hidden', 'true');\n            element.toggleAttribute('data-sbb-aria-hidden', true);\n          }\n        });\n\n      // We need to pierce through Shadow DOM boundary\n      element = element?.parentElement ?? (element?.getRootNode() as ShadowRoot)?.host ?? null;\n    }\n  }\n}\n","import { isServer, type ReactiveController, type ReactiveControllerHost } from 'lit';\n\nimport { readConfig } from '../config.js';\n\n/**\n * The LanguageController is a reactive controller that observes the \"lang\" attribute\n * of the <html> tag.\n * On change of the \"lang\" attribute, it will request an update of connected\n * components.\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/lang\n */\nexport class SbbLanguageController implements ReactiveController {\n  private static readonly _defaultLanguage = 'en';\n  private static readonly _supportedLocales = ['en', 'de', 'fr', 'it'];\n\n  /** A set of connected components that should be notified on language change. */\n  private static readonly _listeners = new Set<SbbLanguageController>();\n\n  /** MutationObserver that observes the \"lang\" attribute of the <html> element. */\n  private static readonly _observer = !isServer\n    ? new MutationObserver((mutations) => {\n        if (mutations[0].oldValue !== document.documentElement.getAttribute('lang')) {\n          SbbLanguageController._listeners.forEach((l) => l._callHandlers());\n        }\n      })\n    : null;\n  private static readonly _observerConfig = {\n    attributeFilter: ['lang'],\n    attributeOldValue: true,\n  };\n\n  /** Get the current language. */\n  public static get current(): string {\n    const language =\n      (readConfig().language ??\n        (isServer\n          ? SbbLanguageController._defaultLanguage\n          : document.documentElement.getAttribute('lang'))) ||\n      SbbLanguageController._defaultLanguage;\n\n    // Support e.g. cases like `de-ch`.\n    const langAttributeNormalized = language.split('-')[0];\n    return SbbLanguageController._supportedLocales.includes(langAttributeNormalized)\n      ? langAttributeNormalized\n      : SbbLanguageController._defaultLanguage;\n  }\n\n  /** Get the current language. */\n  public get current(): string {\n    return SbbLanguageController.current;\n  }\n\n  private _previousLanguage?: string;\n  private _handlers: (() => void)[] = [];\n\n  public constructor(private _host: ReactiveControllerHost) {\n    this._host.addController(this);\n  }\n\n  /** Add a language change handler. */\n  public withHandler(handler: () => void): this {\n    // We use unshift here, to prepend additional handlers.\n    // This ensures that requestUpdate is called after the other handlers.\n    this._handlers.unshift(handler);\n    return this;\n  }\n\n  public hostConnected(): void {\n    if (isServer) {\n      return;\n    }\n    if (!SbbLanguageController._listeners.size) {\n      SbbLanguageController._observer!.observe(\n        document.documentElement,\n        SbbLanguageController._observerConfig,\n      );\n    }\n\n    SbbLanguageController._listeners.add(this);\n    if (this._previousLanguage !== this.current) {\n      this._callHandlers(this._previousLanguage !== undefined);\n    }\n  }\n\n  public hostDisconnected(): void {\n    if (isServer) {\n      return;\n    }\n    this._previousLanguage = this.current;\n    SbbLanguageController._listeners.delete(this);\n    if (!SbbLanguageController._listeners.size) {\n      SbbLanguageController._observer!.disconnect();\n    }\n  }\n\n  private _callHandlers(requestUpdate = true): void {\n    this._handlers.forEach((h) => h());\n    if (requestUpdate) {\n      this._host.requestUpdate();\n    }\n  }\n}\n","import type { ReactiveController, ReactiveControllerHost } from 'lit';\n\n/**\n * This controller checks for slotted children. From these it generates\n * a list of used slot names (`unnamed` for children without a slot attribute)\n * and adds this to the `data-slot-names` attribute, as a space separated list.\n *\n * This allows CSS attribute selector to display/hide/configure a section\n * of the component as required (see [attr~=value] selector specifically).\n *\n * @example\n * .example {\n *   display: none;\n *\n *   :host([data-slot-names~=\"icon\"]) & {\n *     display: inline;\n *   }\n * }\n *\n * https://developer.mozilla.org/en-US/docs/Web/CSS/Attribute_selectors\n */\nexport class SbbSlotStateController implements ReactiveController {\n  public readonly slots = new Set<string>();\n\n  public constructor(\n    private _host: ReactiveControllerHost & HTMLElement,\n    private _onChangeCallback: (() => void) | null = null,\n  ) {\n    this._host.addController(this);\n  }\n\n  public hostConnected(): void {\n    // TODO: Check if this is really needed with SSR.\n    this._syncSlots(...this._host.querySelectorAll!('slot'));\n    this._host.shadowRoot?.addEventListener('slotchange', this._slotchangeHandler);\n  }\n\n  public hostDisconnected(): void {\n    this._host.shadowRoot?.removeEventListener('slotchange', this._slotchangeHandler);\n  }\n\n  // We avoid using AbortController here, as it would mean creating\n  // a new instance for every SbbSlotStateController instance.\n  private _slotchangeHandler = (event: Event): void => {\n    this._syncSlots(event.target as HTMLSlotElement);\n  };\n\n  private _syncSlots(...slots: HTMLSlotElement[]): void {\n    for (const slot of slots) {\n      const slotName = slot.name || 'unnamed';\n      // We want to check, whether an element is slotted or a text node with actual content.\n      if (slot.assignedNodes().some((n) => 'tagName' in n || n.textContent?.trim())) {\n        this.slots.add(slotName);\n      } else {\n        this.slots.delete(slotName);\n      }\n    }\n\n    const oldValue = this._host.getAttribute('data-slot-names');\n    const joinedSlotNames = [...this.slots].sort().join(' ');\n    if (!joinedSlotNames) {\n      this._host.removeAttribute('data-slot-names');\n    } else if (this._host.getAttribute('data-slot-names') !== joinedSlotNames) {\n      this._host.setAttribute('data-slot-names', joinedSlotNames);\n    }\n\n    if (joinedSlotNames !== oldValue) {\n      this._onChangeCallback?.();\n    }\n  }\n}\n"],"names":["element","_a"],"mappings":"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"}
284
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"controllers.js","sources":["../../../../src/elements/core/controllers/connected-abort-controller.ts","../../../../src/elements/core/controllers/inert-controller.ts","../../../../src/elements/core/controllers/language-controller.ts","../../../../src/elements/core/controllers/media-matchers-controller.ts","../../../../src/elements/core/controllers/slot-state-controller.ts"],"sourcesContent":["import type { ReactiveController, ReactiveControllerHost } from 'lit';\n\nexport class SbbConnectedAbortController implements ReactiveController {\n  private _abortController?: AbortController = new AbortController();\n\n  public get signal(): AbortSignal | undefined {\n    return this._abortController?.signal;\n  }\n\n  public constructor(private _host: ReactiveControllerHost) {\n    this._host.addController(this);\n  }\n\n  public hostConnected(): void {\n    if (!this._abortController) {\n      this._abortController = new AbortController();\n    }\n  }\n\n  public hostDisconnected(): void {\n    this._abortController?.abort();\n    this._abortController = undefined;\n  }\n}\n","import type { ReactiveController, ReactiveControllerHost } from 'lit';\n\nimport type { SbbOpenCloseBaseElement } from '../base-elements/open-close-base-element.js';\n\nconst IGNORED_ELEMENTS = ['script', 'head', 'template', 'style'];\nconst inertElements = new Set<HTMLElement>();\nconst inertOverlays = new Set<HTMLElement>();\n\nexport class SbbInertController implements ReactiveController {\n  public constructor(\n    private _host: ReactiveControllerHost & SbbOpenCloseBaseElement,\n    private _inertElements = inertElements,\n    private _inertOverlays = inertOverlays,\n  ) {\n    this._host.addController?.(this);\n  }\n\n  public hostConnected(): void {\n    if (this._host.isOpen) {\n      this.activate();\n    }\n  }\n\n  public hostDisconnected(): void {\n    if (this._inertOverlays.has(this._host)) {\n      this.deactivate();\n    }\n  }\n\n  /** Applies inert state to every other element on the page except the overlay. */\n  public activate(): void {\n    // Remove inert state from previous opened overlay\n    if (this._inertOverlays.size) {\n      this._removeInertAttributes();\n    }\n\n    this._inertOverlays.add(this._host);\n    this._addInertAttributes();\n  }\n\n  /** Removes inert state. */\n  public deactivate(): void {\n    if (this._currentOverlay() !== this._host) {\n      // If e.g. a component gets disconnected, it could be that it is not the top most.\n      // In this case, we can directly remove it, as there is currently no inert state applied.\n      if (this._inertOverlays.has(this._host)) {\n        this._inertOverlays.delete(this._host);\n      } else if (import.meta.env.DEV) {\n        console.warn(\n          'Trying to remove inert state of an overlay which never had an applied inert state.',\n          this._host,\n        );\n      }\n\n      return;\n    }\n\n    this._removeInertAttributes();\n    this._inertOverlays.delete(this._host);\n\n    // If there is as previous opened overlay, set its inert state again.\n    if (this._inertOverlays.size) {\n      this._addInertAttributes();\n    }\n  }\n\n  private _currentOverlay(): HTMLElement | null {\n    return [...this._inertOverlays].pop() ?? null;\n  }\n\n  private _removeInertAttributes(): void {\n    this._inertElements.forEach((element: HTMLElement): void => {\n      if (!element) {\n        return;\n      }\n\n      if (element.hasAttribute('data-sbb-inert')) {\n        element.inert = false;\n        element.removeAttribute('data-sbb-inert');\n      }\n\n      if (element.hasAttribute('data-sbb-aria-hidden')) {\n        element.removeAttribute('aria-hidden');\n        element.removeAttribute('data-sbb-aria-hidden');\n      }\n    });\n    this._inertElements.clear();\n  }\n\n  private _addInertAttributes(): void {\n    let element: Element | null = this._currentOverlay();\n\n    while (element !== document.documentElement && element !== null) {\n      Array.from((element?.parentElement ?? element?.getRootNode())?.childNodes ?? [])\n        .filter(\n          (child): child is HTMLElement =>\n            child !== element &&\n            child instanceof window.HTMLElement &&\n            !IGNORED_ELEMENTS.includes(child.localName),\n        )\n        .forEach((element) => {\n          this._inertElements.add(element);\n\n          if (!element.inert) {\n            element.inert = true;\n            element.toggleAttribute('data-sbb-inert', true);\n          }\n\n          if (!element.hasAttribute('aria-hidden')) {\n            element.setAttribute('aria-hidden', 'true');\n            element.toggleAttribute('data-sbb-aria-hidden', true);\n          }\n        });\n\n      // We need to pierce through Shadow DOM boundary\n      element = element?.parentElement ?? (element?.getRootNode() as ShadowRoot)?.host ?? null;\n    }\n  }\n}\n","import { isServer, type ReactiveController, type ReactiveControllerHost } from 'lit';\n\nimport { readConfig } from '../config.js';\n\n/**\n * The LanguageController is a reactive controller that observes the \"lang\" attribute\n * of the <html> tag.\n * On change of the \"lang\" attribute, it will request an update of connected\n * components.\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/lang\n */\nexport class SbbLanguageController implements ReactiveController {\n  private static readonly _defaultLanguage = 'en';\n  private static readonly _supportedLocales = ['en', 'de', 'fr', 'it'];\n\n  /** A set of connected components that should be notified on language change. */\n  private static readonly _listeners = new Set<SbbLanguageController>();\n\n  /** MutationObserver that observes the \"lang\" attribute of the <html> element. */\n  private static readonly _observer = !isServer\n    ? new MutationObserver((mutations) => {\n        if (mutations[0].oldValue !== document.documentElement.getAttribute('lang')) {\n          SbbLanguageController._listeners.forEach((l) => l._callHandlers());\n        }\n      })\n    : null;\n  private static readonly _observerConfig = {\n    attributeFilter: ['lang'],\n    attributeOldValue: true,\n  };\n\n  /** Get the current language. */\n  public static get current(): string {\n    const language =\n      (readConfig().language ??\n        (isServer\n          ? SbbLanguageController._defaultLanguage\n          : document.documentElement.getAttribute('lang'))) ||\n      SbbLanguageController._defaultLanguage;\n\n    // Support e.g. cases like `de-ch`.\n    const langAttributeNormalized = language.split('-')[0];\n    return SbbLanguageController._supportedLocales.includes(langAttributeNormalized)\n      ? langAttributeNormalized\n      : SbbLanguageController._defaultLanguage;\n  }\n\n  /** Get the current language. */\n  public get current(): string {\n    return SbbLanguageController.current;\n  }\n\n  private _previousLanguage?: string;\n  private _handlers: (() => void)[] = [];\n\n  public constructor(private _host: ReactiveControllerHost) {\n    this._host.addController(this);\n  }\n\n  /** Add a language change handler. */\n  public withHandler(handler: () => void): this {\n    // We use unshift here, to prepend additional handlers.\n    // This ensures that requestUpdate is called after the other handlers.\n    this._handlers.unshift(handler);\n    return this;\n  }\n\n  public hostConnected(): void {\n    if (isServer) {\n      return;\n    }\n    if (!SbbLanguageController._listeners.size) {\n      SbbLanguageController._observer!.observe(\n        document.documentElement,\n        SbbLanguageController._observerConfig,\n      );\n    }\n\n    SbbLanguageController._listeners.add(this);\n    if (this._previousLanguage !== this.current) {\n      this._callHandlers(this._previousLanguage !== undefined);\n    }\n  }\n\n  public hostDisconnected(): void {\n    if (isServer) {\n      return;\n    }\n    this._previousLanguage = this.current;\n    SbbLanguageController._listeners.delete(this);\n    if (!SbbLanguageController._listeners.size) {\n      SbbLanguageController._observer!.disconnect();\n    }\n  }\n\n  private _callHandlers(requestUpdate = true): void {\n    this._handlers.forEach((h) => h());\n    if (requestUpdate) {\n      this._host.requestUpdate();\n    }\n  }\n}\n","import {\n  SbbBreakpointMediumMin,\n  SbbBreakpointSmallMax,\n  SbbTypoScaleDefault,\n} from '@sbb-esta/lyne-design-tokens';\nimport { isServer, type ReactiveController, type ReactiveControllerHost } from 'lit';\n\nconst pxToRem = (px: number): number => px / SbbTypoScaleDefault;\n\n/* eslint-disable @typescript-eslint/naming-convention */\nexport const SbbMediaQueryForcedColors = '(forced-colors: active)';\nexport const SbbMediaQueryHover = '(any-hover: hover)';\nexport const SbbMediaQueryPointerCoarse = '(pointer: coarse)';\nexport const SbbMediaQueryBreakpointMediumAndAbove = `(min-width: ${pxToRem(SbbBreakpointMediumMin)}rem)`;\nexport const SbbMediaQueryBreakpointSmallAndBelow = `(max-width: ${pxToRem(SbbBreakpointSmallMax)}rem)`;\n/* eslint-enable @typescript-eslint/naming-convention */\n\n/**\n * A callback, which is invoked when the associated media query match\n * status changes.\n */\nexport type SbbMediaMatcherHandler = (matches: boolean) => void;\n\ninterface MediaQueryEntry {\n  mediaQueryList: MediaQueryList;\n  eventHandler: (event: MediaQueryListEvent) => void;\n  handlers: Set<SbbMediaMatcherHandler>;\n}\n\n/**\n * We want to cache MediaQueryList instances and corresponding\n * event handlers, as a multitude of event handlers on global objects\n * can degrade performance with time.\n */\nconst mediaQueryRegistry = new Map<string, MediaQueryEntry>();\n\n/**\n * This controller allows listening to media query changes.\n *\n * @example\n * new SbbMediaMatcherController(this, {\n *   [SbbForcedColorsQuery]: (matches) => doSomething(matches),\n * })\n */\nexport class SbbMediaMatcherController implements ReactiveController {\n  public constructor(\n    host: ReactiveControllerHost,\n    private _queries: Record<string, SbbMediaMatcherHandler>,\n  ) {\n    host.addController(this);\n  }\n\n  /**\n   * Returns whether the given query matches. Returns null with SSR.\n   * @param query The query to check against.\n   * @returns Whether the query matches or null with SSR.\n   */\n  public matches(query: string): boolean | null {\n    if (isServer) {\n      return null;\n    }\n    const mediaQuery = mediaQueryRegistry.get(query);\n    if (mediaQuery) {\n      return mediaQuery.mediaQueryList.matches;\n    } else {\n      return matchMedia(query).matches;\n    }\n  }\n\n  public hostConnected(): void {\n    if (isServer) {\n      return;\n    }\n\n    for (const [query, handler] of Object.entries(this._queries)) {\n      const mediaQuery = mediaQueryRegistry.get(query);\n      if (mediaQuery) {\n        mediaQuery.handlers.add(handler);\n      } else {\n        const mediaQueryList = matchMedia(query);\n        const handlers = new Set([handler]);\n        const eventHandler = (e: MediaQueryListEvent): void =>\n          handlers.forEach((h) => h(e.matches));\n        mediaQueryList.addEventListener('change', eventHandler);\n        mediaQueryRegistry.set(query, { mediaQueryList, handlers, eventHandler });\n      }\n    }\n  }\n\n  public hostDisconnected(): void {\n    for (const [query, handler] of Object.entries(this._queries)) {\n      const mediaQuery = mediaQueryRegistry.get(query);\n      if (mediaQuery) {\n        mediaQuery.handlers.delete(handler);\n        if (!mediaQuery.handlers.size) {\n          mediaQueryRegistry.delete(query);\n        }\n      }\n    }\n  }\n}\n","import type { ReactiveController, ReactiveControllerHost } from 'lit';\n\n/**\n * This controller checks for slotted children. From these it generates\n * a list of used slot names (`unnamed` for children without a slot attribute)\n * and adds this to the `data-slot-names` attribute, as a space separated list.\n *\n * This allows CSS attribute selector to display/hide/configure a section\n * of the component as required (see [attr~=value] selector specifically).\n *\n * @example\n * .example {\n *   display: none;\n *\n *   :host([data-slot-names~=\"icon\"]) & {\n *     display: inline;\n *   }\n * }\n *\n * https://developer.mozilla.org/en-US/docs/Web/CSS/Attribute_selectors\n */\nexport class SbbSlotStateController implements ReactiveController {\n  public readonly slots = new Set<string>();\n\n  public constructor(\n    private _host: ReactiveControllerHost & HTMLElement,\n    private _onChangeCallback: (() => void) | null = null,\n  ) {\n    this._host.addController(this);\n  }\n\n  public hostConnected(): void {\n    // TODO: Check if this is really needed with SSR.\n    this._syncSlots(...this._host.querySelectorAll!('slot'));\n    this._host.shadowRoot?.addEventListener('slotchange', this._slotchangeHandler);\n  }\n\n  public hostDisconnected(): void {\n    this._host.shadowRoot?.removeEventListener('slotchange', this._slotchangeHandler);\n  }\n\n  // We avoid using AbortController here, as it would mean creating\n  // a new instance for every SbbSlotStateController instance.\n  private _slotchangeHandler = (event: Event): void => {\n    this._syncSlots(event.target as HTMLSlotElement);\n  };\n\n  private _syncSlots(...slots: HTMLSlotElement[]): void {\n    for (const slot of slots) {\n      const slotName = slot.name || 'unnamed';\n      // We want to check, whether an element is slotted or a text node with actual content.\n      if (slot.assignedNodes().some((n) => 'tagName' in n || n.textContent?.trim())) {\n        this.slots.add(slotName);\n      } else {\n        this.slots.delete(slotName);\n      }\n    }\n\n    const oldValue = this._host.getAttribute('data-slot-names');\n    const joinedSlotNames = [...this.slots].sort().join(' ');\n    if (!joinedSlotNames) {\n      this._host.removeAttribute('data-slot-names');\n    } else if (this._host.getAttribute('data-slot-names') !== joinedSlotNames) {\n      this._host.setAttribute('data-slot-names', joinedSlotNames);\n    }\n\n    if (joinedSlotNames !== oldValue) {\n      this._onChangeCallback?.();\n    }\n  }\n}\n"],"names":["element","_a"],"mappings":"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"}
@@ -6,9 +6,10 @@ export type Breakpoint = (typeof breakpoints)[number];
6
6
  *
7
7
  * @param from The breakpoint corresponding to the `min-width` value of the media query (optional).
8
8
  * @param to The breakpoint corresponding to the `max-width` value of the media query (optional).
9
+ * @param properties Whether the max breakpoint should be included
9
10
  * @returns A boolean indicating whether the window matches the breakpoint.
10
11
  */
11
12
  export declare function isBreakpoint(from?: Breakpoint, to?: Breakpoint, properties?: {
12
13
  includeMaxBreakpoint: boolean;
13
- }): boolean;
14
+ }): boolean | null;
14
15
  //# sourceMappingURL=breakpoint.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"breakpoint.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/dom/breakpoint.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,WAAW,yEAA0E,CAAC;AACnG,MAAM,MAAM,UAAU,GAAG,CAAC,OAAO,WAAW,CAAC,CAAC,MAAM,CAAC,CAAC;AAEtD;;;;;;;GAOG;AACH,wBAAgB,YAAY,CAC1B,IAAI,CAAC,EAAE,UAAU,EACjB,EAAE,CAAC,EAAE,UAAU,EACf,UAAU,CAAC,EAAE;IAAE,oBAAoB,EAAE,OAAO,CAAA;CAAE,GAC7C,OAAO,CAuBT"}
1
+ {"version":3,"file":"breakpoint.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/dom/breakpoint.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,WAAW,yEAA0E,CAAC;AACnG,MAAM,MAAM,UAAU,GAAG,CAAC,OAAO,WAAW,CAAC,CAAC,MAAM,CAAC,CAAC;AAEtD;;;;;;;;GAQG;AACH,wBAAgB,YAAY,CAC1B,IAAI,CAAC,EAAE,UAAU,EACjB,EAAE,CAAC,EAAE,UAAU,EACf,UAAU,CAAC,EAAE;IAAE,oBAAoB,EAAE,OAAO,CAAA;CAAE,GAC7C,OAAO,GAAG,IAAI,CAsBhB"}
@@ -2,7 +2,7 @@ import { isServer } from "lit";
2
2
  const breakpoints = ["zero", "micro", "small", "medium", "wide", "large", "ultra"];
3
3
  function isBreakpoint(from, to, properties) {
4
4
  if (isServer) {
5
- return false;
5
+ return null;
6
6
  }
7
7
  const computedStyle = getComputedStyle(document.documentElement);
8
8
  const breakpointMin = from ? computedStyle.getPropertyValue(`--sbb-breakpoint-${from}-min`) : "";
@@ -138,4 +138,4 @@ export {
138
138
  pageScrollDisabled,
139
139
  setOrRemoveAttribute
140
140
  };
141
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"dom.js","sources":["../../../../src/elements/core/dom/breakpoint.ts","../../../../src/elements/core/dom/find-referenced-element.ts","../../../../src/elements/core/dom/get-document-writing-mode.ts","../../../../src/elements/core/dom/host-context.ts","../../../../src/elements/core/dom/input-element.ts","../../../../src/elements/core/dom/set-or-remove-attribute.ts","../../../../src/elements/core/dom/platform.ts","../../../../src/elements/core/dom/scroll.ts","../../../../src/elements/core/dom/ssr.ts"],"sourcesContent":["import { isServer } from 'lit';\n\nexport const breakpoints = ['zero', 'micro', 'small', 'medium', 'wide', 'large', 'ultra'] as const;\nexport type Breakpoint = (typeof breakpoints)[number];\n\n/**\n * Checks whether the document matches a particular media query.\n * It will rely on the global CSS variables to determine the value of the breakpoints.\n *\n * @param from The breakpoint corresponding to the `min-width` value of the media query (optional).\n * @param to The breakpoint corresponding to the `max-width` value of the media query (optional).\n * @returns A boolean indicating whether the window matches the breakpoint.\n */\nexport function isBreakpoint(\n  from?: Breakpoint,\n  to?: Breakpoint,\n  properties?: { includeMaxBreakpoint: boolean },\n): boolean {\n  if (isServer) {\n    // TODO: Remove and decide case by case what should be done on consuming end\n    return false;\n  }\n\n  const computedStyle = getComputedStyle(document.documentElement);\n  const breakpointMin = from ? computedStyle.getPropertyValue(`--sbb-breakpoint-${from}-min`) : '';\n  const breakpointMax = to\n    ? `${\n        parseFloat(\n          computedStyle.getPropertyValue(\n            `--sbb-breakpoint-${to}-${properties?.includeMaxBreakpoint ? 'max' : 'min'}`,\n          ),\n        ) - (properties?.includeMaxBreakpoint ? 0 : 0.0625)\n      }rem`\n    : ''; // subtract 1px (0.0625rem) from the max-width breakpoint\n\n  const minWidth = breakpointMin && `(min-width: ${breakpointMin})`;\n  const maxWidth = breakpointMax && `(max-width: ${breakpointMax})`;\n  const and = breakpointMin && breakpointMax && ' and ';\n\n  return window.matchMedia(`${minWidth}${and}${maxWidth}`).matches;\n}\n","import { isServer } from 'lit';\n\n/**\n *  Check whether it's a string or an HTMLElement, if it's a string queries the element with the\n *  corresponding id.\n *  @param reference either the wanted id or the HTMLElement\n */\nexport function findReferencedElement<T extends HTMLElement = HTMLElement>(\n  reference: string | HTMLElement,\n): T | null {\n  if (isServer) {\n    return null;\n  } else if (typeof reference === 'string') {\n    return document.getElementById(reference) as T;\n  } else if (reference instanceof window.Element) {\n    return reference as T;\n  }\n  return null;\n}\n","import { isServer } from 'lit';\n\n/**\n * @deprecated use :dir() selector instead\n */\nexport const getDocumentWritingMode = (): string =>\n  (!isServer && document.documentElement.getAttribute('dir')) || 'ltr';\n","import { isServer } from 'lit';\n\n/**\n * Looks for the closest element matching the given selector starting from the given element.\n * Returns null, if none of the ancestor match.\n *\n * @param selector The selector to match ancestor against.\n * @param element The base element from which to start the search.\n * @returns The closest element matching the selector or null if none is found.\n */\nexport function hostContext(selector: string, element: Element): Element | null {\n  if (isServer) {\n    return null;\n  }\n  // Start with parent element in order to avoid finding element itself\n  element = element.parentElement ?? (element.getRootNode() as ShadowRoot).host;\n  while (element && (element as any) !== document && (element as any) !== window) {\n    const match = element.closest(selector);\n    if (match) {\n      return match;\n    }\n\n    element = (element.getRootNode() as ShadowRoot).host;\n  }\n\n  return null;\n}\n\n// A list of elements that should not allow another anchor or button element inside them.\n// Needs to be extended if additional elements fall into this category.\nexport const ACTION_ELEMENTS = 'a,button,sbb-teaser-hero,sbb-teaser';\n","import { findReferencedElement } from './find-referenced-element.js';\n\n/**\n * Given an element, returns the related input reference, if it exists respecting following priority.\n * 1. Input field in `sbb-form-field` (if trigger is undefiend)\n * 2. Input referenced by id (trigger is string)\n * 3. Input referenced directly (trigger is HTMLElement)\n * @param element The starting SbbDatepickerElement element.\n * @param trigger The id or the reference of the input.\n */\nexport function findInput(\n  element: HTMLElement,\n  trigger?: string | HTMLElement | null,\n): HTMLInputElement | null {\n  if (!trigger) {\n    const parent = element.closest?.('sbb-form-field');\n    return parent?.querySelector('input') as HTMLInputElement | null;\n  }\n\n  return findReferencedElement<HTMLInputElement>(trigger);\n}\n","/**\n * Set the attribute only if value is not 'false', otherwise remove attribute.\n * @param element The element that will have the attribute\n * @param attribute The attribute name\n * @param value The attribute value\n */\nexport function setOrRemoveAttribute(element: HTMLElement, attribute: string, value?: any): void {\n  if (!value) {\n    element.removeAttribute(attribute);\n  } else {\n    element.setAttribute(attribute, value);\n  }\n}\n","// This file is freely inspired by Angular Material solution.\n// Reference: https://github.com/angular/components/blob/main/src/cdk/platform/platform.ts\nimport { isServer } from 'lit';\n\n// Whether the current platform supports the V8 Break Iterator. The V8 check\n// is necessary to detect all Blink based browsers.\nlet hasV8BreakIterator: boolean;\n\n// We need a try/catch around the reference to `Intl`, because accessing it in some cases can\n// cause IE to throw. These cases are tied to particular versions of Windows and can happen if\n// the consumer is providing a polyfilled `Map`. See:\n// https://github.com/Microsoft/ChakraCore/issues/3189\n// https://github.com/angular/components/issues/15687\ntry {\n  hasV8BreakIterator = typeof Intl !== 'undefined' && (Intl as any).v8BreakIterator;\n} catch {\n  hasV8BreakIterator = false;\n}\n\n/** Whether the current browser is Microsoft Edge. */\nexport const isEdge = !isServer && /(edge)/i.test(navigator.userAgent);\n\n/** Whether the current rendering engine is Microsoft Trident. */\nexport const isTrident = !isServer && /(msie|trident)/i.test(navigator.userAgent);\n\n// EdgeHTML and Trident mock Blink specific things and need to be excluded from this check.\n/** Whether the current rendering engine is Blink. */\nexport const isBlink =\n  !isServer &&\n  !!((window as any).chrome || hasV8BreakIterator) &&\n  typeof CSS !== 'undefined' &&\n  !isEdge &&\n  !isTrident;\n\n// Webkit is part of the userAgent in EdgeHTML, Blink and Trident. Therefore, we need to\n// ensure that Webkit runs standalone and is not used as another engine's base.\n/** Whether the current rendering engine is WebKit. */\nexport const isWebkit =\n  !isServer && /AppleWebKit/i.test(navigator.userAgent) && !isBlink && !isEdge && !isTrident;\n\n/** Whether the current platform is Apple iOS. */\nexport const isIOS =\n  !isServer && /iPad|iPhone|iPod/.test(navigator.userAgent) && !('MSStream' in window);\n\n// It's difficult to detect the plain Gecko engine, because most of the browsers identify\n// them self as Gecko-like browsers and modify the userAgent's according to that.\n// Since we only cover one explicit Firefox case, we can simply check for Firefox\n// instead of having an unstable check for Gecko.\n/** Whether the current browser is Firefox. */\nexport const isFirefox = !isServer && /(firefox|minefield)/i.test(navigator.userAgent);\n\n/** Whether the current platform is Android. */\n// Trident on mobile adds the android platform to the userAgent to trick detections.\nexport const isAndroid = !isServer && /android/i.test(navigator.userAgent) && !isTrident;\n\n// Safari browsers will include the Safari keyword in their userAgent. Some browsers may fake\n// this and just place the Safari keyword in the userAgent. To be more safe about Safari every\n// Safari browser should also use Webkit as its layout engine.\n/** Whether the current browser is Safari. */\nexport const isSafari = !isServer && /safari/i.test(navigator.userAgent) && isWebkit;\n\n/**\n * We just check for the blink engine.\n */\nexport const isChromium = isBlink;\n\n/** Whether the application is being rendered in a Next.js environment. */\nexport const isNextjs = (): boolean => !!(globalThis as { next?: object }).next;\n","export function pageScrollDisabled(): boolean {\n  return document.body.hasAttribute('data-sbb-scroll-disabled');\n}\n\n/**\n * Handle the page scroll, allowing to disable/enable the window scroll avoiding a potential\n * content shift caused by the disappearance/appearance of the scrollbar.\n */\nexport class SbbScrollHandler {\n  private _position!: string;\n  private _overflow!: string;\n  private _marginInlineEnd!: string;\n\n  public disableScroll(): void {\n    if (pageScrollDisabled()) {\n      return;\n    }\n\n    // Save any pre-existing styles to reapply them to the body when enabling the scroll again.\n    this._position = document.body.style.position;\n    this._overflow = document.body.style.overflow;\n    this._marginInlineEnd = document.body.style.marginInlineEnd;\n\n    const scrollbarWidth = window.innerWidth - document.documentElement.clientWidth;\n\n    document.body.style.overflow = 'hidden';\n    document.body.style.position = 'relative';\n    document.body.style.marginInlineEnd = `${scrollbarWidth}px`;\n    document.body.style.setProperty('--sbb-scrollbar-width', `${scrollbarWidth}px`);\n\n    document.body.toggleAttribute('data-sbb-scroll-disabled', true);\n  }\n\n  public enableScroll(): void {\n    if (!pageScrollDisabled()) {\n      return;\n    }\n\n    // Revert body inline styles.\n    document.body.style.position = this._position || '';\n    document.body.style.overflow = this._overflow || '';\n    document.body.style.marginInlineEnd = this._marginInlineEnd || '';\n    document.body.style.setProperty('--sbb-scrollbar-width', '0');\n\n    document.body.removeAttribute('data-sbb-scroll-disabled');\n  }\n}\n","import type { LitElement } from 'lit';\n\nconst localNameCache = new Map<unknown, string>();\n\n/**\n * In SSR the local/tag name is not available on the class instance, but it is available\n * in the shim customElements registry.\n *\n * https://github.com/lit/lit/blob/main/packages/labs/ssr-dom-shim/src.ts (See CustomElementRegistryShim)\n *\n * Can be removed once https://github.com/lit/lit/pull/4553 is merged/released.\n *\n * @deprecated Will be removed with next major version\n */\nexport function getLocalName(element: LitElement): string {\n  if (localNameCache.has(element.constructor)) {\n    return localNameCache.get(element.constructor)!;\n  }\n\n  const definitions = // eslint-disable-next-line @typescript-eslint/naming-convention\n    (customElements as unknown as { __definitions: Map<string, { ctor: unknown }> }).__definitions;\n  for (const [key, value] of definitions) {\n    if (value.ctor === element.constructor) {\n      localNameCache.set(element.constructor, key);\n      return key;\n    }\n  }\n  throw new Error(`Given element ${element.constructor.name} has not been registered yet.`);\n}\n"],"names":[],"mappings":"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"}
141
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"dom.js","sources":["../../../../src/elements/core/dom/breakpoint.ts","../../../../src/elements/core/dom/find-referenced-element.ts","../../../../src/elements/core/dom/get-document-writing-mode.ts","../../../../src/elements/core/dom/host-context.ts","../../../../src/elements/core/dom/input-element.ts","../../../../src/elements/core/dom/set-or-remove-attribute.ts","../../../../src/elements/core/dom/platform.ts","../../../../src/elements/core/dom/scroll.ts","../../../../src/elements/core/dom/ssr.ts"],"sourcesContent":["import { isServer } from 'lit';\n\nexport const breakpoints = ['zero', 'micro', 'small', 'medium', 'wide', 'large', 'ultra'] as const;\nexport type Breakpoint = (typeof breakpoints)[number];\n\n/**\n * Checks whether the document matches a particular media query.\n * It will rely on the global CSS variables to determine the value of the breakpoints.\n *\n * @param from The breakpoint corresponding to the `min-width` value of the media query (optional).\n * @param to The breakpoint corresponding to the `max-width` value of the media query (optional).\n * @param properties Whether the max breakpoint should be included\n * @returns A boolean indicating whether the window matches the breakpoint.\n */\nexport function isBreakpoint(\n  from?: Breakpoint,\n  to?: Breakpoint,\n  properties?: { includeMaxBreakpoint: boolean },\n): boolean | null {\n  if (isServer) {\n    return null;\n  }\n\n  const computedStyle = getComputedStyle(document.documentElement);\n  const breakpointMin = from ? computedStyle.getPropertyValue(`--sbb-breakpoint-${from}-min`) : '';\n  const breakpointMax = to\n    ? `${\n        parseFloat(\n          computedStyle.getPropertyValue(\n            `--sbb-breakpoint-${to}-${properties?.includeMaxBreakpoint ? 'max' : 'min'}`,\n          ),\n        ) - (properties?.includeMaxBreakpoint ? 0 : 0.0625)\n      }rem`\n    : ''; // subtract 1px (0.0625rem) from the max-width breakpoint\n\n  const minWidth = breakpointMin && `(min-width: ${breakpointMin})`;\n  const maxWidth = breakpointMax && `(max-width: ${breakpointMax})`;\n  const and = breakpointMin && breakpointMax && ' and ';\n\n  return window.matchMedia(`${minWidth}${and}${maxWidth}`).matches;\n}\n","import { isServer } from 'lit';\n\n/**\n *  Check whether it's a string or an HTMLElement, if it's a string queries the element with the\n *  corresponding id.\n *  @param reference either the wanted id or the HTMLElement\n */\nexport function findReferencedElement<T extends HTMLElement = HTMLElement>(\n  reference: string | HTMLElement,\n): T | null {\n  if (isServer) {\n    return null;\n  } else if (typeof reference === 'string') {\n    return document.getElementById(reference) as T;\n  } else if (reference instanceof window.Element) {\n    return reference as T;\n  }\n  return null;\n}\n","import { isServer } from 'lit';\n\n/**\n * @deprecated use :dir() selector instead\n */\nexport const getDocumentWritingMode = (): string =>\n  (!isServer && document.documentElement.getAttribute('dir')) || 'ltr';\n","import { isServer } from 'lit';\n\n/**\n * Looks for the closest element matching the given selector starting from the given element.\n * Returns null, if none of the ancestor match.\n *\n * @param selector The selector to match ancestor against.\n * @param element The base element from which to start the search.\n * @returns The closest element matching the selector or null if none is found.\n */\nexport function hostContext(selector: string, element: Element): Element | null {\n  if (isServer) {\n    return null;\n  }\n  // Start with parent element in order to avoid finding element itself\n  element = element.parentElement ?? (element.getRootNode() as ShadowRoot).host;\n  while (element && (element as any) !== document && (element as any) !== window) {\n    const match = element.closest(selector);\n    if (match) {\n      return match;\n    }\n\n    element = (element.getRootNode() as ShadowRoot).host;\n  }\n\n  return null;\n}\n\n// A list of elements that should not allow another anchor or button element inside them.\n// Needs to be extended if additional elements fall into this category.\nexport const ACTION_ELEMENTS = 'a,button,sbb-teaser-hero,sbb-teaser';\n","import { findReferencedElement } from './find-referenced-element.js';\n\n/**\n * Given an element, returns the related input reference, if it exists respecting following priority.\n * 1. Input field in `sbb-form-field` (if trigger is undefiend)\n * 2. Input referenced by id (trigger is string)\n * 3. Input referenced directly (trigger is HTMLElement)\n * @param element The starting SbbDatepickerElement element.\n * @param trigger The id or the reference of the input.\n */\nexport function findInput(\n  element: HTMLElement,\n  trigger?: string | HTMLElement | null,\n): HTMLInputElement | null {\n  if (!trigger) {\n    const parent = element.closest?.('sbb-form-field');\n    return parent?.querySelector('input') as HTMLInputElement | null;\n  }\n\n  return findReferencedElement<HTMLInputElement>(trigger);\n}\n","/**\n * Set the attribute only if value is not 'false', otherwise remove attribute.\n * @param element The element that will have the attribute\n * @param attribute The attribute name\n * @param value The attribute value\n */\nexport function setOrRemoveAttribute(element: HTMLElement, attribute: string, value?: any): void {\n  if (!value) {\n    element.removeAttribute(attribute);\n  } else {\n    element.setAttribute(attribute, value);\n  }\n}\n","// This file is freely inspired by Angular Material solution.\n// Reference: https://github.com/angular/components/blob/main/src/cdk/platform/platform.ts\nimport { isServer } from 'lit';\n\n// Whether the current platform supports the V8 Break Iterator. The V8 check\n// is necessary to detect all Blink based browsers.\nlet hasV8BreakIterator: boolean;\n\n// We need a try/catch around the reference to `Intl`, because accessing it in some cases can\n// cause IE to throw. These cases are tied to particular versions of Windows and can happen if\n// the consumer is providing a polyfilled `Map`. See:\n// https://github.com/Microsoft/ChakraCore/issues/3189\n// https://github.com/angular/components/issues/15687\ntry {\n  hasV8BreakIterator = typeof Intl !== 'undefined' && (Intl as any).v8BreakIterator;\n} catch {\n  hasV8BreakIterator = false;\n}\n\n/** Whether the current browser is Microsoft Edge. */\nexport const isEdge = !isServer && /(edge)/i.test(navigator.userAgent);\n\n/** Whether the current rendering engine is Microsoft Trident. */\nexport const isTrident = !isServer && /(msie|trident)/i.test(navigator.userAgent);\n\n// EdgeHTML and Trident mock Blink specific things and need to be excluded from this check.\n/** Whether the current rendering engine is Blink. */\nexport const isBlink =\n  !isServer &&\n  !!((window as any).chrome || hasV8BreakIterator) &&\n  typeof CSS !== 'undefined' &&\n  !isEdge &&\n  !isTrident;\n\n// Webkit is part of the userAgent in EdgeHTML, Blink and Trident. Therefore, we need to\n// ensure that Webkit runs standalone and is not used as another engine's base.\n/** Whether the current rendering engine is WebKit. */\nexport const isWebkit =\n  !isServer && /AppleWebKit/i.test(navigator.userAgent) && !isBlink && !isEdge && !isTrident;\n\n/** Whether the current platform is Apple iOS. */\nexport const isIOS =\n  !isServer && /iPad|iPhone|iPod/.test(navigator.userAgent) && !('MSStream' in window);\n\n// It's difficult to detect the plain Gecko engine, because most of the browsers identify\n// them self as Gecko-like browsers and modify the userAgent's according to that.\n// Since we only cover one explicit Firefox case, we can simply check for Firefox\n// instead of having an unstable check for Gecko.\n/** Whether the current browser is Firefox. */\nexport const isFirefox = !isServer && /(firefox|minefield)/i.test(navigator.userAgent);\n\n/** Whether the current platform is Android. */\n// Trident on mobile adds the android platform to the userAgent to trick detections.\nexport const isAndroid = !isServer && /android/i.test(navigator.userAgent) && !isTrident;\n\n// Safari browsers will include the Safari keyword in their userAgent. Some browsers may fake\n// this and just place the Safari keyword in the userAgent. To be more safe about Safari every\n// Safari browser should also use Webkit as its layout engine.\n/** Whether the current browser is Safari. */\nexport const isSafari = !isServer && /safari/i.test(navigator.userAgent) && isWebkit;\n\n/**\n * We just check for the blink engine.\n */\nexport const isChromium = isBlink;\n\n/** Whether the application is being rendered in a Next.js environment. */\nexport const isNextjs = (): boolean => !!(globalThis as { next?: object }).next;\n","export function pageScrollDisabled(): boolean {\n  return document.body.hasAttribute('data-sbb-scroll-disabled');\n}\n\n/**\n * Handle the page scroll, allowing to disable/enable the window scroll avoiding a potential\n * content shift caused by the disappearance/appearance of the scrollbar.\n */\nexport class SbbScrollHandler {\n  private _position!: string;\n  private _overflow!: string;\n  private _marginInlineEnd!: string;\n\n  public disableScroll(): void {\n    if (pageScrollDisabled()) {\n      return;\n    }\n\n    // Save any pre-existing styles to reapply them to the body when enabling the scroll again.\n    this._position = document.body.style.position;\n    this._overflow = document.body.style.overflow;\n    this._marginInlineEnd = document.body.style.marginInlineEnd;\n\n    const scrollbarWidth = window.innerWidth - document.documentElement.clientWidth;\n\n    document.body.style.overflow = 'hidden';\n    document.body.style.position = 'relative';\n    document.body.style.marginInlineEnd = `${scrollbarWidth}px`;\n    document.body.style.setProperty('--sbb-scrollbar-width', `${scrollbarWidth}px`);\n\n    document.body.toggleAttribute('data-sbb-scroll-disabled', true);\n  }\n\n  public enableScroll(): void {\n    if (!pageScrollDisabled()) {\n      return;\n    }\n\n    // Revert body inline styles.\n    document.body.style.position = this._position || '';\n    document.body.style.overflow = this._overflow || '';\n    document.body.style.marginInlineEnd = this._marginInlineEnd || '';\n    document.body.style.setProperty('--sbb-scrollbar-width', '0');\n\n    document.body.removeAttribute('data-sbb-scroll-disabled');\n  }\n}\n","import type { LitElement } from 'lit';\n\nconst localNameCache = new Map<unknown, string>();\n\n/**\n * In SSR the local/tag name is not available on the class instance, but it is available\n * in the shim customElements registry.\n *\n * https://github.com/lit/lit/blob/main/packages/labs/ssr-dom-shim/src.ts (See CustomElementRegistryShim)\n *\n * Can be removed once https://github.com/lit/lit/pull/4553 is merged/released.\n *\n * @deprecated Will be removed with next major version\n */\nexport function getLocalName(element: LitElement): string {\n  if (localNameCache.has(element.constructor)) {\n    return localNameCache.get(element.constructor)!;\n  }\n\n  const definitions = // eslint-disable-next-line @typescript-eslint/naming-convention\n    (customElements as unknown as { __definitions: Map<string, { ctor: unknown }> }).__definitions;\n  for (const [key, value] of definitions) {\n    if (value.ctor === element.constructor) {\n      localNameCache.set(element.constructor, key);\n      return key;\n    }\n  }\n  throw new Error(`Given element ${element.constructor.name} has not been registered yet.`);\n}\n"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"form-associated-checkbox-mixin.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/mixins/form-associated-checkbox-mixin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,KAAK,UAAU,EAAE,MAAM,KAAK,CAAC;AAMxD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAoB,KAAK,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAClF,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EAErB,KAAK,0BAA0B,EAChC,MAAM,4BAA4B,CAAC;AACpC,OAAO,EAAoB,KAAK,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAIlF,MAAM,CAAC,OAAO,CAAC,QAAQ,OAAO,kCAC5B,SAAQ,0BACR,YAAW,OAAO,CAAC,oBAAoB,CAAC,EAAE,OAAO,CAAC,oBAAoB,CAAC;IAEvE,IAAW,OAAO,IAAI,OAAO,CAAC;IAC9B,IAAW,OAAO,CAAC,KAAK,EAAE,OAAO,EAAE;IAEnC,IAAW,QAAQ,CAAC,KAAK,EAAE,OAAO,EAAE;IACpC,IAAW,QAAQ,IAAI,OAAO,CAAC;IAE/B,IAAW,QAAQ,CAAC,KAAK,EAAE,OAAO,EAAE;IACpC,IAAW,QAAQ,IAAI,OAAO,CAAC;IAExB,iBAAiB,IAAI,IAAI;IACzB,wBAAwB,CAAC,KAAK,EAAE,gBAAgB,GAAG,IAAI,EAAE,MAAM,EAAE,iBAAiB,GAAG,IAAI;IAEhG,SAAS,CAAC,oBAAoB,IAAI,OAAO;IACzC,SAAS,CAAC,oBAAoB,IAAI,OAAO;IACzC,SAAS,CAAC,mBAAmB,CAAC,IAAI,IAAI;IACtC,SAAS,CAAC,eAAe,IAAI,IAAI;CAClC;AAED;;;;GAIG;AAEH,eAAO,MAAM,8BAA8B,GAAI,CAAC,SAAS,WAAW,CAAC,UAAU,CAAC,cAClE,CAAC,KACZ,WAAW,CAAC,kCAAkC,CAAC,GAAG,CA6IpD,CAAC"}
1
+ {"version":3,"file":"form-associated-checkbox-mixin.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/mixins/form-associated-checkbox-mixin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,KAAK,UAAU,EAAE,MAAM,KAAK,CAAC;AAMxD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAoB,KAAK,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAClF,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EAErB,KAAK,0BAA0B,EAChC,MAAM,4BAA4B,CAAC;AACpC,OAAO,EAAoB,KAAK,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAIlF,MAAM,CAAC,OAAO,CAAC,QAAQ,OAAO,kCAC5B,SAAQ,0BACR,YAAW,OAAO,CAAC,oBAAoB,CAAC,EAAE,OAAO,CAAC,oBAAoB,CAAC;IAEvE,IAAW,OAAO,IAAI,OAAO,CAAC;IAC9B,IAAW,OAAO,CAAC,KAAK,EAAE,OAAO,EAAE;IAEnC,IAAW,QAAQ,CAAC,KAAK,EAAE,OAAO,EAAE;IACpC,IAAW,QAAQ,IAAI,OAAO,CAAC;IAE/B,IAAW,QAAQ,CAAC,KAAK,EAAE,OAAO,EAAE;IACpC,IAAW,QAAQ,IAAI,OAAO,CAAC;IAExB,iBAAiB,IAAI,IAAI;IACzB,wBAAwB,CAAC,KAAK,EAAE,gBAAgB,GAAG,IAAI,EAAE,MAAM,EAAE,iBAAiB,GAAG,IAAI;IAEhG,SAAS,CAAC,oBAAoB,IAAI,OAAO;IACzC,SAAS,CAAC,oBAAoB,IAAI,OAAO;IACzC,SAAS,CAAC,mBAAmB,CAAC,IAAI,IAAI;IACtC,SAAS,CAAC,eAAe,IAAI,IAAI;CAClC;AAED;;;;GAIG;AAEH,eAAO,MAAM,8BAA8B,GAAI,CAAC,SAAS,WAAW,CAAC,UAAU,CAAC,cAClE,CAAC,KACZ,WAAW,CAAC,kCAAkC,CAAC,GAAG,CAqJpD,CAAC"}