@sbb-esta/lyne-elements 0.52.2 → 1.0.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 (181) hide show
  1. package/checkbox/checkbox/checkbox.d.ts +3 -46
  2. package/checkbox/checkbox/checkbox.d.ts.map +1 -1
  3. package/checkbox/checkbox-group/checkbox-group.d.ts +4 -2
  4. package/checkbox/checkbox-group/checkbox-group.d.ts.map +1 -1
  5. package/checkbox/checkbox-group.js +11 -8
  6. package/checkbox/checkbox-panel/checkbox-panel.d.ts +41 -0
  7. package/checkbox/checkbox-panel/checkbox-panel.d.ts.map +1 -0
  8. package/checkbox/checkbox-panel.d.ts +2 -0
  9. package/checkbox/checkbox-panel.d.ts.map +1 -0
  10. package/checkbox/checkbox-panel.js +67 -0
  11. package/checkbox/checkbox.js +26 -103
  12. package/checkbox/common/checkbox-common.d.ts +13 -0
  13. package/checkbox/common/checkbox-common.d.ts.map +1 -0
  14. package/checkbox/common.d.ts +2 -0
  15. package/checkbox/common.d.ts.map +1 -0
  16. package/checkbox/common.js +52 -0
  17. package/checkbox.d.ts +2 -0
  18. package/checkbox.d.ts.map +1 -1
  19. package/checkbox.js +2 -0
  20. package/core/mixins/panel-mixin.d.ts +13 -0
  21. package/core/mixins/panel-mixin.d.ts.map +1 -0
  22. package/core/mixins.d.ts +1 -0
  23. package/core/mixins.d.ts.map +1 -1
  24. package/core/mixins.js +120 -89
  25. package/core/styles/node_modules_@sbb-esta_lyne-design-tokens_dist_scss_sbb-variables_css--mixin.scss +1 -1
  26. package/core.css +1 -1
  27. package/custom-elements.json +8862 -6904
  28. package/development/checkbox/checkbox/checkbox.d.ts +3 -46
  29. package/development/checkbox/checkbox/checkbox.d.ts.map +1 -1
  30. package/development/checkbox/checkbox-group/checkbox-group.d.ts +4 -2
  31. package/development/checkbox/checkbox-group/checkbox-group.d.ts.map +1 -1
  32. package/development/checkbox/checkbox-group.js +43 -13
  33. package/development/checkbox/checkbox-panel/checkbox-panel.d.ts +41 -0
  34. package/development/checkbox/checkbox-panel/checkbox-panel.d.ts.map +1 -0
  35. package/development/checkbox/checkbox-panel.d.ts +2 -0
  36. package/development/checkbox/checkbox-panel.d.ts.map +1 -0
  37. package/development/checkbox/checkbox-panel.js +86 -0
  38. package/development/checkbox/checkbox.js +19 -239
  39. package/development/checkbox/common/checkbox-common.d.ts +13 -0
  40. package/development/checkbox/common/checkbox-common.d.ts.map +1 -0
  41. package/development/checkbox/common.d.ts +2 -0
  42. package/development/checkbox/common.d.ts.map +1 -0
  43. package/development/checkbox/common.js +156 -0
  44. package/development/checkbox.d.ts +2 -0
  45. package/development/checkbox.d.ts.map +1 -1
  46. package/development/checkbox.js +3 -1
  47. package/development/core/mixins/panel-mixin.d.ts +13 -0
  48. package/development/core/mixins/panel-mixin.d.ts.map +1 -0
  49. package/development/core/mixins.d.ts +1 -0
  50. package/development/core/mixins.d.ts.map +1 -1
  51. package/development/core/mixins.js +187 -31
  52. package/development/image.js +1 -1
  53. package/development/radio-button/common/radio-button-common.d.ts +22 -0
  54. package/development/radio-button/common/radio-button-common.d.ts.map +1 -0
  55. package/development/radio-button/common.d.ts +2 -0
  56. package/development/radio-button/common.d.ts.map +1 -0
  57. package/development/radio-button/common.js +294 -0
  58. package/development/radio-button/radio-button/radio-button.d.ts +2 -81
  59. package/development/radio-button/radio-button/radio-button.d.ts.map +1 -1
  60. package/development/radio-button/radio-button-group/radio-button-group.d.ts +6 -4
  61. package/development/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  62. package/development/radio-button/radio-button-group.js +55 -23
  63. package/development/radio-button/radio-button-panel/index.d.ts +2 -0
  64. package/development/radio-button/radio-button-panel/index.d.ts.map +1 -0
  65. package/development/radio-button/radio-button-panel/radio-button-panel.d.ts +29 -0
  66. package/development/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -0
  67. package/development/radio-button/radio-button-panel.d.ts +2 -0
  68. package/development/radio-button/radio-button-panel.d.ts.map +1 -0
  69. package/development/radio-button/radio-button-panel.js +69 -0
  70. package/development/radio-button/radio-button.js +10 -324
  71. package/development/radio-button.d.ts +2 -0
  72. package/development/radio-button.d.ts.map +1 -1
  73. package/development/radio-button.js +3 -1
  74. package/{selection-panel/selection-panel.d.ts → development/selection-expansion-panel/selection-expansion-panel.d.ts} +9 -7
  75. package/development/selection-expansion-panel/selection-expansion-panel.d.ts.map +1 -0
  76. package/development/selection-expansion-panel.d.ts +2 -0
  77. package/development/selection-expansion-panel.d.ts.map +1 -0
  78. package/development/selection-expansion-panel.js +340 -0
  79. package/development/tabs/tab/index.d.ts +2 -0
  80. package/development/tabs/tab/index.d.ts.map +1 -0
  81. package/development/tabs/tab/tab.d.ts +24 -0
  82. package/development/tabs/tab/tab.d.ts.map +1 -0
  83. package/development/tabs/tab-group/tab-group.d.ts +20 -15
  84. package/development/tabs/tab-group/tab-group.d.ts.map +1 -1
  85. package/development/tabs/tab-group.js +24 -14
  86. package/development/tabs/{tab-title/tab-title.d.ts → tab-label/tab-label.d.ts} +4 -4
  87. package/development/tabs/{tab-title/tab-title.d.ts.map → tab-label/tab-label.d.ts.map} +1 -1
  88. package/development/tabs/tab-label.d.ts +2 -0
  89. package/development/tabs/tab-label.d.ts.map +1 -0
  90. package/development/tabs/{tab-title.js → tab-label.js} +86 -86
  91. package/development/tabs/tab.d.ts +2 -0
  92. package/development/tabs/tab.d.ts.map +1 -0
  93. package/development/tabs/tab.js +71 -0
  94. package/development/tabs.d.ts +2 -1
  95. package/development/tabs.d.ts.map +1 -1
  96. package/development/tabs.js +3 -2
  97. package/development/train/train-formation/train-formation.d.ts.map +1 -1
  98. package/development/train/train-formation.js +12 -12
  99. package/index.d.ts +10 -8
  100. package/index.js +10 -8
  101. package/package.json +34 -19
  102. package/radio-button/common/radio-button-common.d.ts +22 -0
  103. package/radio-button/common/radio-button-common.d.ts.map +1 -0
  104. package/radio-button/common.d.ts +2 -0
  105. package/radio-button/common.d.ts.map +1 -0
  106. package/radio-button/common.js +105 -0
  107. package/radio-button/radio-button/radio-button.d.ts +2 -81
  108. package/radio-button/radio-button/radio-button.d.ts.map +1 -1
  109. package/radio-button/radio-button-group/radio-button-group.d.ts +6 -4
  110. package/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  111. package/radio-button/radio-button-group.js +64 -58
  112. package/radio-button/radio-button-panel/index.d.ts +2 -0
  113. package/radio-button/radio-button-panel/index.d.ts.map +1 -0
  114. package/radio-button/radio-button-panel/radio-button-panel.d.ts +29 -0
  115. package/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -0
  116. package/radio-button/radio-button-panel.d.ts +2 -0
  117. package/radio-button/radio-button-panel.d.ts.map +1 -0
  118. package/radio-button/radio-button-panel.js +59 -0
  119. package/radio-button/radio-button.js +20 -143
  120. package/radio-button.d.ts +2 -0
  121. package/radio-button.d.ts.map +1 -1
  122. package/radio-button.js +2 -0
  123. package/{development/selection-panel/selection-panel.d.ts → selection-expansion-panel/selection-expansion-panel.d.ts} +9 -7
  124. package/selection-expansion-panel/selection-expansion-panel.d.ts.map +1 -0
  125. package/selection-expansion-panel.d.ts +2 -0
  126. package/selection-expansion-panel.d.ts.map +1 -0
  127. package/selection-expansion-panel.js +146 -0
  128. package/standard-theme.css +1 -1
  129. package/tabs/tab/index.d.ts +2 -0
  130. package/tabs/tab/index.d.ts.map +1 -0
  131. package/tabs/tab/tab.d.ts +24 -0
  132. package/tabs/tab/tab.d.ts.map +1 -0
  133. package/tabs/tab-group/tab-group.d.ts +20 -15
  134. package/tabs/tab-group/tab-group.d.ts.map +1 -1
  135. package/tabs/tab-group.js +39 -29
  136. package/tabs/{tab-title/tab-title.d.ts → tab-label/tab-label.d.ts} +4 -4
  137. package/tabs/{tab-title/tab-title.d.ts.map → tab-label/tab-label.d.ts.map} +1 -1
  138. package/tabs/tab-label.d.ts +2 -0
  139. package/tabs/tab-label.d.ts.map +1 -0
  140. package/tabs/tab-label.js +51 -0
  141. package/tabs/tab.d.ts +2 -0
  142. package/tabs/tab.d.ts.map +1 -0
  143. package/tabs/tab.js +41 -0
  144. package/tabs.d.ts +2 -1
  145. package/tabs.d.ts.map +1 -1
  146. package/tabs.js +2 -1
  147. package/train/train-formation/train-formation.d.ts.map +1 -1
  148. package/train/train-formation.js +32 -32
  149. package/development/selection-panel/selection-panel.d.ts.map +0 -1
  150. package/development/selection-panel.d.ts +0 -2
  151. package/development/selection-panel.d.ts.map +0 -1
  152. package/development/selection-panel.js +0 -376
  153. package/development/tabs/tab-title.d.ts +0 -2
  154. package/development/tabs/tab-title.d.ts.map +0 -1
  155. package/development/teaser-hero/teaser-hero.d.ts +0 -26
  156. package/development/teaser-hero/teaser-hero.d.ts.map +0 -1
  157. package/development/teaser-hero.d.ts +0 -2
  158. package/development/teaser-hero.d.ts.map +0 -1
  159. package/development/teaser-hero.js +0 -181
  160. package/development/teaser-paid/teaser-paid.d.ts +0 -20
  161. package/development/teaser-paid/teaser-paid.d.ts.map +0 -1
  162. package/development/teaser-paid.d.ts +0 -2
  163. package/development/teaser-paid.d.ts.map +0 -1
  164. package/development/teaser-paid.js +0 -91
  165. package/selection-panel/selection-panel.d.ts.map +0 -1
  166. package/selection-panel.d.ts +0 -2
  167. package/selection-panel.d.ts.map +0 -1
  168. package/selection-panel.js +0 -138
  169. package/tabs/tab-title.d.ts +0 -2
  170. package/tabs/tab-title.d.ts.map +0 -1
  171. package/tabs/tab-title.js +0 -51
  172. package/teaser-hero/teaser-hero.d.ts +0 -26
  173. package/teaser-hero/teaser-hero.d.ts.map +0 -1
  174. package/teaser-hero.d.ts +0 -2
  175. package/teaser-hero.d.ts.map +0 -1
  176. package/teaser-hero.js +0 -51
  177. package/teaser-paid/teaser-paid.d.ts +0 -20
  178. package/teaser-paid/teaser-paid.d.ts.map +0 -1
  179. package/teaser-paid.d.ts +0 -2
  180. package/teaser-paid.d.ts.map +0 -1
  181. package/teaser-paid.js +0 -28
@@ -1,17 +1,17 @@
1
1
  import { property, state } from "lit/decorators.js";
2
- import { defaultConverter, isServer, html, nothing } from "lit";
2
+ import { defaultConverter, isServer, html, nothing, css } from "lit";
3
3
  import { hostAttributes } from "./decorators.js";
4
- import { preventScrollOnSpacebarPress, forwardEventToHost } from "./eventing.js";
4
+ import { preventScrollOnSpacebarPress, forwardEventToHost, EventEmitter } from "./eventing.js";
5
5
  import { getLocalName } from "./dom.js";
6
6
  import "../screen-reader-only.js";
7
- var __defProp$5 = Object.defineProperty;
7
+ var __defProp$6 = Object.defineProperty;
8
8
  var __getOwnPropDesc$3 = Object.getOwnPropertyDescriptor;
9
- var __decorateClass$5 = (decorators, target, key, kind) => {
9
+ var __decorateClass$6 = (decorators, target, key, kind) => {
10
10
  var result = __getOwnPropDesc$3(target, key);
11
11
  for (var i = decorators.length - 1, decorator; i >= 0; i--)
12
12
  if (decorator = decorators[i])
13
13
  result = decorator(target, key, result) || result;
14
- if (result) __defProp$5(target, key, result);
14
+ if (result) __defProp$6(target, key, result);
15
15
  return result;
16
16
  };
17
17
  const SbbDisabledMixin = (superClass) => {
@@ -34,7 +34,7 @@ const SbbDisabledMixin = (superClass) => {
34
34
  return false;
35
35
  }
36
36
  }
37
- __decorateClass$5([
37
+ __decorateClass$6([
38
38
  property({ reflect: true, type: Boolean })
39
39
  ], SbbDisabledElement.prototype, "disabled");
40
40
  return SbbDisabledElement;
@@ -57,14 +57,14 @@ const SbbDisabledTabIndexActionMixin = (superClass) => {
57
57
  }
58
58
  return SbbDisabledTabIndexAction;
59
59
  };
60
- var __defProp$4 = Object.defineProperty;
60
+ var __defProp$5 = Object.defineProperty;
61
61
  var __getOwnPropDesc$2 = Object.getOwnPropertyDescriptor;
62
- var __decorateClass$4 = (decorators, target, key, kind) => {
62
+ var __decorateClass$5 = (decorators, target, key, kind) => {
63
63
  var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$2(target, key) : target;
64
64
  for (var i = decorators.length - 1, decorator; i >= 0; i--)
65
65
  if (decorator = decorators[i])
66
66
  result = (kind ? decorator(target, key, result) : decorator(result)) || result;
67
- if (kind && result) __defProp$4(target, key, result);
67
+ if (kind && result) __defProp$5(target, key, result);
68
68
  return result;
69
69
  };
70
70
  const SbbFormAssociatedMixin = (superClass) => {
@@ -164,25 +164,25 @@ const SbbFormAssociatedMixin = (superClass) => {
164
164
  };
165
165
  _SbbFormAssociatedElement.formAssociated = true;
166
166
  let SbbFormAssociatedElement = _SbbFormAssociatedElement;
167
- __decorateClass$4([
167
+ __decorateClass$5([
168
168
  property()
169
169
  ], SbbFormAssociatedElement.prototype, "name", 1);
170
- __decorateClass$4([
170
+ __decorateClass$5([
171
171
  property()
172
172
  ], SbbFormAssociatedElement.prototype, "value", 1);
173
- __decorateClass$4([
173
+ __decorateClass$5([
174
174
  state()
175
175
  ], SbbFormAssociatedElement.prototype, "formDisabled", 2);
176
176
  return SbbFormAssociatedElement;
177
177
  };
178
- var __defProp$3 = Object.defineProperty;
178
+ var __defProp$4 = Object.defineProperty;
179
179
  var __getOwnPropDesc$1 = Object.getOwnPropertyDescriptor;
180
- var __decorateClass$3 = (decorators, target, key, kind) => {
180
+ var __decorateClass$4 = (decorators, target, key, kind) => {
181
181
  var result = __getOwnPropDesc$1(target, key);
182
182
  for (var i = decorators.length - 1, decorator; i >= 0; i--)
183
183
  if (decorator = decorators[i])
184
184
  result = decorator(target, key, result) || result;
185
- if (result) __defProp$3(target, key, result);
185
+ if (result) __defProp$4(target, key, result);
186
186
  return result;
187
187
  };
188
188
  const SbbRequiredMixin = (superClass) => {
@@ -211,19 +211,19 @@ const SbbRequiredMixin = (superClass) => {
211
211
  return false;
212
212
  }
213
213
  }
214
- __decorateClass$3([
214
+ __decorateClass$4([
215
215
  property({ reflect: true, type: Boolean })
216
216
  ], SbbRequiredElement.prototype, "required");
217
217
  return SbbRequiredElement;
218
218
  };
219
- var __defProp$2 = Object.defineProperty;
219
+ var __defProp$3 = Object.defineProperty;
220
220
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
221
- var __decorateClass$2 = (decorators, target, key, kind) => {
221
+ var __decorateClass$3 = (decorators, target, key, kind) => {
222
222
  var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
223
223
  for (var i = decorators.length - 1, decorator; i >= 0; i--)
224
224
  if (decorator = decorators[i])
225
225
  result = (kind ? decorator(target, key, result) : decorator(result)) || result;
226
- if (kind && result) __defProp$2(target, key, result);
226
+ if (kind && result) __defProp$3(target, key, result);
227
227
  return result;
228
228
  };
229
229
  const SbbFormAssociatedCheckboxMixin = (superClass) => {
@@ -313,7 +313,7 @@ const SbbFormAssociatedCheckboxMixin = (superClass) => {
313
313
  }
314
314
  }
315
315
  };
316
- __decorateClass$2([
316
+ __decorateClass$3([
317
317
  property({
318
318
  type: Boolean,
319
319
  converter: {
@@ -327,7 +327,7 @@ const SbbFormAssociatedCheckboxMixin = (superClass) => {
327
327
  }
328
328
  })
329
329
  ], SbbFormAssociatedCheckboxElement.prototype, "checked", 1);
330
- SbbFormAssociatedCheckboxElement = __decorateClass$2([
330
+ SbbFormAssociatedCheckboxElement = __decorateClass$3([
331
331
  hostAttributes({
332
332
  tabindex: "0"
333
333
  })
@@ -410,13 +410,13 @@ const SbbHydrationMixin = (base) => {
410
410
  }
411
411
  return SbbHydrationMixinClass;
412
412
  };
413
- var __defProp$1 = Object.defineProperty;
414
- var __decorateClass$1 = (decorators, target, key, kind) => {
413
+ var __defProp$2 = Object.defineProperty;
414
+ var __decorateClass$2 = (decorators, target, key, kind) => {
415
415
  var result = void 0;
416
416
  for (var i = decorators.length - 1, decorator; i >= 0; i--)
417
417
  if (decorator = decorators[i])
418
418
  result = decorator(target, key, result) || result;
419
- if (result) __defProp$1(target, key, result);
419
+ if (result) __defProp$2(target, key, result);
420
420
  return result;
421
421
  };
422
422
  const SSR_CHILD_COUNT_ATTRIBUTE = "data-ssr-child-count";
@@ -505,18 +505,18 @@ const SbbNamedSlotListMixin = (superClass) => {
505
505
  return html`<span hidden><slot></slot></span>`;
506
506
  }
507
507
  }
508
- __decorateClass$1([
508
+ __decorateClass$2([
509
509
  state()
510
510
  ], NamedSlotListElement.prototype, "listChildren");
511
511
  return NamedSlotListElement;
512
512
  };
513
- var __defProp = Object.defineProperty;
514
- var __decorateClass = (decorators, target, key, kind) => {
513
+ var __defProp$1 = Object.defineProperty;
514
+ var __decorateClass$1 = (decorators, target, key, kind) => {
515
515
  var result = void 0;
516
516
  for (var i = decorators.length - 1, decorator; i >= 0; i--)
517
517
  if (decorator = decorators[i])
518
518
  result = decorator(target, key, result) || result;
519
- if (result) __defProp(target, key, result);
519
+ if (result) __defProp$1(target, key, result);
520
520
  return result;
521
521
  };
522
522
  const SbbNegativeMixin = (superClass) => {
@@ -526,11 +526,52 @@ const SbbNegativeMixin = (superClass) => {
526
526
  this.negative = false;
527
527
  }
528
528
  }
529
- __decorateClass([
529
+ __decorateClass$1([
530
530
  property({ reflect: true, type: Boolean })
531
531
  ], SbbNegativeElement.prototype, "negative");
532
532
  return SbbNegativeElement;
533
533
  };
534
+ var __defProp = Object.defineProperty;
535
+ var __decorateClass = (decorators, target, key, kind) => {
536
+ var result = void 0;
537
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
538
+ if (decorator = decorators[i])
539
+ result = decorator(target, key, result) || result;
540
+ if (result) __defProp(target, key, result);
541
+ return result;
542
+ };
543
+ const SbbPanelMixin = (superClass) => {
544
+ var _a;
545
+ const _SbbPanelElement = (_a = class extends superClass {
546
+ constructor() {
547
+ super(...arguments);
548
+ this.color = "white";
549
+ this.borderless = false;
550
+ this._panelConnected = new EventEmitter(
551
+ this,
552
+ _a.events.panelConnected,
553
+ { bubbles: true }
554
+ );
555
+ }
556
+ connectedCallback() {
557
+ super.connectedCallback();
558
+ this._panelConnected.emit();
559
+ }
560
+ }, _a.events = {
561
+ panelConnected: "panelConnected"
562
+ }, _a);
563
+ __decorateClass([
564
+ property()
565
+ ], _SbbPanelElement.prototype, "color");
566
+ __decorateClass([
567
+ property({ reflect: true, type: Boolean })
568
+ ], _SbbPanelElement.prototype, "borderless");
569
+ __decorateClass([
570
+ property()
571
+ ], _SbbPanelElement.prototype, "expansionState");
572
+ let SbbPanelElement = _SbbPanelElement;
573
+ return SbbPanelElement;
574
+ };
534
575
  const SbbUpdateSchedulerMixin = (base) => {
535
576
  class SbbUpdateSchedulerElement extends base {
536
577
  constructor() {
@@ -553,6 +594,119 @@ const SbbUpdateSchedulerMixin = (base) => {
553
594
  }
554
595
  return SbbUpdateSchedulerElement;
555
596
  };
597
+ const panelCommon = css`/**
598
+ * Better font rendering (on OS X)
599
+ * http://maximilianhoffmann.com/posts/better-font-rendering-on-osx
600
+ *
601
+ * Usage:
602
+ *
603
+ * .var_dark_on_light {
604
+ * @include font-smoothing;
605
+ * }
606
+ * .var_light_on_dark {
607
+ * @include font-smoothing-reset;
608
+ * }
609
+ */
610
+ /** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
611
+ :host {
612
+ --sbb-selection-panel-background: var(
613
+ --sbb-selection-expansion-panel-inner-background,
614
+ var(--sbb-color-white)
615
+ );
616
+ --sbb-selection-panel-border-color: var(--sbb-color-cloud);
617
+ --sbb-selection-panel-border-radius: var(
618
+ --sbb-selection-expansion-panel-border-radius,
619
+ var(--sbb-border-radius-4x)
620
+ );
621
+ --sbb-selection-panel-border-width: var(
622
+ --sbb-selection-expansion-panel-inner-border-width,
623
+ var(--sbb-border-width-1x)
624
+ );
625
+ --sbb-selection-panel-input-padding: var(--sbb-spacing-responsive-xs)
626
+ var(--sbb-spacing-responsive-xxs);
627
+ --sbb-selection-panel-animation-duration: var(
628
+ --sbb-disable-animation-zero-time,
629
+ var(--sbb-animation-duration-4x)
630
+ );
631
+ --sbb-selection-panel-cursor: pointer;
632
+ --sbb-selection-panel-suffix-color: var(--sbb-color-charcoal);
633
+ --sbb-selection-panel-subtext-color: var(--sbb-color-granite);
634
+ display: block;
635
+ outline: none !important;
636
+ }
637
+
638
+ :host([color=milk]) {
639
+ --sbb-selection-panel-background: var(
640
+ --sbb-selection-expansion-panel-inner-background,
641
+ var(--sbb-color-milk)
642
+ );
643
+ }
644
+
645
+ :host([borderless]:not([data-checked])) {
646
+ --sbb-selection-panel-border-color: transparent;
647
+ }
648
+
649
+ :host(:is([data-checked]):not(:disabled, [disabled])) {
650
+ --sbb-selection-panel-border-color: var(--sbb-color-charcoal);
651
+ --sbb-selection-panel-border-width: var(
652
+ --sbb-selection-expansion-panel-inner-border-width,
653
+ var(--sbb-border-width-2x)
654
+ );
655
+ }
656
+
657
+ :host(:is(:disabled, [disabled])) {
658
+ --sbb-selection-panel-cursor: default;
659
+ }
660
+
661
+ .sbb-selection-panel {
662
+ display: block;
663
+ cursor: var(--sbb-selection-panel-cursor);
664
+ position: relative;
665
+ border-radius: var(--sbb-selection-panel-border-radius);
666
+ box-shadow: inset 0 0 0 var(--sbb-selection-panel-border-width) var(--sbb-selection-panel-border-color);
667
+ padding: var(--sbb-selection-panel-input-padding);
668
+ background-color: var(--sbb-selection-panel-background);
669
+ transition-duration: var(--sbb-selection-panel-animation-duration);
670
+ transition-timing-function: var(--sbb-animation-easing);
671
+ transition-property: box-shadow;
672
+ }
673
+ @media (forced-colors: active) {
674
+ .sbb-selection-panel::after {
675
+ content: "";
676
+ display: block;
677
+ position: absolute;
678
+ inset: 0;
679
+ pointer-events: none;
680
+ border: var(--sbb-selection-panel-border-width) solid var(--sbb-selection-panel-border-color);
681
+ border-radius: var(--sbb-selection-panel-border-radius);
682
+ }
683
+ }
684
+ :host(:focus-visible) .sbb-selection-panel {
685
+ outline-offset: var(--sbb-focus-outline-offset);
686
+ outline: var(--sbb-focus-outline-color) solid var(--sbb-focus-outline-width);
687
+ }
688
+
689
+ .sbb-selection-panel__badge {
690
+ user-select: none;
691
+ pointer-events: none;
692
+ position: absolute;
693
+ inset: 0;
694
+ border-radius: var(--sbb-selection-panel-border-radius);
695
+ overflow: hidden;
696
+ }
697
+
698
+ slot[name=suffix] {
699
+ color: var(--sbb-selection-panel-suffix-color);
700
+ }
701
+
702
+ slot[name=subtext] {
703
+ display: block;
704
+ color: var(--sbb-selection-panel-subtext-color);
705
+ padding-inline-start: var(--sbb-spacing-fixed-8x);
706
+ }
707
+ :host(:not([data-slot-names~=subtext])) slot[name=subtext] {
708
+ display: none;
709
+ }`;
556
710
  export {
557
711
  SbbDisabledMixin,
558
712
  SbbDisabledTabIndexActionMixin,
@@ -561,7 +715,9 @@ export {
561
715
  SbbHydrationMixin,
562
716
  SbbNamedSlotListMixin,
563
717
  SbbNegativeMixin,
718
+ SbbPanelMixin,
564
719
  SbbRequiredMixin,
565
- SbbUpdateSchedulerMixin
720
+ SbbUpdateSchedulerMixin,
721
+ panelCommon as panelCommonStyle
566
722
  };
567
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"mixins.js","sources":["../../../../src/elements/core/mixins/disabled-mixin.ts","../../../../src/elements/core/mixins/form-associated-mixin.ts","../../../../src/elements/core/mixins/required-mixin.ts","../../../../src/elements/core/mixins/form-associated-checkbox-mixin.ts","../../../../src/elements/core/mixins/hydration-mixin.ts","../../../../src/elements/core/mixins/named-slot-list-mixin.ts","../../../../src/elements/core/mixins/negative-mixin.ts","../../../../src/elements/core/mixins/update-scheduler-mixin.ts"],"sourcesContent":["import type { LitElement, PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport type { AbstractConstructor } from './constructor.js';\n\nexport declare class SbbDisabledMixinType {\n  public set disabled(value: boolean);\n  public get disabled(): boolean;\n  protected isDisabledExternally(): boolean;\n}\n\n/**\n * Enhance your component with a disabled property.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbDisabledMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbDisabledMixinType> & T => {\n  abstract class SbbDisabledElement extends superClass implements Partial<SbbDisabledMixinType> {\n    /** Whether the component is disabled. */\n    @property({ reflect: true, type: Boolean })\n    public set disabled(value: boolean) {\n      // To provide the same behavior as the native disabled state,\n      // any value is converted to a boolean.\n      this._disabled = Boolean(value);\n    }\n    public get disabled(): boolean {\n      return this._disabled || this.isDisabledExternally();\n    }\n    private _disabled: boolean = false;\n\n    /**\n     * Will be used as 'or' check to the current disabled state.\n     * Can e.g. be used to read disabled state of a group.\n     */\n    protected isDisabledExternally(): boolean {\n      return false;\n    }\n  }\n\n  return SbbDisabledElement as unknown as AbstractConstructor<SbbDisabledMixinType> & T;\n};\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbDisabledTabIndexActionMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbDisabledMixinType> & T => {\n  abstract class SbbDisabledTabIndexAction\n    extends SbbDisabledMixin(superClass)\n    implements SbbDisabledMixinType\n  {\n    protected override willUpdate(changedProperties: PropertyValues<this>): void {\n      super.willUpdate(changedProperties);\n\n      if (!changedProperties.has('disabled')) {\n        return;\n      }\n\n      // FIXME if tabindex is not needed in combination with aria-disabled,\n      //  use the SbbDisabledMixin and implement a different willUpdate method.\n      if (this.disabled) {\n        this.setAttribute('aria-disabled', 'true');\n        this.removeAttribute('tabindex');\n      } else {\n        this.removeAttribute('aria-disabled');\n        this.setAttribute('tabindex', '0');\n      }\n    }\n  }\n  return SbbDisabledTabIndexAction as AbstractConstructor<SbbDisabledMixinType> & T;\n};\n","import type { LitElement } from 'lit';\nimport { property, state } from 'lit/decorators.js';\n\nimport type { Constructor } from './constructor.js';\n\nexport declare abstract class SbbFormAssociatedMixinType {\n  public get form(): HTMLFormElement | null;\n  public get name(): string;\n  public set name(value: string);\n  public get type(): string;\n  public get value(): string | null;\n  public set value(value: string | null);\n\n  public get validity(): ValidityState;\n  public get validationMessage(): string;\n  public get willValidate(): boolean;\n\n  protected formDisabled: boolean;\n  protected readonly internals: ElementInternals;\n\n  public checkValidity(): boolean;\n  public reportValidity(): boolean;\n\n  public formAssociatedCallback?(form: HTMLFormElement | null): void;\n  public formDisabledCallback(disabled: boolean): void;\n  public abstract formResetCallback(): void;\n  public abstract formStateRestoreCallback(\n    state: FormRestoreState | null,\n    reason: FormRestoreReason,\n  ): void;\n\n  protected updateFormValue(): void;\n}\n\n/**\n * The FormAssociatedMixin enables native form support for custom controls.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbFormAssociatedMixin = <T extends Constructor<LitElement>>(\n  superClass: T,\n): Constructor<SbbFormAssociatedMixinType> & T => {\n  abstract class SbbFormAssociatedElement\n    extends superClass\n    implements Partial<SbbFormAssociatedMixinType>\n  {\n    public static formAssociated = true;\n\n    /**\n     * Returns the form owner of internals target element.\n     */\n    public get form(): HTMLFormElement | null {\n      return this.internals.form;\n    }\n\n    /**\n     * Name of the form element. Will be read from name attribute.\n     *\n     * @description Developer note: In this case updating the attribute must be synchronous.\n     * Due to this it is implemented as a getter/setter and the attributeChangedCallback() handles the diff check.\n     */\n    @property()\n    public set name(name: string) {\n      this.setAttribute('name', `${name}`);\n    }\n    public get name(): string {\n      return this.getAttribute('name') ?? '';\n    }\n\n    /** @internal */\n    public get type(): string {\n      return this.localName;\n    }\n\n    /** Value of the form element. */\n    @property()\n    public set value(value: string | null) {\n      this._value = value;\n      this.updateFormValue();\n    }\n    public get value(): string | null {\n      return this._value;\n    }\n    private _value: string | null = null;\n\n    /**\n     * Returns the ValidityState object for internals target element.\n     *\n     * @internal\n     */\n    public get validity(): ValidityState {\n      return this.internals.validity;\n    }\n\n    /**\n     * Returns the error message that would be shown to the user\n     * if internals target element was to be checked for validity.\n     *\n     * @internal\n     */\n    public get validationMessage(): string {\n      return this.internals.validationMessage;\n    }\n\n    /**\n     * Returns true if internals target element will be validated\n     * when the form is submitted; false otherwise.\n     *\n     * @internal\n     */\n    public get willValidate(): boolean {\n      return this.internals.willValidate;\n    }\n\n    /** @internal */\n    protected readonly internals: ElementInternals = this.attachInternals();\n\n    /** Whenever a surrounding form or fieldset is changing its disabled state. */\n    @state() protected formDisabled: boolean = false;\n\n    public override attributeChangedCallback(\n      name: string,\n      old: string | null,\n      value: string | null,\n    ): void {\n      if (name !== 'name' || old !== value) {\n        super.attributeChangedCallback(name, old, value);\n      }\n    }\n\n    /**\n     * Returns true if internals target element has no validity problems; false otherwise.\n     * Fires an invalid event at the element in the latter case.\n     *\n     * @internal\n     */\n    public checkValidity(): boolean {\n      return this.internals.checkValidity();\n    }\n\n    /**\n     * Returns true if internals target element has no validity problems; otherwise,\n     * returns false, fires an invalid event at the element,\n     * and (if the event isn't canceled) reports the problem to the user.\n     *\n     * @internal\n     */\n    public reportValidity(): boolean {\n      return this.internals.reportValidity();\n    }\n\n    /**\n     * Called when the associated form element changes.\n     * ElementInternals.form returns the associated from element.\n     *\n     * @internal\n     */\n    public formAssociatedCallback?(form: HTMLFormElement | null): void;\n\n    /**\n     * Is called whenever a surrounding form / fieldset changes disabled state.\n     * @param disabled\n     *\n     * @internal\n     */\n    public formDisabledCallback(disabled: boolean): void {\n      this.formDisabled = disabled;\n    }\n\n    /**\n     * Is called whenever the form is being reset.\n     *\n     * @internal\n     */\n    public abstract formResetCallback(): void;\n\n    /**\n     *  Called when the browser is trying to restore element’s state to state in which case\n     *  reason is “restore”, or when the browser is trying to fulfill autofill on behalf of\n     *  user in which case reason is “autocomplete”.\n     *  In the case of “restore”, state is a string, File, or FormData object\n     *  previously set as the second argument to setFormValue.\n     *\n     * @internal\n     */\n    public abstract formStateRestoreCallback(\n      state: FormRestoreState | null,\n      reason: FormRestoreReason,\n    ): void;\n\n    /** Should be called when form value is changed. */\n    protected updateFormValue(): void {\n      this.internals.setFormValue(this.value);\n    }\n  }\n  return SbbFormAssociatedElement as unknown as Constructor<SbbFormAssociatedMixinType> & T;\n};\n\n/**\n * A value to be restored for a component's form value. If a component's form\n * state is a `FormData` object, its entry list of name and values will be\n * provided.\n */\nexport type FormRestoreState = File | string | [string, FormDataEntryValue][];\n\n/**\n * The reason a form component is being restored for, either `'restore'` for\n * browser restoration or `'autocomplete'` for restoring user values.\n */\nexport type FormRestoreReason = 'restore' | 'autocomplete';\n","import type { LitElement, PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport type { AbstractConstructor } from './constructor.js';\nimport type { SbbFormAssociatedMixinType } from './form-associated-mixin.js';\n\nexport declare class SbbRequiredMixinType {\n  public set required(value: boolean);\n  public get required(): boolean;\n  protected isRequiredExternally(): boolean;\n}\n\n/**\n * Enhance your component with a required property.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbRequiredMixin = <\n  T extends AbstractConstructor<LitElement & SbbFormAssociatedMixinType>,\n>(\n  superClass: T,\n): AbstractConstructor<SbbRequiredMixinType> & T => {\n  abstract class SbbRequiredElement extends superClass implements Partial<SbbRequiredMixinType> {\n    /** Whether the component is required. */\n    @property({ reflect: true, type: Boolean })\n    public set required(value: boolean) {\n      // To provide the same behavior as the native required state,\n      // any value is converted to a boolean.\n      this._required = Boolean(value);\n    }\n    public get required(): boolean {\n      return this._required || this.isRequiredExternally();\n    }\n    private _required: boolean = false;\n\n    protected override async willUpdate(changedProperties: PropertyValues<this>): Promise<void> {\n      super.willUpdate(changedProperties);\n\n      if (changedProperties.has('required')) {\n        // Firefox needs explicitly set aria-required value.\n        this.internals.ariaRequired = `${this.required}`;\n      }\n    }\n\n    /**\n     * Will be used as 'or' check to the current required state.\n     * Can e.g. be used to read required state of a group.\n     */\n    protected isRequiredExternally(): boolean {\n      return false;\n    }\n  }\n\n  return SbbRequiredElement as unknown as AbstractConstructor<SbbRequiredMixinType> & T;\n};\n","import { defaultConverter, type LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { hostAttributes } from '../decorators.js';\nimport { preventScrollOnSpacebarPress } from '../eventing.js';\n\nimport type { Constructor } from './constructor.js';\nimport { SbbDisabledMixin, type SbbDisabledMixinType } from './disabled-mixin.js';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbFormAssociatedMixin,\n  type SbbFormAssociatedMixinType,\n} from './form-associated-mixin.js';\nimport { SbbRequiredMixin, type SbbRequiredMixinType } from './required-mixin.js';\n\ntype CheckedSetterValue = { value: boolean; attribute: boolean };\n\nexport declare abstract class SbbFormAssociatedCheckboxMixinType\n  extends SbbFormAssociatedMixinType\n  implements Partial<SbbDisabledMixinType>, Partial<SbbRequiredMixinType>\n{\n  public get checked(): boolean;\n  public set checked(value: boolean);\n\n  public set disabled(value: boolean);\n  public get disabled(): boolean;\n\n  public set required(value: boolean);\n  public get required(): boolean;\n\n  public formResetCallback(): void;\n  public formStateRestoreCallback(state: FormRestoreState | null, reason: FormRestoreReason): void;\n\n  protected isDisabledExternally(): boolean;\n  protected isRequiredExternally(): boolean;\n  protected withUserInteraction?(): void;\n}\n\n/**\n * The FormAssociatedCheckboxMixin enables native form support for checkbox controls.\n *\n * Inherited classes MUST implement the ariaChecked state (ElementInternals) themselves.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbFormAssociatedCheckboxMixin = <T extends Constructor<LitElement>>(\n  superClass: T,\n): Constructor<SbbFormAssociatedCheckboxMixinType> & T => {\n  @hostAttributes({\n    tabindex: '0',\n  })\n  abstract class SbbFormAssociatedCheckboxElement\n    extends SbbDisabledMixin(SbbRequiredMixin(SbbFormAssociatedMixin(superClass)))\n    implements Partial<SbbFormAssociatedCheckboxMixinType>\n  {\n    private _attributeMutationBlocked = false;\n\n    /** Whether the checkbox is checked. */\n    @property({\n      type: Boolean,\n      converter: {\n        ...defaultConverter,\n        // We need to pass information to the setter so that we know it was called by attribute change.\n        fromAttribute: (value: string | null, type?: unknown): CheckedSetterValue => {\n          const result = defaultConverter.fromAttribute?.(value, type);\n          return { value: result, attribute: true } as CheckedSetterValue;\n        },\n      },\n    })\n    public set checked(value: boolean) {\n      const attributeSetter =\n        typeof value === 'object' ? (value as unknown as CheckedSetterValue).attribute : false;\n      if (attributeSetter) {\n        value = (value as unknown as CheckedSetterValue).value;\n      }\n\n      // As soon as mutation was done not by setting attribute,\n      // we need to block syncing attribute.\n      if (this.hasUpdated && !attributeSetter) {\n        this._attributeMutationBlocked = true;\n      }\n      this._checked = Boolean(value);\n      this.updateFormValue();\n    }\n    public get checked(): boolean {\n      return this._checked;\n    }\n    private _checked = false;\n\n    protected constructor() {\n      super();\n      /** @internal */\n      this.internals.role = 'checkbox';\n    }\n\n    public override connectedCallback(): void {\n      super.connectedCallback();\n\n      this.addEventListener('click', this._handleUserInteraction);\n      this.addEventListener('keydown', preventScrollOnSpacebarPress);\n      this.addEventListener('keyup', this._handleKeyboardInteraction);\n    }\n\n    public override disconnectedCallback(): void {\n      super.disconnectedCallback();\n\n      this.removeEventListener('click', this._handleUserInteraction);\n      this.removeEventListener('keydown', preventScrollOnSpacebarPress);\n      this.removeEventListener('keyup', this._handleKeyboardInteraction);\n    }\n\n    public override attributeChangedCallback(\n      name: string,\n      old: string | null,\n      value: string | null,\n    ): void {\n      // Attribute should not be interpreted after programmatic or manual state change.\n      if (name !== 'checked' || !this._attributeMutationBlocked) {\n        super.attributeChangedCallback(name, old, value);\n      }\n    }\n\n    /**\n     * Is called whenever the form is being reset.\n     *\n     * @internal\n     */\n    public override formResetCallback(): void {\n      this.checked = this.hasAttribute('checked');\n      this._attributeMutationBlocked = false;\n    }\n\n    /**\n     *  Called when the browser is trying to restore element’s state to state in which case\n     *  reason is “restore”, or when the browser is trying to fulfill autofill on behalf of\n     *  user in which case reason is “autocomplete”.\n     *  In the case of “restore”, state is a string, File, or FormData object\n     *  previously set as the second argument to setFormValue.\n     *\n     * @internal\n     */\n    public override formStateRestoreCallback(\n      state: FormRestoreState | null,\n      _reason: FormRestoreReason,\n    ): void {\n      if (state) {\n        this.checked = state === 'true';\n      }\n    }\n\n    /**\n     * Additional logic which is being executed when user\n     * interaction happens and state is not disabled.\n     */\n    protected withUserInteraction?(): void;\n\n    protected override updateFormValue(): void {\n      if (this.checked) {\n        this.internals.setFormValue(this.value, `${this.checked}`);\n      } else {\n        this.internals.setFormValue(null);\n      }\n    }\n\n    /** Method triggered on keyboard user interaction with checkbox. */\n    private _handleKeyboardInteraction = (event: KeyboardEvent): void => {\n      if (event.key === ' ') {\n        this._handleUserInteraction();\n      }\n    };\n\n    /** Method triggered on user interaction with checkbox. */\n    private _handleUserInteraction = (): void => {\n      if (this.disabled) {\n        return;\n      }\n      this.withUserInteraction?.();\n      this.checked = !this.checked;\n      this._attributeMutationBlocked = true;\n\n      this.dispatchEvent(new InputEvent('input', { composed: true, bubbles: true }));\n      this.dispatchEvent(new Event('change', { bubbles: true }));\n      this.dispatchEvent(new CustomEvent('didChange', { bubbles: true }));\n    };\n  }\n\n  return SbbFormAssociatedCheckboxElement as unknown as Constructor<SbbFormAssociatedCheckboxMixinType> &\n    T;\n};\n","import { isServer, type LitElement, type PropertyValues } from 'lit';\n\nimport { forwardEventToHost } from '../eventing.js';\n\nimport type { AbstractConstructor } from './constructor.js';\n\n// Define the interface for the mixin\nexport declare abstract class SbbHydrationMixinType {\n  /**\n   * Returns a Promise that resolves when the element has completed hydration.\n   * The Promise value is a boolean that is `true` if the element required hydration\n   * and `false` if not.\n   *\n   * @return A promise of a boolean that resolves to true once the hydration completed.\n   */\n  public get hydrationComplete(): Promise<boolean>;\n\n  /**\n   * Called only if Declarative Shadow DOM is detected, during the initialization stage\n   * but before the hydration stage.\n   * When using server side rendering, this is called in willUpdate.\n   */\n  protected recoverSsrState?(): void;\n\n  /** Reads and removes an attribute with the given name. Either returns the attributte value or null. */\n  protected getAndRemoveAttribute(name: string): string | null;\n}\n\n/**\n * The key for globalThis lit hydration function.\n * If this is defined, then lit hydration is enabled.\n *\n * @see https://github.com/lit/lit/blob/main/packages/labs/ssr-client/src/lit-element-hydrate-support.ts\n */\nconst litElementHydrateSupport = 'litElementHydrateSupport';\n\n/**\n * This is a similar check as in core/testing, but we want to avoid an import to that module from\n * a production module.\n * TODO: Should this be solved in a different way or removed in a production build?\n */\nconst hydrationSuppressed = isServer || (globalThis as any).testGroup === 'ssr-non-hydrated';\n\n/**\n * This mixin extends a base class with functionality to check if hydration is completed.\n * It also delays slotchange events until hydration is complete.\n *\n * @param base The class to extend.\n * @returns A class extended with the hydration check functionality.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbHydrationMixin = <T extends AbstractConstructor<LitElement>>(\n  base: T,\n): AbstractConstructor<SbbHydrationMixinType> & T => {\n  abstract class SbbHydrationMixinClass extends base implements Partial<SbbHydrationMixinType> {\n    private _hydrationRequired = false;\n    private _hydrationComplete = new Promise<boolean>(\n      (resolve) => (this._resolveHydration = resolve),\n    );\n    private _resolveHydration!: (hydrationRequired: boolean) => void;\n\n    /**\n     * Returns a Promise that resolves when the element has completed hydration.\n     * The Promise value is a boolean that is `true` if the element required hydration\n     * and `false` if not.\n     *\n     * @return A promise of a boolean that resolves to true once the hydration completed.\n     * @internal\n     */\n    public get hydrationComplete(): Promise<boolean> {\n      return this._hydrationComplete;\n    }\n\n    private _handleBeforeHydrationSlotchange = (event: Event): void => {\n      if (!this._hydrationRequired) {\n        return;\n      }\n      event.stopImmediatePropagation();\n      const target = event.target as HTMLSlotElement;\n      this.hydrationComplete.then(() => forwardEventToHost(event, target));\n    };\n\n    protected override createRenderRoot(): HTMLElement | DocumentFragment {\n      // Check whether hydration is needed by checking whether the shadow root\n      // is available before createRenderRoot is called.\n      this._hydrationRequired =\n        !!this.shadowRoot &&\n        litElementHydrateSupport in globalThis &&\n        (isServer || !hydrationSuppressed);\n      if (!this._hydrationRequired) {\n        this._resolveHydration(false);\n      } else {\n        const slots = this.shadowRoot?.querySelectorAll('slot');\n        if (slots?.length) {\n          slots.forEach((slot) =>\n            slot.addEventListener('slotchange', this._handleBeforeHydrationSlotchange, {\n              capture: true,\n            }),\n          );\n          this.hydrationComplete.then(() =>\n            slots.forEach((slot) =>\n              slot.removeEventListener('slotchange', this._handleBeforeHydrationSlotchange),\n            ),\n          );\n        }\n        this.recoverSsrState?.();\n      }\n      return super.createRenderRoot();\n    }\n\n    protected override willUpdate(changedProperties: PropertyValues<this>): void {\n      super.willUpdate(changedProperties);\n\n      if (isServer) {\n        this.recoverSsrState?.();\n      }\n    }\n\n    protected override update(changedProperties: PropertyValues<this>): void {\n      // When hydration is needed, we wait the hydration process to finish, which is patched\n      // into the update method of the LitElement base class.\n      super.update(changedProperties);\n\n      if (this._hydrationRequired) {\n        this._hydrationRequired = false;\n        this._resolveHydration(true);\n      }\n    }\n\n    /**\n     * Called only if Declarative Shadow DOM is detected, during the initialization stage\n     * but before the hydration stage.\n     * When using server side rendering, this is called in willUpdate.\n     */\n    protected recoverSsrState?(): void;\n\n    /** Reads and removes an attribute with the given name. Either returns the attributte value or null. */\n    protected getAndRemoveAttribute(name: string): string | null {\n      const value = this.getAttribute(name);\n      this.removeAttribute(name);\n      return value;\n    }\n  }\n  return SbbHydrationMixinClass as unknown as AbstractConstructor<SbbHydrationMixinType> & T;\n};\n","import { html, type LitElement, nothing, type TemplateResult } from 'lit';\nimport { state } from 'lit/decorators.js';\n\nimport { getLocalName } from '../dom.js';\n\nimport type { AbstractConstructor } from './constructor.js';\nimport { SbbHydrationMixin, type SbbHydrationMixinType } from './hydration-mixin.js';\n\nimport '../../screen-reader-only.js';\n\nconst SSR_CHILD_COUNT_ATTRIBUTE = 'data-ssr-child-count';\nconst SLOTNAME_PREFIX = 'li';\n\n/**\n * Helper type for willUpdate or similar checks.\n * Allows the usage of the string literal 'listChildren'.\n *\n * @example\n * protected override willUpdate(changedProperties: PropertyValues<WithListChildren<this>>): void {\n *   if (changedProperties.has('listChildren')) {\n *     ...\n *   }\n * }\n */\nexport type WithListChildren<\n  T extends SbbNamedSlotListMixinType<C>,\n  C extends HTMLElement = HTMLElement,\n> = T & { listChildren: C[] };\n\nexport declare abstract class SbbNamedSlotListMixinType<\n  C extends HTMLElement,\n> extends SbbHydrationMixinType {\n  protected abstract readonly listChildLocalNames: string[];\n  @state() protected listChildren: C[];\n  protected renderList(attributes?: {\n    class?: string;\n    ariaLabel?: string;\n    ariaLabelledby?: string;\n  }): TemplateResult;\n  protected listSlotNames(): string[];\n  protected renderHiddenSlot(): TemplateResult;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbNamedSlotListMixin = <\n  C extends HTMLElement,\n  T extends AbstractConstructor<LitElement>,\n>(\n  superClass: T,\n): AbstractConstructor<SbbNamedSlotListMixinType<C>> & T => {\n  /**\n   * This base class provides named slot list observer functionality.\n   * This allows using the pattern of rendering a named slot for each child, which allows\n   * wrapping children in a ul/li list.\n   */\n  abstract class NamedSlotListElement<C extends HTMLElement = HTMLElement>\n    extends SbbHydrationMixin(superClass)\n    implements Partial<SbbNamedSlotListMixinType<C>>\n  {\n    /** A list of upper-cased tag names to match against. (e.g. SBB-LINK) */\n    protected abstract readonly listChildLocalNames: string[];\n\n    /**\n     * A list of children with the defined tag names.\n     * This array is only updated, if there is an actual change\n     * to the child elements.\n     */\n    @state() protected listChildren: C[] = [];\n\n    public override connectedCallback(): void {\n      super.connectedCallback();\n      this.shadowRoot?.addEventListener('slotchange', this._handleSlotchange, { passive: true });\n    }\n\n    public override disconnectedCallback(): void {\n      super.disconnectedCallback();\n      this.shadowRoot?.removeEventListener('slotchange', this._handleSlotchange);\n    }\n\n    private _handleSlotchange = (): void => {\n      const listChildren = Array.from(this.children ?? []).filter((e): e is C =>\n        this.listChildLocalNames.includes(e.localName),\n      );\n      // If the slotted child instances have not changed, we can skip syncing and updating\n      // the link reference list.\n      if (\n        listChildren.length === this.listChildren.length &&\n        this.listChildren.every((e, i) => listChildren[i] === e)\n      ) {\n        return;\n      }\n\n      this.listChildren\n        .filter((c) => !listChildren.includes(c))\n        .forEach((c) => c.removeAttribute('slot'));\n      this.listChildren = listChildren;\n      this.listChildren.forEach((c, index) =>\n        c.setAttribute('slot', `${SLOTNAME_PREFIX}-${index}`),\n      );\n\n      // Remove the ssr attribute, once we have actually initialized the children elements.\n      this.removeAttribute(SSR_CHILD_COUNT_ATTRIBUTE);\n    };\n\n    /**\n     * Renders list and list slots for slotted children or an amount of list slots\n     * corresponding to the `data-ssr-child-count` attribute value.\n     *\n     * This is a possible optimization for SSR, as in an SSR Lit environment\n     * other elements are not available, but might be available in the meta\n     * framework wrapper (like e.g. React). This allows to provide the amount of\n     * children to be passed via the `data-ssr-child-count` attribute value.\n     */\n    protected renderList(\n      attributes: { class?: string; ariaLabel?: string; ariaLabelledby?: string } = {},\n    ): TemplateResult {\n      const listSlotNames = this.listSlotNames();\n\n      if (listSlotNames.length >= 2) {\n        return html`\n          <ul\n            class=${attributes.class || (this.localName ?? getLocalName(this))}\n            aria-label=${attributes.ariaLabel || nothing}\n            aria-labelledby=${attributes.ariaLabelledby || nothing}\n          >\n            ${listSlotNames.map((name) => html`<li><slot name=${name}></slot></li>`)}\n          </ul>\n          ${this.renderHiddenSlot()}\n        `;\n      } else if (listSlotNames.length === 1) {\n        return html`<sbb-screen-reader-only>${attributes.ariaLabel}</sbb-screen-reader-only>\n          <span class=${attributes.class || (this.localName ?? getLocalName(this))}>\n            <span><slot name=${listSlotNames[0]}></slot></span>\n          </span>\n          ${this.renderHiddenSlot()} `;\n      } else {\n        return this.renderHiddenSlot();\n      }\n    }\n\n    /**\n     * Returns an array of list slot names with the length corresponding to the amount of matched\n     * children or the `data-ssr-child-count` attribute value.\n     *\n     * This is a possible optimization for SSR, as in an SSR Lit environment\n     * other elements are not available, but might be available in the meta\n     * framework wrapper (like e.g. React). This allows to provide the amount of\n     * children to be passed via the `data-ssr-child-count` attribute value.\n     */\n    protected listSlotNames(): string[] {\n      const listChildren = this.listChildren.length\n        ? this.listChildren\n        : Array.from({ length: +(this.getAttribute(SSR_CHILD_COUNT_ATTRIBUTE) ?? 0) });\n      return listChildren.map((_, i) => `${SLOTNAME_PREFIX}-${i}`);\n    }\n\n    /**\n     * Returns a hidden slot, which is intended as the children change detection.\n     * When an element without a slot attribute is slotted to the element, it triggers\n     * the slotchange event, which can be used to assign it to the appropriate named slot.\n     */\n    protected renderHiddenSlot(): TemplateResult {\n      return html`<span hidden><slot></slot></span>`;\n    }\n  }\n\n  return NamedSlotListElement as unknown as AbstractConstructor<SbbNamedSlotListMixinType<C>> & T;\n};\n","import type { LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport type { AbstractConstructor } from './constructor.js';\n\nexport declare class SbbNegativeMixinType {\n  public negative: boolean;\n}\n\n/**\n * Enhance your component with a negative property.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbNegativeMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbNegativeMixinType> & T => {\n  abstract class SbbNegativeElement extends superClass implements SbbNegativeMixinType {\n    /** Negative coloring variant flag. */\n    @property({ reflect: true, type: Boolean }) public negative: boolean = false;\n  }\n\n  return SbbNegativeElement as AbstractConstructor<SbbNegativeMixinType> & T;\n};\n","import type { LitElement } from 'lit';\n\nimport type { AbstractConstructor } from './constructor.js';\n\n// Define the interface for the mixin\nexport declare class SbbUpdateSchedulerMixinType {\n  protected startUpdate(): void;\n  protected completeUpdate(): void;\n}\n\n/**\n * This mixin allows scheduling manual updates, which affect updateComplete.\n * @param base The class to extend.\n * @returns A class extended with the slot child observer functionality.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbUpdateSchedulerMixin = <T extends AbstractConstructor<LitElement>>(\n  base: T,\n): AbstractConstructor<SbbUpdateSchedulerMixinType> & T => {\n  abstract class SbbUpdateSchedulerElement\n    extends base\n    implements Partial<SbbUpdateSchedulerMixinType>\n  {\n    private _updatePromise = Promise.resolve();\n    private _updateResolve = (): void => {};\n\n    protected startUpdate(): void {\n      this._updatePromise = new Promise<void>((r) => (this._updateResolve = r));\n    }\n\n    protected completeUpdate(): void {\n      this._updateResolve();\n    }\n\n    protected override async getUpdateComplete(): Promise<boolean> {\n      const result = await super.getUpdateComplete();\n      await this._updatePromise;\n      return result;\n    }\n  }\n  return SbbUpdateSchedulerElement as unknown as AbstractConstructor<SbbUpdateSchedulerMixinType> &\n    T;\n};\n"],"names":["__decorateClass","state"],"mappings":"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"}
723
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"mixins.js","sources":["../../../../src/elements/core/mixins/disabled-mixin.ts","../../../../src/elements/core/mixins/form-associated-mixin.ts","../../../../src/elements/core/mixins/required-mixin.ts","../../../../src/elements/core/mixins/form-associated-checkbox-mixin.ts","../../../../src/elements/core/mixins/hydration-mixin.ts","../../../../src/elements/core/mixins/named-slot-list-mixin.ts","../../../../src/elements/core/mixins/negative-mixin.ts","../../../../src/elements/core/mixins/panel-mixin.ts","../../../../src/elements/core/mixins/update-scheduler-mixin.ts"],"sourcesContent":["import type { LitElement, PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport type { AbstractConstructor } from './constructor.js';\n\nexport declare class SbbDisabledMixinType {\n  public set disabled(value: boolean);\n  public get disabled(): boolean;\n  protected isDisabledExternally(): boolean;\n}\n\n/**\n * Enhance your component with a disabled property.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbDisabledMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbDisabledMixinType> & T => {\n  abstract class SbbDisabledElement extends superClass implements Partial<SbbDisabledMixinType> {\n    /** Whether the component is disabled. */\n    @property({ reflect: true, type: Boolean })\n    public set disabled(value: boolean) {\n      // To provide the same behavior as the native disabled state,\n      // any value is converted to a boolean.\n      this._disabled = Boolean(value);\n    }\n    public get disabled(): boolean {\n      return this._disabled || this.isDisabledExternally();\n    }\n    private _disabled: boolean = false;\n\n    /**\n     * Will be used as 'or' check to the current disabled state.\n     * Can e.g. be used to read disabled state of a group.\n     */\n    protected isDisabledExternally(): boolean {\n      return false;\n    }\n  }\n\n  return SbbDisabledElement as unknown as AbstractConstructor<SbbDisabledMixinType> & T;\n};\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbDisabledTabIndexActionMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbDisabledMixinType> & T => {\n  abstract class SbbDisabledTabIndexAction\n    extends SbbDisabledMixin(superClass)\n    implements SbbDisabledMixinType\n  {\n    protected override willUpdate(changedProperties: PropertyValues<this>): void {\n      super.willUpdate(changedProperties);\n\n      if (!changedProperties.has('disabled')) {\n        return;\n      }\n\n      // FIXME if tabindex is not needed in combination with aria-disabled,\n      //  use the SbbDisabledMixin and implement a different willUpdate method.\n      if (this.disabled) {\n        this.setAttribute('aria-disabled', 'true');\n        this.removeAttribute('tabindex');\n      } else {\n        this.removeAttribute('aria-disabled');\n        this.setAttribute('tabindex', '0');\n      }\n    }\n  }\n  return SbbDisabledTabIndexAction as AbstractConstructor<SbbDisabledMixinType> & T;\n};\n","import type { LitElement } from 'lit';\nimport { property, state } from 'lit/decorators.js';\n\nimport type { Constructor } from './constructor.js';\n\nexport declare abstract class SbbFormAssociatedMixinType {\n  public get form(): HTMLFormElement | null;\n  public get name(): string;\n  public set name(value: string);\n  public get type(): string;\n  public get value(): string | null;\n  public set value(value: string | null);\n\n  public get validity(): ValidityState;\n  public get validationMessage(): string;\n  public get willValidate(): boolean;\n\n  protected formDisabled: boolean;\n  protected readonly internals: ElementInternals;\n\n  public checkValidity(): boolean;\n  public reportValidity(): boolean;\n\n  public formAssociatedCallback?(form: HTMLFormElement | null): void;\n  public formDisabledCallback(disabled: boolean): void;\n  public abstract formResetCallback(): void;\n  public abstract formStateRestoreCallback(\n    state: FormRestoreState | null,\n    reason: FormRestoreReason,\n  ): void;\n\n  protected updateFormValue(): void;\n}\n\n/**\n * The FormAssociatedMixin enables native form support for custom controls.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbFormAssociatedMixin = <T extends Constructor<LitElement>>(\n  superClass: T,\n): Constructor<SbbFormAssociatedMixinType> & T => {\n  abstract class SbbFormAssociatedElement\n    extends superClass\n    implements Partial<SbbFormAssociatedMixinType>\n  {\n    public static formAssociated = true;\n\n    /**\n     * Returns the form owner of internals target element.\n     */\n    public get form(): HTMLFormElement | null {\n      return this.internals.form;\n    }\n\n    /**\n     * Name of the form element. Will be read from name attribute.\n     *\n     * @description Developer note: In this case updating the attribute must be synchronous.\n     * Due to this it is implemented as a getter/setter and the attributeChangedCallback() handles the diff check.\n     */\n    @property()\n    public set name(name: string) {\n      this.setAttribute('name', `${name}`);\n    }\n    public get name(): string {\n      return this.getAttribute('name') ?? '';\n    }\n\n    /** @internal */\n    public get type(): string {\n      return this.localName;\n    }\n\n    /** Value of the form element. */\n    @property()\n    public set value(value: string | null) {\n      this._value = value;\n      this.updateFormValue();\n    }\n    public get value(): string | null {\n      return this._value;\n    }\n    private _value: string | null = null;\n\n    /**\n     * Returns the ValidityState object for internals target element.\n     *\n     * @internal\n     */\n    public get validity(): ValidityState {\n      return this.internals.validity;\n    }\n\n    /**\n     * Returns the error message that would be shown to the user\n     * if internals target element was to be checked for validity.\n     *\n     * @internal\n     */\n    public get validationMessage(): string {\n      return this.internals.validationMessage;\n    }\n\n    /**\n     * Returns true if internals target element will be validated\n     * when the form is submitted; false otherwise.\n     *\n     * @internal\n     */\n    public get willValidate(): boolean {\n      return this.internals.willValidate;\n    }\n\n    /** @internal */\n    protected readonly internals: ElementInternals = this.attachInternals();\n\n    /** Whenever a surrounding form or fieldset is changing its disabled state. */\n    @state() protected formDisabled: boolean = false;\n\n    public override attributeChangedCallback(\n      name: string,\n      old: string | null,\n      value: string | null,\n    ): void {\n      if (name !== 'name' || old !== value) {\n        super.attributeChangedCallback(name, old, value);\n      }\n    }\n\n    /**\n     * Returns true if internals target element has no validity problems; false otherwise.\n     * Fires an invalid event at the element in the latter case.\n     *\n     * @internal\n     */\n    public checkValidity(): boolean {\n      return this.internals.checkValidity();\n    }\n\n    /**\n     * Returns true if internals target element has no validity problems; otherwise,\n     * returns false, fires an invalid event at the element,\n     * and (if the event isn't canceled) reports the problem to the user.\n     *\n     * @internal\n     */\n    public reportValidity(): boolean {\n      return this.internals.reportValidity();\n    }\n\n    /**\n     * Called when the associated form element changes.\n     * ElementInternals.form returns the associated from element.\n     *\n     * @internal\n     */\n    public formAssociatedCallback?(form: HTMLFormElement | null): void;\n\n    /**\n     * Is called whenever a surrounding form / fieldset changes disabled state.\n     * @param disabled\n     *\n     * @internal\n     */\n    public formDisabledCallback(disabled: boolean): void {\n      this.formDisabled = disabled;\n    }\n\n    /**\n     * Is called whenever the form is being reset.\n     *\n     * @internal\n     */\n    public abstract formResetCallback(): void;\n\n    /**\n     *  Called when the browser is trying to restore element’s state to state in which case\n     *  reason is “restore”, or when the browser is trying to fulfill autofill on behalf of\n     *  user in which case reason is “autocomplete”.\n     *  In the case of “restore”, state is a string, File, or FormData object\n     *  previously set as the second argument to setFormValue.\n     *\n     * @internal\n     */\n    public abstract formStateRestoreCallback(\n      state: FormRestoreState | null,\n      reason: FormRestoreReason,\n    ): void;\n\n    /** Should be called when form value is changed. */\n    protected updateFormValue(): void {\n      this.internals.setFormValue(this.value);\n    }\n  }\n  return SbbFormAssociatedElement as unknown as Constructor<SbbFormAssociatedMixinType> & T;\n};\n\n/**\n * A value to be restored for a component's form value. If a component's form\n * state is a `FormData` object, its entry list of name and values will be\n * provided.\n */\nexport type FormRestoreState = File | string | [string, FormDataEntryValue][];\n\n/**\n * The reason a form component is being restored for, either `'restore'` for\n * browser restoration or `'autocomplete'` for restoring user values.\n */\nexport type FormRestoreReason = 'restore' | 'autocomplete';\n","import type { LitElement, PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport type { AbstractConstructor } from './constructor.js';\nimport type { SbbFormAssociatedMixinType } from './form-associated-mixin.js';\n\nexport declare class SbbRequiredMixinType {\n  public set required(value: boolean);\n  public get required(): boolean;\n  protected isRequiredExternally(): boolean;\n}\n\n/**\n * Enhance your component with a required property.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbRequiredMixin = <\n  T extends AbstractConstructor<LitElement & SbbFormAssociatedMixinType>,\n>(\n  superClass: T,\n): AbstractConstructor<SbbRequiredMixinType> & T => {\n  abstract class SbbRequiredElement extends superClass implements Partial<SbbRequiredMixinType> {\n    /** Whether the component is required. */\n    @property({ reflect: true, type: Boolean })\n    public set required(value: boolean) {\n      // To provide the same behavior as the native required state,\n      // any value is converted to a boolean.\n      this._required = Boolean(value);\n    }\n    public get required(): boolean {\n      return this._required || this.isRequiredExternally();\n    }\n    private _required: boolean = false;\n\n    protected override async willUpdate(changedProperties: PropertyValues<this>): Promise<void> {\n      super.willUpdate(changedProperties);\n\n      if (changedProperties.has('required')) {\n        // Firefox needs explicitly set aria-required value.\n        this.internals.ariaRequired = `${this.required}`;\n      }\n    }\n\n    /**\n     * Will be used as 'or' check to the current required state.\n     * Can e.g. be used to read required state of a group.\n     */\n    protected isRequiredExternally(): boolean {\n      return false;\n    }\n  }\n\n  return SbbRequiredElement as unknown as AbstractConstructor<SbbRequiredMixinType> & T;\n};\n","import { defaultConverter, type LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { hostAttributes } from '../decorators.js';\nimport { preventScrollOnSpacebarPress } from '../eventing.js';\n\nimport type { Constructor } from './constructor.js';\nimport { SbbDisabledMixin, type SbbDisabledMixinType } from './disabled-mixin.js';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbFormAssociatedMixin,\n  type SbbFormAssociatedMixinType,\n} from './form-associated-mixin.js';\nimport { SbbRequiredMixin, type SbbRequiredMixinType } from './required-mixin.js';\n\ntype CheckedSetterValue = { value: boolean; attribute: boolean };\n\nexport declare abstract class SbbFormAssociatedCheckboxMixinType\n  extends SbbFormAssociatedMixinType\n  implements Partial<SbbDisabledMixinType>, Partial<SbbRequiredMixinType>\n{\n  public get checked(): boolean;\n  public set checked(value: boolean);\n\n  public set disabled(value: boolean);\n  public get disabled(): boolean;\n\n  public set required(value: boolean);\n  public get required(): boolean;\n\n  public formResetCallback(): void;\n  public formStateRestoreCallback(state: FormRestoreState | null, reason: FormRestoreReason): void;\n\n  protected isDisabledExternally(): boolean;\n  protected isRequiredExternally(): boolean;\n  protected withUserInteraction?(): void;\n}\n\n/**\n * The FormAssociatedCheckboxMixin enables native form support for checkbox controls.\n *\n * Inherited classes MUST implement the ariaChecked state (ElementInternals) themselves.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbFormAssociatedCheckboxMixin = <T extends Constructor<LitElement>>(\n  superClass: T,\n): Constructor<SbbFormAssociatedCheckboxMixinType> & T => {\n  @hostAttributes({\n    tabindex: '0',\n  })\n  abstract class SbbFormAssociatedCheckboxElement\n    extends SbbDisabledMixin(SbbRequiredMixin(SbbFormAssociatedMixin(superClass)))\n    implements Partial<SbbFormAssociatedCheckboxMixinType>\n  {\n    private _attributeMutationBlocked = false;\n\n    /** Whether the checkbox is checked. */\n    @property({\n      type: Boolean,\n      converter: {\n        ...defaultConverter,\n        // We need to pass information to the setter so that we know it was called by attribute change.\n        fromAttribute: (value: string | null, type?: unknown): CheckedSetterValue => {\n          const result = defaultConverter.fromAttribute?.(value, type);\n          return { value: result, attribute: true } as CheckedSetterValue;\n        },\n      },\n    })\n    public set checked(value: boolean) {\n      const attributeSetter =\n        typeof value === 'object' ? (value as unknown as CheckedSetterValue).attribute : false;\n      if (attributeSetter) {\n        value = (value as unknown as CheckedSetterValue).value;\n      }\n\n      // As soon as mutation was done not by setting attribute,\n      // we need to block syncing attribute.\n      if (this.hasUpdated && !attributeSetter) {\n        this._attributeMutationBlocked = true;\n      }\n      this._checked = Boolean(value);\n      this.updateFormValue();\n    }\n    public get checked(): boolean {\n      return this._checked;\n    }\n    private _checked = false;\n\n    protected constructor() {\n      super();\n      /** @internal */\n      this.internals.role = 'checkbox';\n    }\n\n    public override connectedCallback(): void {\n      super.connectedCallback();\n\n      this.addEventListener('click', this._handleUserInteraction);\n      this.addEventListener('keydown', preventScrollOnSpacebarPress);\n      this.addEventListener('keyup', this._handleKeyboardInteraction);\n    }\n\n    public override disconnectedCallback(): void {\n      super.disconnectedCallback();\n\n      this.removeEventListener('click', this._handleUserInteraction);\n      this.removeEventListener('keydown', preventScrollOnSpacebarPress);\n      this.removeEventListener('keyup', this._handleKeyboardInteraction);\n    }\n\n    public override attributeChangedCallback(\n      name: string,\n      old: string | null,\n      value: string | null,\n    ): void {\n      // Attribute should not be interpreted after programmatic or manual state change.\n      if (name !== 'checked' || !this._attributeMutationBlocked) {\n        super.attributeChangedCallback(name, old, value);\n      }\n    }\n\n    /**\n     * Is called whenever the form is being reset.\n     *\n     * @internal\n     */\n    public override formResetCallback(): void {\n      this.checked = this.hasAttribute('checked');\n      this._attributeMutationBlocked = false;\n    }\n\n    /**\n     *  Called when the browser is trying to restore element’s state to state in which case\n     *  reason is “restore”, or when the browser is trying to fulfill autofill on behalf of\n     *  user in which case reason is “autocomplete”.\n     *  In the case of “restore”, state is a string, File, or FormData object\n     *  previously set as the second argument to setFormValue.\n     *\n     * @internal\n     */\n    public override formStateRestoreCallback(\n      state: FormRestoreState | null,\n      _reason: FormRestoreReason,\n    ): void {\n      if (state) {\n        this.checked = state === 'true';\n      }\n    }\n\n    /**\n     * Additional logic which is being executed when user\n     * interaction happens and state is not disabled.\n     */\n    protected withUserInteraction?(): void;\n\n    protected override updateFormValue(): void {\n      if (this.checked) {\n        this.internals.setFormValue(this.value, `${this.checked}`);\n      } else {\n        this.internals.setFormValue(null);\n      }\n    }\n\n    /** Method triggered on keyboard user interaction with checkbox. */\n    private _handleKeyboardInteraction = (event: KeyboardEvent): void => {\n      if (event.key === ' ') {\n        this._handleUserInteraction();\n      }\n    };\n\n    /** Method triggered on user interaction with checkbox. */\n    private _handleUserInteraction = (): void => {\n      if (this.disabled) {\n        return;\n      }\n      this.withUserInteraction?.();\n      this.checked = !this.checked;\n      this._attributeMutationBlocked = true;\n\n      this.dispatchEvent(new InputEvent('input', { composed: true, bubbles: true }));\n      this.dispatchEvent(new Event('change', { bubbles: true }));\n      this.dispatchEvent(new CustomEvent('didChange', { bubbles: true }));\n    };\n  }\n\n  return SbbFormAssociatedCheckboxElement as unknown as Constructor<SbbFormAssociatedCheckboxMixinType> &\n    T;\n};\n","import { isServer, type LitElement, type PropertyValues } from 'lit';\n\nimport { forwardEventToHost } from '../eventing.js';\n\nimport type { AbstractConstructor } from './constructor.js';\n\n// Define the interface for the mixin\nexport declare abstract class SbbHydrationMixinType {\n  /**\n   * Returns a Promise that resolves when the element has completed hydration.\n   * The Promise value is a boolean that is `true` if the element required hydration\n   * and `false` if not.\n   *\n   * @return A promise of a boolean that resolves to true once the hydration completed.\n   */\n  public get hydrationComplete(): Promise<boolean>;\n\n  /**\n   * Called only if Declarative Shadow DOM is detected, during the initialization stage\n   * but before the hydration stage.\n   * When using server side rendering, this is called in willUpdate.\n   */\n  protected recoverSsrState?(): void;\n\n  /** Reads and removes an attribute with the given name. Either returns the attributte value or null. */\n  protected getAndRemoveAttribute(name: string): string | null;\n}\n\n/**\n * The key for globalThis lit hydration function.\n * If this is defined, then lit hydration is enabled.\n *\n * @see https://github.com/lit/lit/blob/main/packages/labs/ssr-client/src/lit-element-hydrate-support.ts\n */\nconst litElementHydrateSupport = 'litElementHydrateSupport';\n\n/**\n * This is a similar check as in core/testing, but we want to avoid an import to that module from\n * a production module.\n * TODO: Should this be solved in a different way or removed in a production build?\n */\nconst hydrationSuppressed = isServer || (globalThis as any).testGroup === 'ssr-non-hydrated';\n\n/**\n * This mixin extends a base class with functionality to check if hydration is completed.\n * It also delays slotchange events until hydration is complete.\n *\n * @param base The class to extend.\n * @returns A class extended with the hydration check functionality.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbHydrationMixin = <T extends AbstractConstructor<LitElement>>(\n  base: T,\n): AbstractConstructor<SbbHydrationMixinType> & T => {\n  abstract class SbbHydrationMixinClass extends base implements Partial<SbbHydrationMixinType> {\n    private _hydrationRequired = false;\n    private _hydrationComplete = new Promise<boolean>(\n      (resolve) => (this._resolveHydration = resolve),\n    );\n    private _resolveHydration!: (hydrationRequired: boolean) => void;\n\n    /**\n     * Returns a Promise that resolves when the element has completed hydration.\n     * The Promise value is a boolean that is `true` if the element required hydration\n     * and `false` if not.\n     *\n     * @return A promise of a boolean that resolves to true once the hydration completed.\n     * @internal\n     */\n    public get hydrationComplete(): Promise<boolean> {\n      return this._hydrationComplete;\n    }\n\n    private _handleBeforeHydrationSlotchange = (event: Event): void => {\n      if (!this._hydrationRequired) {\n        return;\n      }\n      event.stopImmediatePropagation();\n      const target = event.target as HTMLSlotElement;\n      this.hydrationComplete.then(() => forwardEventToHost(event, target));\n    };\n\n    protected override createRenderRoot(): HTMLElement | DocumentFragment {\n      // Check whether hydration is needed by checking whether the shadow root\n      // is available before createRenderRoot is called.\n      this._hydrationRequired =\n        !!this.shadowRoot &&\n        litElementHydrateSupport in globalThis &&\n        (isServer || !hydrationSuppressed);\n      if (!this._hydrationRequired) {\n        this._resolveHydration(false);\n      } else {\n        const slots = this.shadowRoot?.querySelectorAll('slot');\n        if (slots?.length) {\n          slots.forEach((slot) =>\n            slot.addEventListener('slotchange', this._handleBeforeHydrationSlotchange, {\n              capture: true,\n            }),\n          );\n          this.hydrationComplete.then(() =>\n            slots.forEach((slot) =>\n              slot.removeEventListener('slotchange', this._handleBeforeHydrationSlotchange),\n            ),\n          );\n        }\n        this.recoverSsrState?.();\n      }\n      return super.createRenderRoot();\n    }\n\n    protected override willUpdate(changedProperties: PropertyValues<this>): void {\n      super.willUpdate(changedProperties);\n\n      if (isServer) {\n        this.recoverSsrState?.();\n      }\n    }\n\n    protected override update(changedProperties: PropertyValues<this>): void {\n      // When hydration is needed, we wait the hydration process to finish, which is patched\n      // into the update method of the LitElement base class.\n      super.update(changedProperties);\n\n      if (this._hydrationRequired) {\n        this._hydrationRequired = false;\n        this._resolveHydration(true);\n      }\n    }\n\n    /**\n     * Called only if Declarative Shadow DOM is detected, during the initialization stage\n     * but before the hydration stage.\n     * When using server side rendering, this is called in willUpdate.\n     */\n    protected recoverSsrState?(): void;\n\n    /** Reads and removes an attribute with the given name. Either returns the attributte value or null. */\n    protected getAndRemoveAttribute(name: string): string | null {\n      const value = this.getAttribute(name);\n      this.removeAttribute(name);\n      return value;\n    }\n  }\n  return SbbHydrationMixinClass as unknown as AbstractConstructor<SbbHydrationMixinType> & T;\n};\n","import { html, type LitElement, nothing, type TemplateResult } from 'lit';\nimport { state } from 'lit/decorators.js';\n\nimport { getLocalName } from '../dom.js';\n\nimport type { AbstractConstructor } from './constructor.js';\nimport { SbbHydrationMixin, type SbbHydrationMixinType } from './hydration-mixin.js';\n\nimport '../../screen-reader-only.js';\n\nconst SSR_CHILD_COUNT_ATTRIBUTE = 'data-ssr-child-count';\nconst SLOTNAME_PREFIX = 'li';\n\n/**\n * Helper type for willUpdate or similar checks.\n * Allows the usage of the string literal 'listChildren'.\n *\n * @example\n * protected override willUpdate(changedProperties: PropertyValues<WithListChildren<this>>): void {\n *   if (changedProperties.has('listChildren')) {\n *     ...\n *   }\n * }\n */\nexport type WithListChildren<\n  T extends SbbNamedSlotListMixinType<C>,\n  C extends HTMLElement = HTMLElement,\n> = T & { listChildren: C[] };\n\nexport declare abstract class SbbNamedSlotListMixinType<\n  C extends HTMLElement,\n> extends SbbHydrationMixinType {\n  protected abstract readonly listChildLocalNames: string[];\n  @state() protected listChildren: C[];\n  protected renderList(attributes?: {\n    class?: string;\n    ariaLabel?: string;\n    ariaLabelledby?: string;\n  }): TemplateResult;\n  protected listSlotNames(): string[];\n  protected renderHiddenSlot(): TemplateResult;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbNamedSlotListMixin = <\n  C extends HTMLElement,\n  T extends AbstractConstructor<LitElement>,\n>(\n  superClass: T,\n): AbstractConstructor<SbbNamedSlotListMixinType<C>> & T => {\n  /**\n   * This base class provides named slot list observer functionality.\n   * This allows using the pattern of rendering a named slot for each child, which allows\n   * wrapping children in a ul/li list.\n   */\n  abstract class NamedSlotListElement<C extends HTMLElement = HTMLElement>\n    extends SbbHydrationMixin(superClass)\n    implements Partial<SbbNamedSlotListMixinType<C>>\n  {\n    /** A list of upper-cased tag names to match against. (e.g. SBB-LINK) */\n    protected abstract readonly listChildLocalNames: string[];\n\n    /**\n     * A list of children with the defined tag names.\n     * This array is only updated, if there is an actual change\n     * to the child elements.\n     */\n    @state() protected listChildren: C[] = [];\n\n    public override connectedCallback(): void {\n      super.connectedCallback();\n      this.shadowRoot?.addEventListener('slotchange', this._handleSlotchange, { passive: true });\n    }\n\n    public override disconnectedCallback(): void {\n      super.disconnectedCallback();\n      this.shadowRoot?.removeEventListener('slotchange', this._handleSlotchange);\n    }\n\n    private _handleSlotchange = (): void => {\n      const listChildren = Array.from(this.children ?? []).filter((e): e is C =>\n        this.listChildLocalNames.includes(e.localName),\n      );\n      // If the slotted child instances have not changed, we can skip syncing and updating\n      // the link reference list.\n      if (\n        listChildren.length === this.listChildren.length &&\n        this.listChildren.every((e, i) => listChildren[i] === e)\n      ) {\n        return;\n      }\n\n      this.listChildren\n        .filter((c) => !listChildren.includes(c))\n        .forEach((c) => c.removeAttribute('slot'));\n      this.listChildren = listChildren;\n      this.listChildren.forEach((c, index) =>\n        c.setAttribute('slot', `${SLOTNAME_PREFIX}-${index}`),\n      );\n\n      // Remove the ssr attribute, once we have actually initialized the children elements.\n      this.removeAttribute(SSR_CHILD_COUNT_ATTRIBUTE);\n    };\n\n    /**\n     * Renders list and list slots for slotted children or an amount of list slots\n     * corresponding to the `data-ssr-child-count` attribute value.\n     *\n     * This is a possible optimization for SSR, as in an SSR Lit environment\n     * other elements are not available, but might be available in the meta\n     * framework wrapper (like e.g. React). This allows to provide the amount of\n     * children to be passed via the `data-ssr-child-count` attribute value.\n     */\n    protected renderList(\n      attributes: { class?: string; ariaLabel?: string; ariaLabelledby?: string } = {},\n    ): TemplateResult {\n      const listSlotNames = this.listSlotNames();\n\n      if (listSlotNames.length >= 2) {\n        return html`\n          <ul\n            class=${attributes.class || (this.localName ?? getLocalName(this))}\n            aria-label=${attributes.ariaLabel || nothing}\n            aria-labelledby=${attributes.ariaLabelledby || nothing}\n          >\n            ${listSlotNames.map((name) => html`<li><slot name=${name}></slot></li>`)}\n          </ul>\n          ${this.renderHiddenSlot()}\n        `;\n      } else if (listSlotNames.length === 1) {\n        return html`<sbb-screen-reader-only>${attributes.ariaLabel}</sbb-screen-reader-only>\n          <span class=${attributes.class || (this.localName ?? getLocalName(this))}>\n            <span><slot name=${listSlotNames[0]}></slot></span>\n          </span>\n          ${this.renderHiddenSlot()} `;\n      } else {\n        return this.renderHiddenSlot();\n      }\n    }\n\n    /**\n     * Returns an array of list slot names with the length corresponding to the amount of matched\n     * children or the `data-ssr-child-count` attribute value.\n     *\n     * This is a possible optimization for SSR, as in an SSR Lit environment\n     * other elements are not available, but might be available in the meta\n     * framework wrapper (like e.g. React). This allows to provide the amount of\n     * children to be passed via the `data-ssr-child-count` attribute value.\n     */\n    protected listSlotNames(): string[] {\n      const listChildren = this.listChildren.length\n        ? this.listChildren\n        : Array.from({ length: +(this.getAttribute(SSR_CHILD_COUNT_ATTRIBUTE) ?? 0) });\n      return listChildren.map((_, i) => `${SLOTNAME_PREFIX}-${i}`);\n    }\n\n    /**\n     * Returns a hidden slot, which is intended as the children change detection.\n     * When an element without a slot attribute is slotted to the element, it triggers\n     * the slotchange event, which can be used to assign it to the appropriate named slot.\n     */\n    protected renderHiddenSlot(): TemplateResult {\n      return html`<span hidden><slot></slot></span>`;\n    }\n  }\n\n  return NamedSlotListElement as unknown as AbstractConstructor<SbbNamedSlotListMixinType<C>> & T;\n};\n","import type { LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport type { AbstractConstructor } from './constructor.js';\n\nexport declare class SbbNegativeMixinType {\n  public negative: boolean;\n}\n\n/**\n * Enhance your component with a negative property.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbNegativeMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbNegativeMixinType> & T => {\n  abstract class SbbNegativeElement extends superClass implements SbbNegativeMixinType {\n    /** Negative coloring variant flag. */\n    @property({ reflect: true, type: Boolean }) public negative: boolean = false;\n  }\n\n  return SbbNegativeElement as AbstractConstructor<SbbNegativeMixinType> & T;\n};\n","import type { LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { EventEmitter } from '../eventing.js';\n\nimport type { AbstractConstructor } from './constructor.js';\n\nexport declare class SbbPanelMixinType {\n  public color: 'white' | 'milk';\n  public borderless: boolean;\n  public expansionState?: string;\n}\n\n/**\n * Mixin for common panel behaviors\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbPanelMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbPanelMixinType> & T => {\n  abstract class SbbPanelElement extends superClass implements SbbPanelMixinType {\n    public static readonly events = {\n      panelConnected: 'panelConnected',\n    } as const;\n\n    /** The background color of the panel. */\n    @property() public color: 'white' | 'milk' = 'white';\n\n    /** Whether the unselected panel has a border. */\n    @property({ reflect: true, type: Boolean }) public borderless = false;\n\n    /** @internal used for accessibility label when in expansion panel */\n    @property() public expansionState?: string;\n\n    /**\n     * @internal\n     * Internal event that emits when the checkbox is loaded.\n     */\n    private _panelConnected: EventEmitter<void> = new EventEmitter(\n      this,\n      SbbPanelElement.events.panelConnected,\n      { bubbles: true },\n    );\n\n    public override connectedCallback(): void {\n      super.connectedCallback();\n\n      this._panelConnected.emit();\n    }\n  }\n\n  return SbbPanelElement as AbstractConstructor<SbbPanelMixinType> & T;\n};\n","import type { LitElement } from 'lit';\n\nimport type { AbstractConstructor } from './constructor.js';\n\n// Define the interface for the mixin\nexport declare class SbbUpdateSchedulerMixinType {\n  protected startUpdate(): void;\n  protected completeUpdate(): void;\n}\n\n/**\n * This mixin allows scheduling manual updates, which affect updateComplete.\n * @param base The class to extend.\n * @returns A class extended with the slot child observer functionality.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbUpdateSchedulerMixin = <T extends AbstractConstructor<LitElement>>(\n  base: T,\n): AbstractConstructor<SbbUpdateSchedulerMixinType> & T => {\n  abstract class SbbUpdateSchedulerElement\n    extends base\n    implements Partial<SbbUpdateSchedulerMixinType>\n  {\n    private _updatePromise = Promise.resolve();\n    private _updateResolve = (): void => {};\n\n    protected startUpdate(): void {\n      this._updatePromise = new Promise<void>((r) => (this._updateResolve = r));\n    }\n\n    protected completeUpdate(): void {\n      this._updateResolve();\n    }\n\n    protected override async getUpdateComplete(): Promise<boolean> {\n      const result = await super.getUpdateComplete();\n      await this._updatePromise;\n      return result;\n    }\n  }\n  return SbbUpdateSchedulerElement as unknown as AbstractConstructor<SbbUpdateSchedulerMixinType> &\n    T;\n};\n"],"names":["__decorateClass","state"],"mappings":";;;;;;;;;;;;;;;;AAea,MAAA,mBAAmB,CAC9B,eACkD;AAAA,EAClD,MAAe,2BAA2B,WAAoD;AAAA,IAA9F,cAAA;AAAA,YAAA,GAAA,SAAA;AAWE,WAAQ,YAAqB;AAAA,IAAA;AAAA,IAR7B,IAAW,SAAS,OAAgB;AAG7B,WAAA,YAAY,QAAQ,KAAK;AAAA,IAChC;AAAA,IACA,IAAW,WAAoB;AACtB,aAAA,KAAK,aAAa,KAAK,qBAAqB;AAAA,IACrD;AAAA;AAAA;AAAA;AAAA;AAAA,IAOU,uBAAgC;AACjC,aAAA;AAAA,IACT;AAAA,EACF;AAjBaA,oBAAA;AAAA,IADV,SAAS,EAAE,SAAS,MAAM,MAAM,SAAS;AAAA,EAAA,GAF7B,mBAGF,WAAA,UAAA;AAmBN,SAAA;AACT;AAGa,MAAA,iCAAiC,CAC5C,eACkD;AAAA,EAClD,MAAe,kCACL,iBAAiB,UAAU,EAErC;AAAA,IACqB,WAAW,mBAA+C;AAC3E,YAAM,WAAW,iBAAiB;AAElC,UAAI,CAAC,kBAAkB,IAAI,UAAU,GAAG;AACtC;AAAA,MACF;AAIA,UAAI,KAAK,UAAU;AACZ,aAAA,aAAa,iBAAiB,MAAM;AACzC,aAAK,gBAAgB,UAAU;AAAA,MAAA,OAC1B;AACL,aAAK,gBAAgB,eAAe;AAC/B,aAAA,aAAa,YAAY,GAAG;AAAA,MACnC;AAAA,IACF;AAAA,EACF;AACO,SAAA;AACT;;;;;;;;;;;AChCa,MAAA,yBAAyB,CACpC,eACgD;AAChD,QAAe,4BAAf,MAAe,kCACL,WAEV;AAAA,IAHA,cAAA;AAAA,YAAA,GAAA,SAAA;AAyCE,WAAQ,SAAwB;AAgCb,WAAA,YAA8B,KAAK;AAG7C,WAAU,eAAwB;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA,IAnE3C,IAAW,OAA+B;AACxC,aAAO,KAAK,UAAU;AAAA,IACxB;AAAA,IASA,IAAW,KAAK,MAAc;AAC5B,WAAK,aAAa,QAAQ,GAAG,IAAI,EAAE;AAAA,IACrC;AAAA,IACA,IAAW,OAAe;AACjB,aAAA,KAAK,aAAa,MAAM,KAAK;AAAA,IACtC;AAAA;AAAA,IAGA,IAAW,OAAe;AACxB,aAAO,KAAK;AAAA,IACd;AAAA,IAIA,IAAW,MAAM,OAAsB;AACrC,WAAK,SAAS;AACd,WAAK,gBAAgB;AAAA,IACvB;AAAA,IACA,IAAW,QAAuB;AAChC,aAAO,KAAK;AAAA,IACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQA,IAAW,WAA0B;AACnC,aAAO,KAAK,UAAU;AAAA,IACxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQA,IAAW,oBAA4B;AACrC,aAAO,KAAK,UAAU;AAAA,IACxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQA,IAAW,eAAwB;AACjC,aAAO,KAAK,UAAU;AAAA,IACxB;AAAA,IAQgB,yBACd,MACA,KACA,OACM;AACF,UAAA,SAAS,UAAU,QAAQ,OAAO;AAC9B,cAAA,yBAAyB,MAAM,KAAK,KAAK;AAAA,MACjD;AAAA,IACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQO,gBAAyB;AACvB,aAAA,KAAK,UAAU;IACxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IASO,iBAA0B;AACxB,aAAA,KAAK,UAAU;IACxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAgBO,qBAAqB,UAAyB;AACnD,WAAK,eAAe;AAAA,IACtB;AAAA;AAAA,IAwBU,kBAAwB;AAC3B,WAAA,UAAU,aAAa,KAAK,KAAK;AAAA,IACxC;AAAA,EACF;AApJE,4BAAc,iBAAiB;AAJjC,MAAe,2BAAf;AAoBaA,oBAAA;AAAA,IADV,SAAS;AAAA,EAAA,GAnBG,yBAoBF,WAAA,QAAA,CAAA;AAcAA,oBAAA;AAAA,IADV,SAAS;AAAA,EAAA,GAjCG,yBAkCF,WAAA,SAAA,CAAA;AA0CQA,oBAAA;AAAA,IAAlB,MAAM;AAAA,EAAA,GA5EM,yBA4EM,WAAA,gBAAA,CAAA;AA6Ed,SAAA;AACT;;;;;;;;;;;ACnLa,MAAA,mBAAmB,CAG9B,eACkD;AAAA,EAClD,MAAe,2BAA2B,WAAoD;AAAA,IAA9F,cAAA;AAAA,YAAA,GAAA,SAAA;AAWE,WAAQ,YAAqB;AAAA,IAAA;AAAA,IAR7B,IAAW,SAAS,OAAgB;AAG7B,WAAA,YAAY,QAAQ,KAAK;AAAA,IAChC;AAAA,IACA,IAAW,WAAoB;AACtB,aAAA,KAAK,aAAa,KAAK,qBAAqB;AAAA,IACrD;AAAA,IAGA,MAAyB,WAAW,mBAAwD;AAC1F,YAAM,WAAW,iBAAiB;AAE9B,UAAA,kBAAkB,IAAI,UAAU,GAAG;AAErC,aAAK,UAAU,eAAe,GAAG,KAAK,QAAQ;AAAA,MAChD;AAAA,IACF;AAAA;AAAA;AAAA;AAAA;AAAA,IAMU,uBAAgC;AACjC,aAAA;AAAA,IACT;AAAA,EACF;AA1BaA,oBAAA;AAAA,IADV,SAAS,EAAE,SAAS,MAAM,MAAM,SAAS;AAAA,EAAA,GAF7B,mBAGF,WAAA,UAAA;AA4BN,SAAA;AACT;;;;;;;;;;;ACRa,MAAA,iCAAiC,CAC5C,eACwD;AAIzC,MAAA,mCAAf,cACU,iBAAiB,iBAAiB,uBAAuB,UAAU,CAAC,CAAC,EAE/E;AAAA,IAmCY,cAAc;AAChB;AAnCR,WAAQ,4BAA4B;AAgCpC,WAAQ,WAAW;AA8EX,WAAA,6BAA6B,CAAC,UAA+B;AAC/D,YAAA,MAAM,QAAQ,KAAK;AACrB,eAAK,uBAAuB;AAAA,QAC9B;AAAA,MAAA;AAIF,WAAQ,yBAAyB,MAAY;;AAC3C,YAAI,KAAK,UAAU;AACjB;AAAA,QACF;AACA,mBAAK,wBAAL;AACK,aAAA,UAAU,CAAC,KAAK;AACrB,aAAK,4BAA4B;AAE5B,aAAA,cAAc,IAAI,WAAW,SAAS,EAAE,UAAU,MAAM,SAAS,KAAM,CAAA,CAAC;AACxE,aAAA,cAAc,IAAI,MAAM,UAAU,EAAE,SAAS,KAAM,CAAA,CAAC;AACpD,aAAA,cAAc,IAAI,YAAY,aAAa,EAAE,SAAS,KAAM,CAAA,CAAC;AAAA,MAAA;AA1FlE,WAAK,UAAU,OAAO;AAAA,IACxB;AAAA,IAxBA,IAAW,QAAQ,OAAgB;AACjC,YAAM,kBACJ,OAAO,UAAU,WAAY,MAAwC,YAAY;AACnF,UAAI,iBAAiB;AACnB,gBAAS,MAAwC;AAAA,MACnD;AAII,UAAA,KAAK,cAAc,CAAC,iBAAiB;AACvC,aAAK,4BAA4B;AAAA,MACnC;AACK,WAAA,WAAW,QAAQ,KAAK;AAC7B,WAAK,gBAAgB;AAAA,IACvB;AAAA,IACA,IAAW,UAAmB;AAC5B,aAAO,KAAK;AAAA,IACd;AAAA,IASgB,oBAA0B;AACxC,YAAM,kBAAkB;AAEnB,WAAA,iBAAiB,SAAS,KAAK,sBAAsB;AACrD,WAAA,iBAAiB,WAAW,4BAA4B;AACxD,WAAA,iBAAiB,SAAS,KAAK,0BAA0B;AAAA,IAChE;AAAA,IAEgB,uBAA6B;AAC3C,YAAM,qBAAqB;AAEtB,WAAA,oBAAoB,SAAS,KAAK,sBAAsB;AACxD,WAAA,oBAAoB,WAAW,4BAA4B;AAC3D,WAAA,oBAAoB,SAAS,KAAK,0BAA0B;AAAA,IACnE;AAAA,IAEgB,yBACd,MACA,KACA,OACM;AAEN,UAAI,SAAS,aAAa,CAAC,KAAK,2BAA2B;AACnD,cAAA,yBAAyB,MAAM,KAAK,KAAK;AAAA,MACjD;AAAA,IACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOgB,oBAA0B;AACnC,WAAA,UAAU,KAAK,aAAa,SAAS;AAC1C,WAAK,4BAA4B;AAAA,IACnC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAWgB,yBACdC,QACA,SACM;AACN,UAAIA,QAAO;AACT,aAAK,UAAUA,WAAU;AAAA,MAC3B;AAAA,IACF;AAAA,IAQmB,kBAAwB;AACzC,UAAI,KAAK,SAAS;AAChB,aAAK,UAAU,aAAa,KAAK,OAAO,GAAG,KAAK,OAAO,EAAE;AAAA,MAAA,OACpD;AACA,aAAA,UAAU,aAAa,IAAI;AAAA,MAClC;AAAA,IACF;AAAA,EAAA;AA7FWD,oBAAA;AAAA,IAXV,SAAS;AAAA,MACR,MAAM;AAAA,MACN,WAAW;AAAA,QACT,GAAG;AAAA;AAAA,QAEH,eAAe,CAAC,OAAsB,SAAuC;;AAC3E,gBAAM,UAAS,6BAAiB,kBAAjB,4BAAiC,OAAO;AACvD,iBAAO,EAAE,OAAO,QAAQ,WAAW,KAAK;AAAA,QAC1C;AAAA,MACF;AAAA,IAAA,CACD;AAAA,EAAA,GAjBY,iCAkBF,WAAA,WAAA,CAAA;AAlBb,qCAAAA,kBAAA;AAAA,IAHC,eAAe;AAAA,MACd,UAAU;AAAA,IAAA,CACX;AAAA,EACc,GAAA,gCAAA;AAuIR,SAAA;AAET;AC1JA,MAAM,2BAA2B;AAOjC,MAAM,sBAAsB,YAAa,WAAmB,cAAc;AAU7D,MAAA,oBAAoB,CAC/B,SACmD;AAAA,EACnD,MAAe,+BAA+B,KAA+C;AAAA,IAA7F,cAAA;AAAA,YAAA,GAAA,SAAA;AACE,WAAQ,qBAAqB;AAC7B,WAAQ,qBAAqB,IAAI;AAAA,QAC/B,CAAC,YAAa,KAAK,oBAAoB;AAAA,MAAA;AAgBjC,WAAA,mCAAmC,CAAC,UAAuB;AAC7D,YAAA,CAAC,KAAK,oBAAoB;AAC5B;AAAA,QACF;AACA,cAAM,yBAAyB;AAC/B,cAAM,SAAS,MAAM;AACrB,aAAK,kBAAkB,KAAK,MAAM,mBAAmB,OAAO,MAAM,CAAC;AAAA,MAAA;AAAA,IACrE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAXA,IAAW,oBAAsC;AAC/C,aAAO,KAAK;AAAA,IACd;AAAA,IAWmB,mBAAmD;;AAG/D,WAAA,qBACH,CAAC,CAAC,KAAK,cACP,4BAA4B,eAC3B,YAAY,CAAC;AACZ,UAAA,CAAC,KAAK,oBAAoB;AAC5B,aAAK,kBAAkB,KAAK;AAAA,MAAA,OACvB;AACL,cAAM,SAAQ,UAAK,eAAL,mBAAiB,iBAAiB;AAChD,YAAI,+BAAO,QAAQ;AACX,gBAAA;AAAA,YAAQ,CAAC,SACb,KAAK,iBAAiB,cAAc,KAAK,kCAAkC;AAAA,cACzE,SAAS;AAAA,YAAA,CACV;AAAA,UAAA;AAEH,eAAK,kBAAkB;AAAA,YAAK,MAC1B,MAAM;AAAA,cAAQ,CAAC,SACb,KAAK,oBAAoB,cAAc,KAAK,gCAAgC;AAAA,YAC9E;AAAA,UAAA;AAAA,QAEJ;AACA,mBAAK,oBAAL;AAAA,MACF;AACA,aAAO,MAAM;IACf;AAAA,IAEmB,WAAW,mBAA+C;;AAC3E,YAAM,WAAW,iBAAiB;AAElC,UAAI,UAAU;AACZ,mBAAK,oBAAL;AAAA,MACF;AAAA,IACF;AAAA,IAEmB,OAAO,mBAA+C;AAGvE,YAAM,OAAO,iBAAiB;AAE9B,UAAI,KAAK,oBAAoB;AAC3B,aAAK,qBAAqB;AAC1B,aAAK,kBAAkB,IAAI;AAAA,MAC7B;AAAA,IACF;AAAA;AAAA,IAUU,sBAAsB,MAA6B;AACrD,YAAA,QAAQ,KAAK,aAAa,IAAI;AACpC,WAAK,gBAAgB,IAAI;AAClB,aAAA;AAAA,IACT;AAAA,EACF;AACO,SAAA;AACT;;;;;;;;;;ACtIA,MAAM,4BAA4B;AAClC,MAAM,kBAAkB;AAiCX,MAAA,wBAAwB,CAInC,eAC0D;AAAA,EAM1D,MAAe,6BACL,kBAAkB,UAAU,EAEtC;AAAA,IAHA,cAAA;AAAA,YAAA,GAAA,SAAA;AAYW,WAAU,eAAoB;AAYvC,WAAQ,oBAAoB,MAAY;AACtC,cAAM,eAAe,MAAM,KAAK,KAAK,YAAY,CAAE,CAAA,EAAE;AAAA,UAAO,CAAC,MAC3D,KAAK,oBAAoB,SAAS,EAAE,SAAS;AAAA,QAAA;AAI/C,YACE,aAAa,WAAW,KAAK,aAAa,UAC1C,KAAK,aAAa,MAAM,CAAC,GAAG,MAAM,aAAa,CAAC,MAAM,CAAC,GACvD;AACA;AAAA,QACF;AAEA,aAAK,aACF,OAAO,CAAC,MAAM,CAAC,aAAa,SAAS,CAAC,CAAC,EACvC,QAAQ,CAAC,MAAM,EAAE,gBAAgB,MAAM,CAAC;AAC3C,aAAK,eAAe;AACpB,aAAK,aAAa;AAAA,UAAQ,CAAC,GAAG,UAC5B,EAAE,aAAa,QAAQ,GAAG,eAAe,IAAI,KAAK,EAAE;AAAA,QAAA;AAItD,aAAK,gBAAgB,yBAAyB;AAAA,MAAA;AAAA,IAChD;AAAA,IAjCgB,oBAA0B;;AACxC,YAAM,kBAAkB;AACnB,iBAAA,eAAA,mBAAY,iBAAiB,cAAc,KAAK,mBAAmB,EAAE,SAAS;IACrF;AAAA,IAEgB,uBAA6B;;AAC3C,YAAM,qBAAqB;AAC3B,iBAAK,eAAL,mBAAiB,oBAAoB,cAAc,KAAK;AAAA,IAC1D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAoCU,WACR,aAA8E,IAC9D;AACV,YAAA,gBAAgB,KAAK;AAEvB,UAAA,cAAc,UAAU,GAAG;AACtB,eAAA;AAAA;AAAA,oBAEK,WAAW,UAAU,KAAK,aAAa,aAAa,IAAI,EAAE;AAAA,yBACrD,WAAW,aAAa,OAAO;AAAA,8BAC1B,WAAW,kBAAkB,OAAO;AAAA;AAAA,cAEpD,cAAc,IAAI,CAAC,SAAS,sBAAsB,IAAI,eAAe,CAAC;AAAA;AAAA,YAExE,KAAK,kBAAkB;AAAA;AAAA,MAAA,WAElB,cAAc,WAAW,GAAG;AAC9B,eAAA,+BAA+B,WAAW,SAAS;AAAA,wBAC1C,WAAW,UAAU,KAAK,aAAa,aAAa,IAAI,EAAE;AAAA,+BACnD,cAAc,CAAC,CAAC;AAAA;AAAA,YAEnC,KAAK,kBAAkB;AAAA,MAAA,OACtB;AACL,eAAO,KAAK;MACd;AAAA,IACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAWU,gBAA0B;AAClC,YAAM,eAAe,KAAK,aAAa,SACnC,KAAK,eACL,MAAM,KAAK,EAAE,QAAQ,EAAE,KAAK,aAAa,yBAAyB,KAAK,IAAI;AACxE,aAAA,aAAa,IAAI,CAAC,GAAG,MAAM,GAAG,eAAe,IAAI,CAAC,EAAE;AAAA,IAC7D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOU,mBAAmC;AACpC,aAAA;AAAA,IACT;AAAA,EACF;AAjGqBA,oBAAA;AAAA,IAAlB,MAAM;AAAA,EAAA,GAZM,qBAYM,WAAA,cAAA;AAmGd,SAAA;AACT;;;;;;;;;;AC1Ja,MAAA,mBAAmB,CAC9B,eACkD;AAAA,EAClD,MAAe,2BAA2B,WAA2C;AAAA,IAArF,cAAA;AAAA,YAAA,GAAA,SAAA;AAE8C,WAAO,WAAoB;AAAA,IAAA;AAAA,EACzE;AADqDA,oBAAA;AAAA,IAAlD,SAAS,EAAE,SAAS,MAAM,MAAM,SAAS;AAAA,EAAA,GAF7B,mBAEsC,WAAA,UAAA;AAG9C,SAAA;AACT;;;;;;;;;;ACLa,MAAA,gBAAgB,CAC3B,eAC+C;;AAChC,QAAA,oBAAf,mBAAuC,WAAwC;AAAA,IAA/E,cAAA;AAAA,YAAA,GAAA,SAAA;AAMc,WAAO,QAA0B;AAGD,WAAO,aAAa;AAShE,WAAQ,kBAAsC,IAAI;AAAA,QAChD;AAAA,QACA,GAAgB,OAAO;AAAA,QACvB,EAAE,SAAS,KAAK;AAAA,MAAA;AAAA,IAClB;AAAA,IAEgB,oBAA0B;AACxC,YAAM,kBAAkB;AAExB,WAAK,gBAAgB;IACvB;AAAA,EAAA,GA3BA,GAAuB,SAAS;AAAA,IAC9B,gBAAgB;AAAA,EAAA,GAFpB;AAMqB,kBAAA;AAAA,IAAlB,SAAS;AAAA,EAAA,GANG,iBAMM,WAAA,OAAA;AAGgC,kBAAA;AAAA,IAAlD,SAAS,EAAE,SAAS,MAAM,MAAM,SAAS;AAAA,EAAA,GAT7B,iBASsC,WAAA,YAAA;AAGhC,kBAAA;AAAA,IAAlB,SAAS;AAAA,EAAA,GAZG,iBAYM,WAAA,gBAAA;AAZrB,MAAe,kBAAf;AA+BO,SAAA;AACT;ACpCa,MAAA,0BAA0B,CACrC,SACyD;AAAA,EACzD,MAAe,kCACL,KAEV;AAAA,IAHA,cAAA;AAAA,YAAA,GAAA,SAAA;AAIU,WAAA,iBAAiB,QAAQ;AACjC,WAAQ,iBAAiB,MAAY;AAAA,MAAA;AAAA,IAAC;AAAA,IAE5B,cAAoB;AAC5B,WAAK,iBAAiB,IAAI,QAAc,CAAC,MAAO,KAAK,iBAAiB,CAAE;AAAA,IAC1E;AAAA,IAEU,iBAAuB;AAC/B,WAAK,eAAe;AAAA,IACtB;AAAA,IAEA,MAAyB,oBAAsC;AACvD,YAAA,SAAS,MAAM,MAAM;AAC3B,YAAM,KAAK;AACJ,aAAA;AAAA,IACT;AAAA,EACF;AACO,SAAA;AAET;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}