@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,14 +1,10 @@
1
1
  import { css, LitElement, html } from "lit";
2
- import { property, state, customElement } from "lit/decorators.js";
3
- import { SbbLanguageController, SbbSlotStateController } from "../core/controllers.js";
4
- import { EventEmitter } from "../core/eventing.js";
5
- import { i18nExpanded, i18nCollapsed } from "../core/i18n.js";
6
- import { SbbUpdateSchedulerMixin, SbbFormAssociatedCheckboxMixin, SbbHydrationMixin } from "../core/mixins.js";
2
+ import { property, customElement } from "lit/decorators.js";
3
+ import { SbbSlotStateController } from "../core/controllers.js";
7
4
  import { SbbIconNameMixin } from "../icon.js";
8
- import "../screen-reader-only.js";
5
+ import { SbbCheckboxCommonElementMixin, checkboxCommonStyle } from "./common.js";
9
6
  import "../visual-checkbox.js";
10
- const style = css`@charset "UTF-8";
11
- /**
7
+ const checkboxStyle = css`/**
12
8
  * Better font rendering (on OS X)
13
9
  * http://maximilianhoffmann.com/posts/better-font-rendering-on-osx
14
10
  *
@@ -22,111 +18,9 @@ const style = css`@charset "UTF-8";
22
18
  * }
23
19
  */
24
20
  /** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
25
- *,
26
- ::before,
27
- ::after {
28
- box-sizing: border-box;
29
- }
30
-
31
21
  :host {
32
- --sbb-checkbox-dimension: var(--sbb-size-icon-ui-small);
33
- --sbb-checkbox-label-color: var(--sbb-color-charcoal);
34
- --sbb-checkbox-label-icon-color: var(--sbb-color-charcoal);
35
- --sbb-checkbox-cursor: pointer;
36
- --sbb-checkbox-suffix-color: var(--sbb-color-charcoal);
37
- --sbb-checkbox-subtext-color: var(--sbb-color-granite);
38
- --sbb-checkbox-label-gap: var(--sbb-spacing-fixed-2x);
39
- display: inline-block;
40
22
  outline: none !important;
41
- }
42
-
43
- :host(:disabled) {
44
- --sbb-checkbox-cursor: default;
45
- --sbb-checkbox-label-color: var(--sbb-color-granite);
46
- }
47
-
48
- :host([data-is-selection-panel-input]) {
49
- --sbb-checkbox-label-gap: 0;
50
- }
51
-
52
- :host(:not([data-is-inside-selection-panel])) :is(slot[name=subtext], slot[name=suffix]) {
53
- display: none;
54
- }
55
-
56
- slot[name=suffix] {
57
- color: var(--sbb-checkbox-suffix-color);
58
- }
59
-
60
- slot[name=subtext] {
61
- display: block;
62
- color: var(--sbb-checkbox-subtext-color);
63
- padding-inline-start: var(--sbb-spacing-fixed-8x);
64
- }
65
- :host(:not([data-slot-names~=subtext])) slot[name=subtext] {
66
- display: none;
67
- }
68
-
69
- .sbb-checkbox-wrapper {
70
- display: flex;
71
- }
72
- .sbb-checkbox-wrapper::before {
73
- content: "​";
74
- user-select: none;
75
- width: 0;
76
- height: 0;
77
- }
78
- :host(:focus-visible:not([data-focus-origin=mouse],
79
- [data-focus-origin=touch],
80
- [data-is-selection-panel-input])) .sbb-checkbox-wrapper {
81
- outline-offset: var(--sbb-focus-outline-offset);
82
- outline: var(--sbb-focus-outline-color) solid var(--sbb-focus-outline-width);
83
- border-radius: calc(var(--sbb-border-radius-4x) - var(--sbb-focus-outline-offset));
84
- }
85
-
86
- .sbb-checkbox {
87
- --sbb-text-font-size: var(--sbb-font-size-text-s);
88
- font-family: var(--sbb-typo-font-family);
89
- font-weight: normal;
90
- line-height: var(--sbb-typo-line-height-body-text);
91
- letter-spacing: var(--sbb-typo-letter-spacing-body-text);
92
- font-size: var(--sbb-text-font-size);
93
- position: relative;
94
- display: block;
95
- width: 100%;
96
- cursor: var(--sbb-checkbox-cursor);
97
- user-select: none;
98
- -webkit-tap-highlight-color: transparent;
99
- }
100
- :host([size=m]) .sbb-checkbox {
101
- --sbb-text-font-size: var(--sbb-font-size-text-m);
102
- font-family: var(--sbb-typo-font-family);
103
- font-weight: normal;
104
- line-height: var(--sbb-typo-line-height-body-text);
105
- letter-spacing: var(--sbb-typo-letter-spacing-body-text);
106
- font-size: var(--sbb-text-font-size);
107
- }
108
-
109
- .sbb-checkbox__inner {
110
- display: flex;
111
- align-items: start;
112
- gap: var(--sbb-spacing-fixed-2x);
113
- }
114
- :host([data-is-selection-panel-input]:focus-visible:not([data-focus-origin=mouse],
115
- [data-focus-origin=touch])) .sbb-checkbox__inner::before {
116
- content: "";
117
- position: absolute;
118
- display: block;
119
- inset-block: calc(var(--sbb-spacing-responsive-xs) * -1 + var(--sbb-focus-outline-width) - var(--sbb-focus-outline-offset) * 2);
120
- inset-inline: calc(var(--sbb-spacing-responsive-xxs) * -1 + var(--sbb-focus-outline-width) - var(--sbb-focus-outline-offset) * 2);
121
- border: var(--sbb-focus-outline-color) solid var(--sbb-focus-outline-width);
122
- border-radius: calc(var(--sbb-border-radius-4x) + var(--sbb-focus-outline-offset));
123
- }
124
-
125
- .sbb-checkbox__aligner,
126
- .sbb-checkbox__label--icon {
127
- display: flex;
128
- align-items: center;
129
- height: calc(1em * var(--sbb-typo-line-height-body-text));
23
+ display: inline-block;
130
24
  }
131
25
 
132
26
  .sbb-checkbox__label--icon {
@@ -135,17 +29,16 @@ slot[name=subtext] {
135
29
  :host([icon-placement=end]) .sbb-checkbox__label--icon {
136
30
  margin-inline-start: auto;
137
31
  }
138
- :host(:is(:not([icon-name], [data-slot-names~=icon]),
139
- [data-is-selection-panel-input])) .sbb-checkbox__label--icon {
32
+ :host(:not([icon-name], [data-slot-names~=icon])) .sbb-checkbox__label--icon {
140
33
  display: none;
141
34
  }
142
35
 
143
- .sbb-checkbox__label {
144
- display: flex;
145
- gap: var(--sbb-checkbox-label-gap);
146
- color: var(--sbb-checkbox-label-color);
147
- line-height: max(1em * var(--sbb-typo-line-height-body-text), var(--sbb-checkbox-dimension));
36
+ :host(:focus-visible:not([data-focus-origin=mouse], [data-focus-origin=touch])) .sbb-checkbox-wrapper {
37
+ outline-offset: var(--sbb-focus-outline-offset);
38
+ outline: var(--sbb-focus-outline-color) solid var(--sbb-focus-outline-width);
39
+ border-radius: calc(var(--sbb-border-radius-4x) - var(--sbb-focus-outline-offset));
148
40
  }
41
+
149
42
  :host([icon-placement=start]) .sbb-checkbox__label {
150
43
  flex-direction: row-reverse;
151
44
  justify-content: flex-end;
@@ -153,10 +46,6 @@ slot[name=subtext] {
153
46
  :host([icon-placement=end]) .sbb-checkbox__label {
154
47
  justify-content: flex-start;
155
48
  flex-grow: 1;
156
- }
157
-
158
- :host(:not([data-is-selection-panel-input][data-has-selection-panel-label])) .sbb-checkbox__expanded-label {
159
- display: none;
160
49
  }`;
161
50
  var __defProp = Object.defineProperty;
162
51
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
@@ -168,109 +57,14 @@ var __decorateClass = (decorators, target, key, kind) => {
168
57
  if (kind && result) __defProp(target, key, result);
169
58
  return result;
170
59
  };
171
- let SbbCheckboxElement = class extends SbbUpdateSchedulerMixin(
172
- SbbFormAssociatedCheckboxMixin(SbbIconNameMixin(SbbHydrationMixin(LitElement)))
60
+ let SbbCheckboxElement = class extends SbbCheckboxCommonElementMixin(
61
+ SbbIconNameMixin(LitElement)
173
62
  ) {
174
63
  constructor() {
175
64
  super();
176
- this.indeterminate = false;
177
65
  this.iconPlacement = "end";
178
- this._size = "m";
179
- this._group = null;
180
- this._language = new SbbLanguageController(this);
181
- this._selectionPanelElement = null;
182
- this._stateChange = new EventEmitter(
183
- this,
184
- SbbCheckboxElement.events.stateChange,
185
- { bubbles: true }
186
- );
187
- this._checkboxLoaded = new EventEmitter(
188
- this,
189
- SbbCheckboxElement.events.checkboxLoaded,
190
- { bubbles: true }
191
- );
192
66
  new SbbSlotStateController(this);
193
67
  }
194
- set size(value) {
195
- this._size = value;
196
- }
197
- get size() {
198
- var _a;
199
- return ((_a = this.group) == null ? void 0 : _a.size) ?? this._size;
200
- }
201
- /** Reference to the connected checkbox group. */
202
- get group() {
203
- return this._group;
204
- }
205
- /**
206
- * Whether the input is the main input of a selection panel.
207
- * @internal
208
- */
209
- get isSelectionPanelInput() {
210
- return this.hasAttribute("data-is-selection-panel-input");
211
- }
212
- connectedCallback() {
213
- var _a, _b;
214
- super.connectedCallback();
215
- this._group = this.closest("sbb-checkbox-group");
216
- this._selectionPanelElement = (_a = this.closest) == null ? void 0 : _a.call(this, "sbb-selection-panel");
217
- this.toggleAttribute("data-is-inside-selection-panel", !!this._selectionPanelElement);
218
- this.toggleAttribute(
219
- "data-is-selection-panel-input",
220
- !!this._selectionPanelElement && !((_b = this.closest) == null ? void 0 : _b.call(this, 'sbb-selection-panel [slot="content"]'))
221
- );
222
- this._checkboxLoaded.emit();
223
- ["disabled", "required", "size"].forEach((p) => this.requestUpdate(p));
224
- }
225
- async willUpdate(changedProperties) {
226
- super.willUpdate(changedProperties);
227
- if (changedProperties.has("checked")) {
228
- if (this.isSelectionPanelInput && this.checked !== changedProperties.get("checked")) {
229
- this._stateChange.emit({ type: "checked", checked: this.checked });
230
- this._updateExpandedLabel();
231
- }
232
- }
233
- if (changedProperties.has("disabled")) {
234
- if (this.isSelectionPanelInput && this.disabled !== changedProperties.get("disabled")) {
235
- this._stateChange.emit({ type: "disabled", disabled: this.disabled });
236
- }
237
- }
238
- if (changedProperties.has("checked") || changedProperties.has("indeterminate")) {
239
- this.internals.ariaChecked = this.indeterminate ? "mixed" : `${this.checked}`;
240
- }
241
- }
242
- firstUpdated(changedProperties) {
243
- super.firstUpdated(changedProperties);
244
- this.startUpdate();
245
- setTimeout(() => {
246
- this.isSelectionPanelInput && this._updateExpandedLabel();
247
- this.completeUpdate();
248
- });
249
- }
250
- isDisabledExternally() {
251
- var _a;
252
- return ((_a = this.group) == null ? void 0 : _a.disabled) ?? false;
253
- }
254
- isRequiredExternally() {
255
- var _a;
256
- return ((_a = this.group) == null ? void 0 : _a.required) ?? false;
257
- }
258
- withUserInteraction() {
259
- if (this.indeterminate) {
260
- this.indeterminate = false;
261
- }
262
- }
263
- async _updateExpandedLabel() {
264
- var _a;
265
- await this.hydrationComplete;
266
- if (!((_a = this._selectionPanelElement) == null ? void 0 : _a.hasContent)) {
267
- this._selectionPanelExpandedLabel = "";
268
- this.removeAttribute("data-has-selection-panel-label");
269
- return;
270
- }
271
- this._selectionPanelExpandedLabel = this.checked ? ", " + i18nExpanded[this._language.current] : ", " + i18nCollapsed[this._language.current];
272
- this.toggleAttribute("data-has-selection-panel-label", true);
273
- }
274
68
  render() {
275
69
  return html`
276
70
  <span class="sbb-checkbox-wrapper">
@@ -285,41 +79,27 @@ let SbbCheckboxElement = class extends SbbUpdateSchedulerMixin(
285
79
  </span>
286
80
  <span class="sbb-checkbox__label">
287
81
  <slot></slot>
288
- <span class="sbb-checkbox__label--icon">${this.renderIconSlot()}</span>
289
- <slot name="suffix"></slot>
82
+ <span class="sbb-checkbox__label--icon sbb-checkbox__aligner"
83
+ >${this.renderIconSlot()}</span
84
+ >
290
85
  </span>
291
86
  </span>
292
- <slot name="subtext"></slot>
293
- <sbb-screen-reader-only class="sbb-checkbox__expanded-label">
294
- ${this._selectionPanelExpandedLabel}
295
- </sbb-screen-reader-only>
296
87
  </span>
297
88
  </span>
298
89
  `;
299
90
  }
300
91
  };
301
- SbbCheckboxElement.styles = style;
92
+ SbbCheckboxElement.styles = [checkboxCommonStyle, checkboxStyle];
302
93
  SbbCheckboxElement.events = {
303
- didChange: "didChange",
304
- stateChange: "stateChange",
305
- checkboxLoaded: "checkboxLoaded"
94
+ didChange: "didChange"
306
95
  };
307
- __decorateClass([
308
- property({ type: Boolean })
309
- ], SbbCheckboxElement.prototype, "indeterminate", 2);
310
96
  __decorateClass([
311
97
  property({ attribute: "icon-placement", reflect: true })
312
98
  ], SbbCheckboxElement.prototype, "iconPlacement", 2);
313
- __decorateClass([
314
- property({ reflect: true })
315
- ], SbbCheckboxElement.prototype, "size", 1);
316
- __decorateClass([
317
- state()
318
- ], SbbCheckboxElement.prototype, "_selectionPanelExpandedLabel", 2);
319
99
  SbbCheckboxElement = __decorateClass([
320
100
  customElement("sbb-checkbox")
321
101
  ], SbbCheckboxElement);
322
102
  export {
323
103
  SbbCheckboxElement
324
104
  };
325
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"checkbox.js","sources":["../../../../src/elements/checkbox/checkbox/checkbox.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  LitElement,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\n\nimport { SbbLanguageController, SbbSlotStateController } from '../../core/controllers.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport { i18nCollapsed, i18nExpanded } from '../../core/i18n.js';\nimport type {\n  SbbCheckedStateChange,\n  SbbDisabledStateChange,\n  SbbIconPlacement,\n  SbbStateChange,\n} from '../../core/interfaces.js';\nimport {\n  SbbFormAssociatedCheckboxMixin,\n  SbbHydrationMixin,\n  SbbUpdateSchedulerMixin,\n} from '../../core/mixins.js';\nimport { SbbIconNameMixin } from '../../icon.js';\nimport type { SbbSelectionPanelElement } from '../../selection-panel.js';\nimport type { SbbCheckboxGroupElement } from '../checkbox-group.js';\n\nimport style from './checkbox.scss?lit&inline';\n\nimport '../../screen-reader-only.js';\nimport '../../visual-checkbox.js';\n\nexport type SbbCheckboxStateChange = Extract<\n  SbbStateChange,\n  SbbDisabledStateChange | SbbCheckedStateChange\n>;\n\nexport type SbbCheckboxSize = 's' | 'm';\n\n/**\n * It displays a checkbox enhanced with the SBB Design.\n *\n * @slot - Use the unnamed slot to add content to the `sbb-checkbox`.\n * @slot icon - Slot used to render the checkbox icon (disabled inside a selection panel).\n * @slot subtext - Slot used to render a subtext under the label (only visible within a selection panel).\n * @slot suffix - Slot used to render additional content after the label (only visible within a selection panel).\n * @event {CustomEvent<void>} didChange - Deprecated. used for React. Will probably be removed once React 19 is available.\n * @event {Event} change - Event fired on change.\n * @event {InputEvent} input - Event fired on input.\n */\n@customElement('sbb-checkbox')\nexport class SbbCheckboxElement extends SbbUpdateSchedulerMixin(\n  SbbFormAssociatedCheckboxMixin(SbbIconNameMixin(SbbHydrationMixin(LitElement))),\n) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    didChange: 'didChange',\n    stateChange: 'stateChange',\n    checkboxLoaded: 'checkboxLoaded',\n  } as const;\n\n  /** Whether the checkbox is indeterminate. */\n  @property({ type: Boolean }) public indeterminate = false;\n\n  /** The label position relative to the labelIcon. Defaults to end */\n  @property({ attribute: 'icon-placement', reflect: true })\n  public iconPlacement: SbbIconPlacement = 'end';\n\n  /** Label size variant, either m or s. */\n  @property({ reflect: true })\n  public set size(value: SbbCheckboxSize) {\n    this._size = value;\n  }\n  public get size(): SbbCheckboxSize {\n    return this.group?.size ?? this._size;\n  }\n  private _size: SbbCheckboxSize = 'm';\n\n  /** Reference to the connected checkbox group. */\n  public get group(): SbbCheckboxGroupElement | null {\n    return this._group;\n  }\n  private _group: SbbCheckboxGroupElement | null = null;\n\n  /**\n   * Whether the input is the main input of a selection panel.\n   * @internal\n   */\n  public get isSelectionPanelInput(): boolean {\n    return this.hasAttribute('data-is-selection-panel-input');\n  }\n\n  /** The label describing whether the selection panel is expanded (for screen readers only). */\n  @state() private _selectionPanelExpandedLabel!: string;\n\n  private _language = new SbbLanguageController(this);\n  private _selectionPanelElement: SbbSelectionPanelElement | null = null;\n\n  /**\n   * @internal\n   * Internal event that emits whenever the state of the checkbox\n   * in relation to the parent selection panel changes.\n   */\n  private _stateChange: EventEmitter<SbbCheckboxStateChange> = new EventEmitter(\n    this,\n    SbbCheckboxElement.events.stateChange,\n    { bubbles: true },\n  );\n\n  /**\n   * @internal\n   * Internal event that emits when the checkbox is loaded.\n   */\n  private _checkboxLoaded: EventEmitter<void> = new EventEmitter(\n    this,\n    SbbCheckboxElement.events.checkboxLoaded,\n    { bubbles: true },\n  );\n\n  public constructor() {\n    super();\n    new SbbSlotStateController(this);\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this._group = this.closest('sbb-checkbox-group') as SbbCheckboxGroupElement;\n    // We can use closest here, as we expect the parent sbb-selection-panel to be in light DOM.\n    this._selectionPanelElement = this.closest?.('sbb-selection-panel');\n    this.toggleAttribute('data-is-inside-selection-panel', !!this._selectionPanelElement);\n    this.toggleAttribute(\n      'data-is-selection-panel-input',\n      !!this._selectionPanelElement && !this.closest?.('sbb-selection-panel [slot=\"content\"]'),\n    );\n\n    this._checkboxLoaded.emit();\n\n    // We need to call requestUpdate to update the reflected attributes\n    ['disabled', 'required', 'size'].forEach((p) => this.requestUpdate(p));\n  }\n\n  protected override async willUpdate(changedProperties: PropertyValues<this>): Promise<void> {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('checked')) {\n      if (this.isSelectionPanelInput && this.checked !== changedProperties.get('checked')!) {\n        this._stateChange.emit({ type: 'checked', checked: this.checked });\n        this._updateExpandedLabel();\n      }\n    }\n    if (changedProperties.has('disabled')) {\n      if (this.isSelectionPanelInput && this.disabled !== changedProperties.get('disabled')!) {\n        this._stateChange.emit({ type: 'disabled', disabled: this.disabled });\n      }\n    }\n    if (changedProperties.has('checked') || changedProperties.has('indeterminate')) {\n      this.internals.ariaChecked = this.indeterminate ? 'mixed' : `${this.checked}`;\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // We need to wait for the selection-panel to be fully initialized\n    this.startUpdate();\n    setTimeout(() => {\n      this.isSelectionPanelInput && this._updateExpandedLabel();\n      this.completeUpdate();\n    });\n  }\n\n  protected override isDisabledExternally(): boolean {\n    return this.group?.disabled ?? false;\n  }\n\n  protected override isRequiredExternally(): boolean {\n    return this.group?.required ?? false;\n  }\n\n  protected override withUserInteraction(): void {\n    if (this.indeterminate) {\n      this.indeterminate = false;\n    }\n  }\n\n  private async _updateExpandedLabel(): Promise<void> {\n    await this.hydrationComplete;\n    if (!this._selectionPanelElement?.hasContent) {\n      this._selectionPanelExpandedLabel = '';\n      this.removeAttribute('data-has-selection-panel-label');\n      return;\n    }\n\n    this._selectionPanelExpandedLabel = this.checked\n      ? ', ' + i18nExpanded[this._language.current]\n      : ', ' + i18nCollapsed[this._language.current];\n    this.toggleAttribute('data-has-selection-panel-label', true);\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <span class=\"sbb-checkbox-wrapper\">\n        <span class=\"sbb-checkbox\">\n          <span class=\"sbb-checkbox__inner\">\n            <span class=\"sbb-checkbox__aligner\">\n              <sbb-visual-checkbox\n                ?checked=${this.checked}\n                ?indeterminate=${this.indeterminate}\n                ?disabled=${this.disabled || this.formDisabled}\n              ></sbb-visual-checkbox>\n            </span>\n            <span class=\"sbb-checkbox__label\">\n              <slot></slot>\n              <span class=\"sbb-checkbox__label--icon\">${this.renderIconSlot()}</span>\n              <slot name=\"suffix\"></slot>\n            </span>\n          </span>\n          <slot name=\"subtext\"></slot>\n          <sbb-screen-reader-only class=\"sbb-checkbox__expanded-label\">\n            ${this._selectionPanelExpandedLabel}\n          </sbb-screen-reader-only>\n        </span>\n      </span>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-checkbox': SbbCheckboxElement;\n  }\n}\n"],"names":[],"mappings":"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"}
105
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9jaGVja2JveC9jaGVja2JveC9jaGVja2JveC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBMaXRFbGVtZW50LCBodG1sLCB0eXBlIENTU1Jlc3VsdEdyb3VwLCB0eXBlIFRlbXBsYXRlUmVzdWx0IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBTYmJTbG90U3RhdGVDb250cm9sbGVyIH0gZnJvbSAnLi4vLi4vY29yZS9jb250cm9sbGVycy5qcyc7XG5pbXBvcnQgdHlwZSB7IFNiYkljb25QbGFjZW1lbnQgfSBmcm9tICcuLi8uLi9jb3JlL2ludGVyZmFjZXMuanMnO1xuaW1wb3J0IHsgU2JiSWNvbk5hbWVNaXhpbiB9IGZyb20gJy4uLy4uL2ljb24uanMnO1xuaW1wb3J0IHsgU2JiQ2hlY2tib3hDb21tb25FbGVtZW50TWl4aW4sIGNoZWNrYm94Q29tbW9uU3R5bGUgfSBmcm9tICcuLi9jb21tb24uanMnO1xuXG5pbXBvcnQgJy4uLy4uL3Zpc3VhbC1jaGVja2JveC5qcyc7XG5cbmltcG9ydCBjaGVja2JveFN0eWxlIGZyb20gJy4vY2hlY2tib3guc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBJdCBkaXNwbGF5cyBhIGNoZWNrYm94IGVuaGFuY2VkIHdpdGggdGhlIFNCQiBEZXNpZ24uXG4gKlxuICogQHNsb3QgLSBVc2UgdGhlIHVubmFtZWQgc2xvdCB0byBhZGQgY29udGVudCB0byB0aGUgYHNiYi1jaGVja2JveGAuXG4gKiBAc2xvdCBpY29uIC0gU2xvdCB1c2VkIHRvIHJlbmRlciB0aGUgY2hlY2tib3ggaWNvbiAoZGlzYWJsZWQgaW5zaWRlIGEgc2VsZWN0aW9uIHBhbmVsKS5cbiAqIEBldmVudCB7Q3VzdG9tRXZlbnQ8dm9pZD59IGRpZENoYW5nZSAtIERlcHJlY2F0ZWQuIHVzZWQgZm9yIFJlYWN0LiBXaWxsIHByb2JhYmx5IGJlIHJlbW92ZWQgb25jZSBSZWFjdCAxOSBpcyBhdmFpbGFibGUuXG4gKiBAZXZlbnQge0V2ZW50fSBjaGFuZ2UgLSBFdmVudCBmaXJlZCBvbiBjaGFuZ2UuXG4gKiBAZXZlbnQge0lucHV0RXZlbnR9IGlucHV0IC0gRXZlbnQgZmlyZWQgb24gaW5wdXQuXG4gKi9cbkBjdXN0b21FbGVtZW50KCdzYmItY2hlY2tib3gnKVxuZXhwb3J0IGNsYXNzIFNiYkNoZWNrYm94RWxlbWVudCBleHRlbmRzIFNiYkNoZWNrYm94Q29tbW9uRWxlbWVudE1peGluKFxuICBTYmJJY29uTmFtZU1peGluKExpdEVsZW1lbnQpLFxuKSB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IFtjaGVja2JveENvbW1vblN0eWxlLCBjaGVja2JveFN0eWxlXTtcblxuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IGV2ZW50cyA9IHtcbiAgICBkaWRDaGFuZ2U6ICdkaWRDaGFuZ2UnLFxuICB9IGFzIGNvbnN0O1xuXG4gIC8qKiBUaGUgbGFiZWwgcG9zaXRpb24gcmVsYXRpdmUgdG8gdGhlIGxhYmVsSWNvbi4gRGVmYXVsdHMgdG8gZW5kICovXG4gIEBwcm9wZXJ0eSh7IGF0dHJpYnV0ZTogJ2ljb24tcGxhY2VtZW50JywgcmVmbGVjdDogdHJ1ZSB9KVxuICBwdWJsaWMgaWNvblBsYWNlbWVudDogU2JiSWNvblBsYWNlbWVudCA9ICdlbmQnO1xuXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuICAgIG5ldyBTYmJTbG90U3RhdGVDb250cm9sbGVyKHRoaXMpO1xuICB9XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgcmV0dXJuIGh0bWxgXG4gICAgICA8c3BhbiBjbGFzcz1cInNiYi1jaGVja2JveC13cmFwcGVyXCI+XG4gICAgICAgIDxzcGFuIGNsYXNzPVwic2JiLWNoZWNrYm94XCI+XG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJzYmItY2hlY2tib3hfX2lubmVyXCI+XG4gICAgICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1jaGVja2JveF9fYWxpZ25lclwiPlxuICAgICAgICAgICAgICA8c2JiLXZpc3VhbC1jaGVja2JveFxuICAgICAgICAgICAgICAgID9jaGVja2VkPSR7dGhpcy5jaGVja2VkfVxuICAgICAgICAgICAgICAgID9pbmRldGVybWluYXRlPSR7dGhpcy5pbmRldGVybWluYXRlfVxuICAgICAgICAgICAgICAgID9kaXNhYmxlZD0ke3RoaXMuZGlzYWJsZWQgfHwgdGhpcy5mb3JtRGlzYWJsZWR9XG4gICAgICAgICAgICAgID48L3NiYi12aXN1YWwtY2hlY2tib3g+XG4gICAgICAgICAgICA8L3NwYW4+XG4gICAgICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1jaGVja2JveF9fbGFiZWxcIj5cbiAgICAgICAgICAgICAgPHNsb3Q+PC9zbG90PlxuICAgICAgICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1jaGVja2JveF9fbGFiZWwtLWljb24gc2JiLWNoZWNrYm94X19hbGlnbmVyXCJcbiAgICAgICAgICAgICAgICA+JHt0aGlzLnJlbmRlckljb25TbG90KCl9PC9zcGFuXG4gICAgICAgICAgICAgID5cbiAgICAgICAgICAgIDwvc3Bhbj5cbiAgICAgICAgICA8L3NwYW4+XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgIDwvc3Bhbj5cbiAgICBgO1xuICB9XG59XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgaW50ZXJmYWNlIEhUTUxFbGVtZW50VGFnTmFtZU1hcCB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuICAgICdzYmItY2hlY2tib3gnOiBTYmJDaGVja2JveEVsZW1lbnQ7XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQXNCTyxJQUFNLHFCQUFOLGNBQWlDO0FBQUEsRUFDdEMsaUJBQWlCLFVBQVU7QUFDN0IsRUFBRTtBQUFBLEVBV08sY0FBYztBQUNiO0FBSFIsU0FBTyxnQkFBa0M7QUFJdkMsUUFBSSx1QkFBdUIsSUFBSTtBQUFBLEVBQ2pDO0FBQUEsRUFFbUIsU0FBeUI7QUFDbkMsV0FBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSwyQkFNZ0IsS0FBSyxPQUFPO0FBQUEsaUNBQ04sS0FBSyxhQUFhO0FBQUEsNEJBQ3ZCLEtBQUssWUFBWSxLQUFLLFlBQVk7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsbUJBTTNDLEtBQUssZ0JBQWdCO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsRUFPdEM7QUFDRjtBQXpDYSxtQkFHWSxTQUF5QixDQUFDLHFCQUFxQixhQUFhO0FBSHhFLG1CQUtZLFNBQVM7QUFBQSxFQUM5QixXQUFXO0FBQ2I7QUFJTyxnQkFBQTtBQUFBLEVBRE4sU0FBUyxFQUFFLFdBQVcsa0JBQWtCLFNBQVMsTUFBTTtBQUFBLEdBVjdDLG1CQVdKLFdBQUEsaUJBQUEsQ0FBQTtBQVhJLHFCQUFOLGdCQUFBO0FBQUEsRUFETixjQUFjLGNBQWM7QUFBQSxHQUNoQixrQkFBQTsifQ==
@@ -0,0 +1,13 @@
1
+ import { LitElement } from 'lit';
2
+ import { Constructor, SbbDisabledMixinType, SbbFormAssociatedCheckboxMixinType, SbbRequiredMixinType } from '../../core/mixins.js';
3
+ import { SbbCheckboxGroupElement } from '../checkbox-group.js';
4
+
5
+ export type SbbCheckboxSize = 's' | 'm';
6
+ export declare class SbbCheckboxCommonElementMixinType extends SbbFormAssociatedCheckboxMixinType implements Partial<SbbDisabledMixinType>, Partial<SbbRequiredMixinType> {
7
+ indeterminate: boolean;
8
+ set size(value: SbbCheckboxSize);
9
+ get size(): SbbCheckboxSize;
10
+ get group(): SbbCheckboxGroupElement | null;
11
+ }
12
+ export declare const SbbCheckboxCommonElementMixin: <T extends Constructor<LitElement>>(superClass: T) => Constructor<SbbCheckboxCommonElementMixinType> & T;
13
+ //# sourceMappingURL=checkbox-common.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"checkbox-common.d.ts","sourceRoot":"","sources":["../../../../../src/elements/checkbox/common/checkbox-common.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAkB,MAAM,KAAK,CAAC;AAGtD,OAAO,EACL,KAAK,WAAW,EAChB,KAAK,oBAAoB,EAEzB,KAAK,kCAAkC,EACvC,KAAK,oBAAoB,EAC1B,MAAM,sBAAsB,CAAC;AAC9B,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,sBAAsB,CAAC;AAEpE,MAAM,MAAM,eAAe,GAAG,GAAG,GAAG,GAAG,CAAC;AAExC,MAAM,CAAC,OAAO,OAAO,iCACnB,SAAQ,kCACR,YAAW,OAAO,CAAC,oBAAoB,CAAC,EAAE,OAAO,CAAC,oBAAoB,CAAC;IAEhE,aAAa,EAAE,OAAO,CAAC;IAE9B,IAAW,IAAI,CAAC,KAAK,EAAE,eAAe,EAAE;IACxC,IAAW,IAAI,IAAI,eAAe,CAAC;IAEnC,IAAW,KAAK,IAAI,uBAAuB,GAAG,IAAI,CAAC;CACpD;AAGD,eAAO,MAAM,6BAA6B,kDAC5B,CAAC,KACZ,YAAY,iCAAiC,CAAC,GAAG,CAuDnD,CAAC"}
@@ -0,0 +1,2 @@
1
+ export * from './common/checkbox-common.js';
2
+ //# sourceMappingURL=common.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../../../src/elements/checkbox/common.ts"],"names":[],"mappings":"AAAA,cAAc,6BAA6B,CAAC;AAE5C,OAAO,EAAE,OAAO,IAAI,mBAAmB,EAAE,MAAM,0CAA0C,CAAC"}
@@ -0,0 +1,156 @@
1
+ import { property } from "lit/decorators.js";
2
+ import { SbbFormAssociatedCheckboxMixin } from "../core/mixins.js";
3
+ import { css } from "lit";
4
+ var __defProp = Object.defineProperty;
5
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
+ var __decorateClass = (decorators, target, key, kind) => {
7
+ var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
8
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
9
+ if (decorator = decorators[i])
10
+ result = (kind ? decorator(target, key, result) : decorator(result)) || result;
11
+ if (kind && result) __defProp(target, key, result);
12
+ return result;
13
+ };
14
+ const SbbCheckboxCommonElementMixin = (superClass) => {
15
+ class SbbCheckboxCommonElement extends SbbFormAssociatedCheckboxMixin(superClass) {
16
+ constructor() {
17
+ super(...arguments);
18
+ this.indeterminate = false;
19
+ this._size = "m";
20
+ this._group = null;
21
+ }
22
+ set size(value) {
23
+ this._size = value;
24
+ }
25
+ get size() {
26
+ var _a;
27
+ return ((_a = this.group) == null ? void 0 : _a.size) ?? this._size;
28
+ }
29
+ /** Reference to the connected checkbox group. */
30
+ get group() {
31
+ return this._group;
32
+ }
33
+ connectedCallback() {
34
+ super.connectedCallback();
35
+ this._group = this.closest("sbb-checkbox-group");
36
+ ["disabled", "required", "size"].forEach((p) => this.requestUpdate(p));
37
+ }
38
+ async willUpdate(changedProperties) {
39
+ super.willUpdate(changedProperties);
40
+ if (changedProperties.has("checked") || changedProperties.has("indeterminate")) {
41
+ this.internals.ariaChecked = this.indeterminate ? "mixed" : `${this.checked}`;
42
+ }
43
+ }
44
+ isDisabledExternally() {
45
+ var _a;
46
+ return ((_a = this.group) == null ? void 0 : _a.disabled) ?? false;
47
+ }
48
+ isRequiredExternally() {
49
+ var _a;
50
+ return ((_a = this.group) == null ? void 0 : _a.required) ?? false;
51
+ }
52
+ withUserInteraction() {
53
+ if (this.indeterminate) {
54
+ this.indeterminate = false;
55
+ }
56
+ }
57
+ }
58
+ __decorateClass([
59
+ property({ type: Boolean })
60
+ ], SbbCheckboxCommonElement.prototype, "indeterminate", 2);
61
+ __decorateClass([
62
+ property({ reflect: true })
63
+ ], SbbCheckboxCommonElement.prototype, "size", 1);
64
+ return SbbCheckboxCommonElement;
65
+ };
66
+ const checkboxCommon = css`@charset "UTF-8";
67
+ /**
68
+ * Better font rendering (on OS X)
69
+ * http://maximilianhoffmann.com/posts/better-font-rendering-on-osx
70
+ *
71
+ * Usage:
72
+ *
73
+ * .var_dark_on_light {
74
+ * @include font-smoothing;
75
+ * }
76
+ * .var_light_on_dark {
77
+ * @include font-smoothing-reset;
78
+ * }
79
+ */
80
+ /** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
81
+ *,
82
+ ::before,
83
+ ::after {
84
+ box-sizing: border-box;
85
+ }
86
+
87
+ :host {
88
+ --sbb-checkbox-dimension: var(--sbb-size-icon-ui-small);
89
+ --sbb-checkbox-label-color: var(--sbb-color-charcoal);
90
+ --sbb-checkbox-label-icon-color: var(--sbb-color-charcoal);
91
+ --sbb-checkbox-cursor: pointer;
92
+ --sbb-checkbox-label-gap: var(--sbb-spacing-fixed-2x);
93
+ }
94
+
95
+ :host(:disabled) {
96
+ --sbb-checkbox-cursor: default;
97
+ --sbb-checkbox-label-color: var(--sbb-color-granite);
98
+ }
99
+
100
+ .sbb-checkbox-wrapper {
101
+ display: flex;
102
+ }
103
+ .sbb-checkbox-wrapper::before {
104
+ content: "​";
105
+ user-select: none;
106
+ width: 0;
107
+ height: 0;
108
+ }
109
+
110
+ .sbb-checkbox {
111
+ --sbb-text-font-size: var(--sbb-font-size-text-m);
112
+ font-family: var(--sbb-typo-font-family);
113
+ font-weight: normal;
114
+ line-height: var(--sbb-typo-line-height-body-text);
115
+ letter-spacing: var(--sbb-typo-letter-spacing-body-text);
116
+ font-size: var(--sbb-text-font-size);
117
+ position: relative;
118
+ display: block;
119
+ width: 100%;
120
+ cursor: var(--sbb-checkbox-cursor);
121
+ user-select: none;
122
+ -webkit-tap-highlight-color: transparent;
123
+ }
124
+ :host([size=s]) .sbb-checkbox {
125
+ --sbb-text-font-size: var(--sbb-font-size-text-s);
126
+ font-family: var(--sbb-typo-font-family);
127
+ font-weight: normal;
128
+ line-height: var(--sbb-typo-line-height-body-text);
129
+ letter-spacing: var(--sbb-typo-letter-spacing-body-text);
130
+ font-size: var(--sbb-text-font-size);
131
+ }
132
+
133
+ .sbb-checkbox__inner {
134
+ display: flex;
135
+ align-items: start;
136
+ gap: var(--sbb-spacing-fixed-2x);
137
+ }
138
+
139
+ .sbb-checkbox__label {
140
+ display: flex;
141
+ gap: var(--sbb-checkbox-label-gap);
142
+ flex-grow: 1;
143
+ color: var(--sbb-checkbox-label-color);
144
+ line-height: max(1em * var(--sbb-typo-line-height-body-text), var(--sbb-checkbox-dimension));
145
+ }
146
+
147
+ .sbb-checkbox__aligner {
148
+ display: flex;
149
+ align-items: center;
150
+ height: calc(1em * var(--sbb-typo-line-height-body-text));
151
+ }`;
152
+ export {
153
+ SbbCheckboxCommonElementMixin,
154
+ checkboxCommon as checkboxCommonStyle
155
+ };
156
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMvY2hlY2tib3gvY29tbW9uL2NoZWNrYm94LWNvbW1vbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IExpdEVsZW1lbnQsIFByb3BlcnR5VmFsdWVzIH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQge1xuICB0eXBlIENvbnN0cnVjdG9yLFxuICB0eXBlIFNiYkRpc2FibGVkTWl4aW5UeXBlLFxuICBTYmJGb3JtQXNzb2NpYXRlZENoZWNrYm94TWl4aW4sXG4gIHR5cGUgU2JiRm9ybUFzc29jaWF0ZWRDaGVja2JveE1peGluVHlwZSxcbiAgdHlwZSBTYmJSZXF1aXJlZE1peGluVHlwZSxcbn0gZnJvbSAnLi4vLi4vY29yZS9taXhpbnMuanMnO1xuaW1wb3J0IHR5cGUgeyBTYmJDaGVja2JveEdyb3VwRWxlbWVudCB9IGZyb20gJy4uL2NoZWNrYm94LWdyb3VwLmpzJztcblxuZXhwb3J0IHR5cGUgU2JiQ2hlY2tib3hTaXplID0gJ3MnIHwgJ20nO1xuXG5leHBvcnQgZGVjbGFyZSBjbGFzcyBTYmJDaGVja2JveENvbW1vbkVsZW1lbnRNaXhpblR5cGVcbiAgZXh0ZW5kcyBTYmJGb3JtQXNzb2NpYXRlZENoZWNrYm94TWl4aW5UeXBlXG4gIGltcGxlbWVudHMgUGFydGlhbDxTYmJEaXNhYmxlZE1peGluVHlwZT4sIFBhcnRpYWw8U2JiUmVxdWlyZWRNaXhpblR5cGU+XG57XG4gIHB1YmxpYyBpbmRldGVybWluYXRlOiBib29sZWFuO1xuXG4gIHB1YmxpYyBzZXQgc2l6ZSh2YWx1ZTogU2JiQ2hlY2tib3hTaXplKTtcbiAgcHVibGljIGdldCBzaXplKCk6IFNiYkNoZWNrYm94U2l6ZTtcblxuICBwdWJsaWMgZ2V0IGdyb3VwKCk6IFNiYkNoZWNrYm94R3JvdXBFbGVtZW50IHwgbnVsbDtcbn1cblxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuZXhwb3J0IGNvbnN0IFNiYkNoZWNrYm94Q29tbW9uRWxlbWVudE1peGluID0gPFQgZXh0ZW5kcyBDb25zdHJ1Y3RvcjxMaXRFbGVtZW50Pj4oXG4gIHN1cGVyQ2xhc3M6IFQsXG4pOiBDb25zdHJ1Y3RvcjxTYmJDaGVja2JveENvbW1vbkVsZW1lbnRNaXhpblR5cGU+ICYgVCA9PiB7XG4gIGFic3RyYWN0IGNsYXNzIFNiYkNoZWNrYm94Q29tbW9uRWxlbWVudFxuICAgIGV4dGVuZHMgU2JiRm9ybUFzc29jaWF0ZWRDaGVja2JveE1peGluKHN1cGVyQ2xhc3MpXG4gICAgaW1wbGVtZW50cyBQYXJ0aWFsPFNiYkNoZWNrYm94Q29tbW9uRWxlbWVudE1peGluVHlwZT5cbiAge1xuICAgIC8qKiBXaGV0aGVyIHRoZSBjaGVja2JveCBpcyBpbmRldGVybWluYXRlLiAqL1xuICAgIEBwcm9wZXJ0eSh7IHR5cGU6IEJvb2xlYW4gfSkgcHVibGljIGluZGV0ZXJtaW5hdGUgPSBmYWxzZTtcblxuICAgIC8qKiBMYWJlbCBzaXplIHZhcmlhbnQsIGVpdGhlciBtIG9yIHMuICovXG4gICAgQHByb3BlcnR5KHsgcmVmbGVjdDogdHJ1ZSB9KVxuICAgIHB1YmxpYyBzZXQgc2l6ZSh2YWx1ZTogU2JiQ2hlY2tib3hTaXplKSB7XG4gICAgICB0aGlzLl9zaXplID0gdmFsdWU7XG4gICAgfVxuICAgIHB1YmxpYyBnZXQgc2l6ZSgpOiBTYmJDaGVja2JveFNpemUge1xuICAgICAgcmV0dXJuIHRoaXMuZ3JvdXA/LnNpemUgPz8gdGhpcy5fc2l6ZTtcbiAgICB9XG4gICAgcHJpdmF0ZSBfc2l6ZTogU2JiQ2hlY2tib3hTaXplID0gJ20nO1xuXG4gICAgLyoqIFJlZmVyZW5jZSB0byB0aGUgY29ubmVjdGVkIGNoZWNrYm94IGdyb3VwLiAqL1xuICAgIHB1YmxpYyBnZXQgZ3JvdXAoKTogU2JiQ2hlY2tib3hHcm91cEVsZW1lbnQgfCBudWxsIHtcbiAgICAgIHJldHVybiB0aGlzLl9ncm91cDtcbiAgICB9XG4gICAgcHJpdmF0ZSBfZ3JvdXA6IFNiYkNoZWNrYm94R3JvdXBFbGVtZW50IHwgbnVsbCA9IG51bGw7XG5cbiAgICBwdWJsaWMgb3ZlcnJpZGUgY29ubmVjdGVkQ2FsbGJhY2soKTogdm9pZCB7XG4gICAgICBzdXBlci5jb25uZWN0ZWRDYWxsYmFjaygpO1xuICAgICAgdGhpcy5fZ3JvdXAgPSB0aGlzLmNsb3Nlc3QoJ3NiYi1jaGVja2JveC1ncm91cCcpIGFzIFNiYkNoZWNrYm94R3JvdXBFbGVtZW50O1xuXG4gICAgICAvLyBXZSBuZWVkIHRvIGNhbGwgcmVxdWVzdFVwZGF0ZSB0byB1cGRhdGUgdGhlIHJlZmxlY3RlZCBhdHRyaWJ1dGVzXG4gICAgICBbJ2Rpc2FibGVkJywgJ3JlcXVpcmVkJywgJ3NpemUnXS5mb3JFYWNoKChwKSA9PiB0aGlzLnJlcXVlc3RVcGRhdGUocCkpO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBvdmVycmlkZSBhc3luYyB3aWxsVXBkYXRlKGNoYW5nZWRQcm9wZXJ0aWVzOiBQcm9wZXJ0eVZhbHVlczx0aGlzPik6IFByb21pc2U8dm9pZD4ge1xuICAgICAgc3VwZXIud2lsbFVwZGF0ZShjaGFuZ2VkUHJvcGVydGllcyk7XG5cbiAgICAgIGlmIChjaGFuZ2VkUHJvcGVydGllcy5oYXMoJ2NoZWNrZWQnKSB8fCBjaGFuZ2VkUHJvcGVydGllcy5oYXMoJ2luZGV0ZXJtaW5hdGUnKSkge1xuICAgICAgICB0aGlzLmludGVybmFscy5hcmlhQ2hlY2tlZCA9IHRoaXMuaW5kZXRlcm1pbmF0ZSA/ICdtaXhlZCcgOiBgJHt0aGlzLmNoZWNrZWR9YDtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgb3ZlcnJpZGUgaXNEaXNhYmxlZEV4dGVybmFsbHkoKTogYm9vbGVhbiB7XG4gICAgICByZXR1cm4gdGhpcy5ncm91cD8uZGlzYWJsZWQgPz8gZmFsc2U7XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIG92ZXJyaWRlIGlzUmVxdWlyZWRFeHRlcm5hbGx5KCk6IGJvb2xlYW4ge1xuICAgICAgcmV0dXJuIHRoaXMuZ3JvdXA/LnJlcXVpcmVkID8/IGZhbHNlO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBvdmVycmlkZSB3aXRoVXNlckludGVyYWN0aW9uKCk6IHZvaWQge1xuICAgICAgaWYgKHRoaXMuaW5kZXRlcm1pbmF0ZSkge1xuICAgICAgICB0aGlzLmluZGV0ZXJtaW5hdGUgPSBmYWxzZTtcbiAgICAgIH1cbiAgICB9XG4gIH1cbiAgcmV0dXJuIFNiYkNoZWNrYm94Q29tbW9uRWxlbWVudCBhcyB1bmtub3duIGFzIENvbnN0cnVjdG9yPFNiYkNoZWNrYm94Q29tbW9uRWxlbWVudE1peGluVHlwZT4gJiBUO1xufTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7O0FBMkJhLE1BQUEsZ0NBQWdDLENBQzNDLGVBQ3VEO0FBQUEsRUFDdkQsTUFBZSxpQ0FDTCwrQkFBK0IsVUFBVSxFQUVuRDtBQUFBLElBSEEsY0FBQTtBQUFBLFlBQUEsR0FBQSxTQUFBO0FBSytCLFdBQU8sZ0JBQWdCO0FBVXBELFdBQVEsUUFBeUI7QUFNakMsV0FBUSxTQUF5QztBQUFBLElBQUE7QUFBQSxJQVpqRCxJQUFXLEtBQUssT0FBd0I7QUFDdEMsV0FBSyxRQUFRO0FBQUEsSUFDZjtBQUFBLElBQ0EsSUFBVyxPQUF3Qjs7QUFDMUIsZUFBQSxVQUFLLFVBQUwsbUJBQVksU0FBUSxLQUFLO0FBQUEsSUFDbEM7QUFBQTtBQUFBLElBSUEsSUFBVyxRQUF3QztBQUNqRCxhQUFPLEtBQUs7QUFBQSxJQUNkO0FBQUEsSUFHZ0Isb0JBQTBCO0FBQ3hDLFlBQU0sa0JBQWtCO0FBQ25CLFdBQUEsU0FBUyxLQUFLLFFBQVEsb0JBQW9CO0FBRzlDLE9BQUEsWUFBWSxZQUFZLE1BQU0sRUFBRSxRQUFRLENBQUMsTUFBTSxLQUFLLGNBQWMsQ0FBQyxDQUFDO0FBQUEsSUFDdkU7QUFBQSxJQUVBLE1BQXlCLFdBQVcsbUJBQXdEO0FBQzFGLFlBQU0sV0FBVyxpQkFBaUI7QUFFbEMsVUFBSSxrQkFBa0IsSUFBSSxTQUFTLEtBQUssa0JBQWtCLElBQUksZUFBZSxHQUFHO0FBQzlFLGFBQUssVUFBVSxjQUFjLEtBQUssZ0JBQWdCLFVBQVUsR0FBRyxLQUFLLE9BQU87QUFBQSxNQUM3RTtBQUFBLElBQ0Y7QUFBQSxJQUVtQix1QkFBZ0M7O0FBQzFDLGVBQUEsVUFBSyxVQUFMLG1CQUFZLGFBQVk7QUFBQSxJQUNqQztBQUFBLElBRW1CLHVCQUFnQzs7QUFDMUMsZUFBQSxVQUFLLFVBQUwsbUJBQVksYUFBWTtBQUFBLElBQ2pDO0FBQUEsSUFFbUIsc0JBQTRCO0FBQzdDLFVBQUksS0FBSyxlQUFlO0FBQ3RCLGFBQUssZ0JBQWdCO0FBQUEsTUFDdkI7QUFBQSxJQUNGO0FBQUEsRUFDRjtBQS9Dc0Msa0JBQUE7QUFBQSxJQUFuQyxTQUFTLEVBQUUsTUFBTSxTQUFTO0FBQUEsRUFBQSxHQUxkLHlCQUt1QixXQUFBLGlCQUFBLENBQUE7QUFJekIsa0JBQUE7QUFBQSxJQURWLFNBQVMsRUFBRSxTQUFTLE1BQU07QUFBQSxFQUFBLEdBUmQseUJBU0YsV0FBQSxRQUFBLENBQUE7QUE0Q04sU0FBQTtBQUNUOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7In0=
@@ -1,3 +1,5 @@
1
1
  export * from './checkbox/checkbox.js';
2
2
  export * from './checkbox/checkbox-group.js';
3
+ export * from './checkbox/checkbox-panel.js';
4
+ export * from './checkbox/common.js';
3
5
  //# sourceMappingURL=checkbox.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"checkbox.d.ts","sourceRoot":"","sources":["../../../src/elements/checkbox.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAC;AACvC,cAAc,8BAA8B,CAAC"}
1
+ {"version":3,"file":"checkbox.d.ts","sourceRoot":"","sources":["../../../src/elements/checkbox.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAC;AACvC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,8BAA8B,CAAC;AAC7C,cAAc,sBAAsB,CAAC"}
@@ -1,3 +1,5 @@
1
1
  export * from "./checkbox/checkbox.js";
2
2
  export * from "./checkbox/checkbox-group.js";
3
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzsifQ==
3
+ export * from "./checkbox/checkbox-panel.js";
4
+ export * from "./checkbox/common.js";
5
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OyJ9
@@ -0,0 +1,13 @@
1
+ import { LitElement } from 'lit';
2
+ import { AbstractConstructor } from './constructor.js';
3
+
4
+ export declare class SbbPanelMixinType {
5
+ color: 'white' | 'milk';
6
+ borderless: boolean;
7
+ expansionState?: string;
8
+ }
9
+ /**
10
+ * Mixin for common panel behaviors
11
+ */
12
+ export declare const SbbPanelMixin: <T extends AbstractConstructor<LitElement>>(superClass: T) => AbstractConstructor<SbbPanelMixinType> & T;
13
+ //# sourceMappingURL=panel-mixin.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"panel-mixin.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/mixins/panel-mixin.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,KAAK,CAAC;AAKtC,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAE5D,MAAM,CAAC,OAAO,OAAO,iBAAiB;IAC7B,KAAK,EAAE,OAAO,GAAG,MAAM,CAAC;IACxB,UAAU,EAAE,OAAO,CAAC;IACpB,cAAc,CAAC,EAAE,MAAM,CAAC;CAChC;AAED;;GAEG;AAEH,eAAO,MAAM,aAAa,0DACZ,CAAC,KACZ,oBAAoB,iBAAiB,CAAC,GAAG,CAiC3C,CAAC"}
@@ -5,6 +5,7 @@ export * from './mixins/form-associated-mixin.js';
5
5
  export * from './mixins/hydration-mixin.js';
6
6
  export * from './mixins/named-slot-list-mixin.js';
7
7
  export * from './mixins/negative-mixin.js';
8
+ export * from './mixins/panel-mixin.js';
8
9
  export * from './mixins/required-mixin.js';
9
10
  export * from './mixins/update-scheduler-mixin.js';
10
11
  //# sourceMappingURL=mixins.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"mixins.d.ts","sourceRoot":"","sources":["../../../../src/elements/core/mixins.ts"],"names":[],"mappings":"AAAA,cAAc,yBAAyB,CAAC;AACxC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,4CAA4C,CAAC;AAC3D,cAAc,mCAAmC,CAAC;AAClD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,mCAAmC,CAAC;AAClD,cAAc,4BAA4B,CAAC;AAC3C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,oCAAoC,CAAC"}
1
+ {"version":3,"file":"mixins.d.ts","sourceRoot":"","sources":["../../../../src/elements/core/mixins.ts"],"names":[],"mappings":"AAAA,cAAc,yBAAyB,CAAC;AACxC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,4CAA4C,CAAC;AAC3D,cAAc,mCAAmC,CAAC;AAClD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,mCAAmC,CAAC;AAClD,cAAc,4BAA4B,CAAC;AAC3C,cAAc,yBAAyB,CAAC;AACxC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,oCAAoC,CAAC;AAEnD,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,uCAAuC,CAAC"}