@sbb-esta/lyne-elements 1.3.0 → 1.5.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 (305) hide show
  1. package/autocomplete/autocomplete-base-element.d.ts +93 -0
  2. package/autocomplete/autocomplete-base-element.d.ts.map +1 -0
  3. package/autocomplete/autocomplete.d.ts +13 -86
  4. package/autocomplete/autocomplete.d.ts.map +1 -1
  5. package/autocomplete-grid/autocomplete-grid/autocomplete-grid.d.ts +45 -0
  6. package/autocomplete-grid/autocomplete-grid/autocomplete-grid.d.ts.map +1 -0
  7. package/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.d.ts +33 -0
  8. package/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.d.ts.map +1 -0
  9. package/autocomplete-grid/autocomplete-grid-button.d.ts +2 -0
  10. package/autocomplete-grid/autocomplete-grid-button.d.ts.map +1 -0
  11. package/autocomplete-grid/autocomplete-grid-button.js +66 -0
  12. package/autocomplete-grid/autocomplete-grid-cell/autocomplete-grid-cell.d.ts +17 -0
  13. package/autocomplete-grid/autocomplete-grid-cell/autocomplete-grid-cell.d.ts.map +1 -0
  14. package/autocomplete-grid/autocomplete-grid-cell.d.ts +2 -0
  15. package/autocomplete-grid/autocomplete-grid-cell.d.ts.map +1 -0
  16. package/autocomplete-grid/autocomplete-grid-cell.js +28 -0
  17. package/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.d.ts +21 -0
  18. package/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.d.ts.map +1 -0
  19. package/autocomplete-grid/autocomplete-grid-optgroup/index.d.ts +2 -0
  20. package/autocomplete-grid/autocomplete-grid-optgroup/index.d.ts.map +1 -0
  21. package/autocomplete-grid/autocomplete-grid-optgroup.d.ts +2 -0
  22. package/autocomplete-grid/autocomplete-grid-optgroup.d.ts.map +1 -0
  23. package/autocomplete-grid/autocomplete-grid-optgroup.js +37 -0
  24. package/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.d.ts +40 -0
  25. package/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.d.ts.map +1 -0
  26. package/autocomplete-grid/autocomplete-grid-option.d.ts +2 -0
  27. package/autocomplete-grid/autocomplete-grid-option.d.ts.map +1 -0
  28. package/autocomplete-grid/autocomplete-grid-option.js +67 -0
  29. package/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.d.ts +18 -0
  30. package/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.d.ts.map +1 -0
  31. package/autocomplete-grid/autocomplete-grid-row.d.ts +2 -0
  32. package/autocomplete-grid/autocomplete-grid-row.d.ts.map +1 -0
  33. package/autocomplete-grid/autocomplete-grid-row.js +31 -0
  34. package/autocomplete-grid/autocomplete-grid.d.ts +2 -0
  35. package/autocomplete-grid/autocomplete-grid.d.ts.map +1 -0
  36. package/autocomplete-grid/autocomplete-grid.js +139 -0
  37. package/autocomplete-grid.d.ts +7 -0
  38. package/autocomplete-grid.d.ts.map +1 -0
  39. package/autocomplete-grid.js +6 -0
  40. package/autocomplete.d.ts +1 -0
  41. package/autocomplete.d.ts.map +1 -1
  42. package/autocomplete.js +162 -145
  43. package/breadcrumb/breadcrumb-group/breadcrumb-group.d.ts.map +1 -1
  44. package/button/mini-button/mini-button-base-element.d.ts +9 -0
  45. package/button/mini-button/mini-button-base-element.d.ts.map +1 -0
  46. package/button/mini-button/mini-button.d.ts +3 -4
  47. package/button/mini-button/mini-button.d.ts.map +1 -1
  48. package/button/mini-button.d.ts +1 -0
  49. package/button/mini-button.d.ts.map +1 -1
  50. package/button/mini-button.js +23 -13
  51. package/checkbox/checkbox/checkbox.d.ts +5 -0
  52. package/checkbox/checkbox/checkbox.d.ts.map +1 -1
  53. package/checkbox/checkbox-panel/checkbox-panel.d.ts +5 -0
  54. package/checkbox/checkbox-panel/checkbox-panel.d.ts.map +1 -1
  55. package/checkbox/checkbox-panel.js +28 -18
  56. package/checkbox/checkbox.js +30 -19
  57. package/checkbox/common/checkbox-common.d.ts +1 -3
  58. package/checkbox/common/checkbox-common.d.ts.map +1 -1
  59. package/checkbox/common.js +16 -25
  60. package/container/container.js +3 -3
  61. package/core/i18n/i18n.d.ts +2 -0
  62. package/core/i18n/i18n.d.ts.map +1 -1
  63. package/core/i18n.js +61 -49
  64. package/core/mixins/form-associated-mixin.d.ts.map +1 -1
  65. package/core/mixins/panel-mixin.d.ts +1 -0
  66. package/core/mixins/panel-mixin.d.ts.map +1 -1
  67. package/core/mixins.js +3 -1
  68. package/core/overlay/overlay-trigger-attributes.d.ts +1 -1
  69. package/core/overlay/overlay-trigger-attributes.d.ts.map +1 -1
  70. package/core/overlay.js +2 -2
  71. package/core/styles/core.scss +1 -0
  72. package/core/styles/mixins/buttons.scss +13 -8
  73. package/core/styles/mixins/helpers.scss +1 -0
  74. package/core/styles/mixins/pearl-chain-bullet.scss +1 -1
  75. package/core/styles/node_modules_@sbb-esta_lyne-design-tokens_dist_scss_sbb-variables.scss +1 -0
  76. package/core/styles/node_modules_@sbb-esta_lyne-design-tokens_dist_scss_sbb-variables_css--mixin.scss +2 -1
  77. package/core.css +3 -1
  78. package/custom-elements.json +14325 -9229
  79. package/datepicker/datepicker-next-day.js +12 -12
  80. package/datepicker/datepicker-previous-day.js +1 -1
  81. package/development/autocomplete/autocomplete-base-element.d.ts +93 -0
  82. package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -0
  83. package/development/autocomplete/autocomplete.d.ts +13 -86
  84. package/development/autocomplete/autocomplete.d.ts.map +1 -1
  85. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.d.ts +45 -0
  86. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.d.ts.map +1 -0
  87. package/development/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.d.ts +33 -0
  88. package/development/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.d.ts.map +1 -0
  89. package/development/autocomplete-grid/autocomplete-grid-button.d.ts +2 -0
  90. package/development/autocomplete-grid/autocomplete-grid-button.d.ts.map +1 -0
  91. package/development/autocomplete-grid/autocomplete-grid-button.js +224 -0
  92. package/development/autocomplete-grid/autocomplete-grid-cell/autocomplete-grid-cell.d.ts +17 -0
  93. package/development/autocomplete-grid/autocomplete-grid-cell/autocomplete-grid-cell.d.ts.map +1 -0
  94. package/development/autocomplete-grid/autocomplete-grid-cell.d.ts +2 -0
  95. package/development/autocomplete-grid/autocomplete-grid-cell.d.ts.map +1 -0
  96. package/development/autocomplete-grid/autocomplete-grid-cell.js +67 -0
  97. package/development/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.d.ts +21 -0
  98. package/development/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.d.ts.map +1 -0
  99. package/development/autocomplete-grid/autocomplete-grid-optgroup/index.d.ts +2 -0
  100. package/development/autocomplete-grid/autocomplete-grid-optgroup/index.d.ts.map +1 -0
  101. package/development/autocomplete-grid/autocomplete-grid-optgroup.d.ts +2 -0
  102. package/development/autocomplete-grid/autocomplete-grid-optgroup.d.ts.map +1 -0
  103. package/development/autocomplete-grid/autocomplete-grid-optgroup.js +45 -0
  104. package/development/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.d.ts +40 -0
  105. package/development/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.d.ts.map +1 -0
  106. package/development/autocomplete-grid/autocomplete-grid-option.d.ts +2 -0
  107. package/development/autocomplete-grid/autocomplete-grid-option.d.ts.map +1 -0
  108. package/development/autocomplete-grid/autocomplete-grid-option.js +174 -0
  109. package/development/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.d.ts +18 -0
  110. package/development/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.d.ts.map +1 -0
  111. package/development/autocomplete-grid/autocomplete-grid-row.d.ts +2 -0
  112. package/development/autocomplete-grid/autocomplete-grid-row.d.ts.map +1 -0
  113. package/development/autocomplete-grid/autocomplete-grid-row.js +143 -0
  114. package/development/autocomplete-grid/autocomplete-grid.d.ts +2 -0
  115. package/development/autocomplete-grid/autocomplete-grid.d.ts.map +1 -0
  116. package/development/autocomplete-grid/autocomplete-grid.js +185 -0
  117. package/development/autocomplete-grid.d.ts +7 -0
  118. package/development/autocomplete-grid.d.ts.map +1 -0
  119. package/development/autocomplete-grid.js +7 -0
  120. package/development/autocomplete.d.ts +1 -0
  121. package/development/autocomplete.d.ts.map +1 -1
  122. package/development/autocomplete.js +168 -143
  123. package/development/breadcrumb/breadcrumb-group/breadcrumb-group.d.ts.map +1 -1
  124. package/development/breadcrumb/breadcrumb-group.js +1 -1
  125. package/development/button/mini-button/mini-button-base-element.d.ts +9 -0
  126. package/development/button/mini-button/mini-button-base-element.d.ts.map +1 -0
  127. package/development/button/mini-button/mini-button.d.ts +3 -4
  128. package/development/button/mini-button/mini-button.d.ts.map +1 -1
  129. package/development/button/mini-button.d.ts +1 -0
  130. package/development/button/mini-button.d.ts.map +1 -1
  131. package/development/button/mini-button.js +32 -16
  132. package/development/checkbox/checkbox/checkbox.d.ts +5 -0
  133. package/development/checkbox/checkbox/checkbox.d.ts.map +1 -1
  134. package/development/checkbox/checkbox-panel/checkbox-panel.d.ts +5 -0
  135. package/development/checkbox/checkbox-panel/checkbox-panel.d.ts.map +1 -1
  136. package/development/checkbox/checkbox-panel.js +13 -2
  137. package/development/checkbox/checkbox.js +19 -1
  138. package/development/checkbox/common/checkbox-common.d.ts +1 -3
  139. package/development/checkbox/common/checkbox-common.d.ts.map +1 -1
  140. package/development/checkbox/common.js +13 -19
  141. package/development/container/container.js +2 -1
  142. package/development/core/i18n/i18n.d.ts +2 -0
  143. package/development/core/i18n/i18n.d.ts.map +1 -1
  144. package/development/core/i18n.js +15 -1
  145. package/development/core/mixins/form-associated-mixin.d.ts.map +1 -1
  146. package/development/core/mixins/panel-mixin.d.ts +1 -0
  147. package/development/core/mixins/panel-mixin.d.ts.map +1 -1
  148. package/development/core/mixins.js +4 -2
  149. package/development/core/overlay/overlay-trigger-attributes.d.ts +1 -1
  150. package/development/core/overlay/overlay-trigger-attributes.d.ts.map +1 -1
  151. package/development/core/overlay.js +3 -3
  152. package/development/datepicker/datepicker-next-day.js +8 -7
  153. package/development/datepicker/datepicker-previous-day.js +8 -7
  154. package/development/flip-card/flip-card/flip-card.d.ts +32 -0
  155. package/development/flip-card/flip-card/flip-card.d.ts.map +1 -0
  156. package/development/flip-card/flip-card/index.d.ts +2 -0
  157. package/development/flip-card/flip-card/index.d.ts.map +1 -0
  158. package/development/flip-card/flip-card-details/flip-card-details.d.ts +22 -0
  159. package/development/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -0
  160. package/development/flip-card/flip-card-details/index.d.ts +2 -0
  161. package/development/flip-card/flip-card-details/index.d.ts.map +1 -0
  162. package/development/flip-card/flip-card-details.d.ts +2 -0
  163. package/development/flip-card/flip-card-details.d.ts.map +1 -0
  164. package/development/flip-card/flip-card-details.js +105 -0
  165. package/development/flip-card/flip-card-summary/flip-card-summary.d.ts +22 -0
  166. package/development/flip-card/flip-card-summary/flip-card-summary.d.ts.map +1 -0
  167. package/development/flip-card/flip-card-summary/index.d.ts +2 -0
  168. package/development/flip-card/flip-card-summary/index.d.ts.map +1 -0
  169. package/development/flip-card/flip-card-summary.d.ts +2 -0
  170. package/development/flip-card/flip-card-summary.d.ts.map +1 -0
  171. package/development/flip-card/flip-card-summary.js +151 -0
  172. package/development/flip-card/flip-card.d.ts +2 -0
  173. package/development/flip-card/flip-card.d.ts.map +1 -0
  174. package/development/flip-card/flip-card.js +187 -0
  175. package/development/flip-card.d.ts +4 -0
  176. package/development/flip-card.d.ts.map +1 -0
  177. package/development/flip-card.js +4 -0
  178. package/development/form-field/form-field-clear/form-field-clear.d.ts.map +1 -1
  179. package/development/form-field/form-field-clear.js +8 -7
  180. package/development/form-field/form-field.js +3 -3
  181. package/development/icon/icon-base.d.ts.map +1 -1
  182. package/development/icon/icon.d.ts.map +1 -1
  183. package/development/icon.js +1 -1
  184. package/development/image/image.d.ts +1 -0
  185. package/development/image/image.d.ts.map +1 -1
  186. package/development/image.js +10 -4
  187. package/development/map-container.js +12 -14
  188. package/development/navigation/navigation-marker/navigation-marker.d.ts.map +1 -1
  189. package/development/navigation/navigation-marker.js +1 -1
  190. package/development/option/optgroup/optgroup-base-element.d.ts +28 -0
  191. package/development/option/optgroup/optgroup-base-element.d.ts.map +1 -0
  192. package/development/option/optgroup/optgroup.d.ts +7 -20
  193. package/development/option/optgroup/optgroup.d.ts.map +1 -1
  194. package/development/option/optgroup.d.ts +1 -0
  195. package/development/option/optgroup.d.ts.map +1 -1
  196. package/development/option/optgroup.js +74 -49
  197. package/development/option/option/option-base-element.d.ts +69 -0
  198. package/development/option/option/option-base-element.d.ts.map +1 -0
  199. package/development/option/option/option.d.ts +14 -57
  200. package/development/option/option/option.d.ts.map +1 -1
  201. package/development/option/option.d.ts +1 -0
  202. package/development/option/option.d.ts.map +1 -1
  203. package/development/option/option.js +267 -220
  204. package/development/radio-button/common/radio-button-common.d.ts +1 -1
  205. package/development/radio-button/common/radio-button-common.d.ts.map +1 -1
  206. package/development/radio-button/common.js +13 -12
  207. package/development/radio-button/radio-button/radio-button.d.ts +7 -0
  208. package/development/radio-button/radio-button/radio-button.d.ts.map +1 -1
  209. package/development/radio-button/radio-button-group/radio-button-group.d.ts +1 -1
  210. package/development/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  211. package/development/radio-button/radio-button-group.js +1 -1
  212. package/development/radio-button/radio-button-panel/radio-button-panel.d.ts +7 -0
  213. package/development/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -1
  214. package/development/radio-button/radio-button-panel.js +16 -2
  215. package/development/radio-button/radio-button.js +16 -2
  216. package/development/skiplink-list/skiplink-list.d.ts +1 -0
  217. package/development/skiplink-list/skiplink-list.d.ts.map +1 -1
  218. package/development/skiplink-list.js +1 -1
  219. package/development/status/status.d.ts +1 -1
  220. package/development/status/status.d.ts.map +1 -1
  221. package/development/status.js +39 -2
  222. package/development/tabs/tab-group.js +2 -9
  223. package/development/tabs/tab.js +10 -2
  224. package/development/tag/tag-group.js +1 -1
  225. package/development/timetable-occupancy-icon/timetable-occupancy-icon.d.ts.map +1 -1
  226. package/development/timetable-occupancy-icon.js +3 -6
  227. package/development/toggle/toggle.js +1 -1
  228. package/development/visual-checkbox/visual-checkbox.d.ts +3 -0
  229. package/development/visual-checkbox/visual-checkbox.d.ts.map +1 -1
  230. package/development/visual-checkbox.js +11 -3
  231. package/flip-card/flip-card/flip-card.d.ts +32 -0
  232. package/flip-card/flip-card/flip-card.d.ts.map +1 -0
  233. package/flip-card/flip-card/index.d.ts +2 -0
  234. package/flip-card/flip-card/index.d.ts.map +1 -0
  235. package/flip-card/flip-card-details/flip-card-details.d.ts +22 -0
  236. package/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -0
  237. package/flip-card/flip-card-details/index.d.ts +2 -0
  238. package/flip-card/flip-card-details/index.d.ts.map +1 -0
  239. package/flip-card/flip-card-details.d.ts +2 -0
  240. package/flip-card/flip-card-details.d.ts.map +1 -0
  241. package/flip-card/flip-card-details.js +52 -0
  242. package/flip-card/flip-card-summary/flip-card-summary.d.ts +22 -0
  243. package/flip-card/flip-card-summary/flip-card-summary.d.ts.map +1 -0
  244. package/flip-card/flip-card-summary/index.d.ts +2 -0
  245. package/flip-card/flip-card-summary/index.d.ts.map +1 -0
  246. package/flip-card/flip-card-summary.d.ts +2 -0
  247. package/flip-card/flip-card-summary.d.ts.map +1 -0
  248. package/flip-card/flip-card-summary.js +41 -0
  249. package/flip-card/flip-card.d.ts +2 -0
  250. package/flip-card/flip-card.d.ts.map +1 -0
  251. package/flip-card/flip-card.js +58 -0
  252. package/flip-card.d.ts +4 -0
  253. package/flip-card.d.ts.map +1 -0
  254. package/flip-card.js +3 -0
  255. package/form-field/form-field-clear/form-field-clear.d.ts.map +1 -1
  256. package/form-field/form-field-clear.js +11 -11
  257. package/form-field/form-field.js +2 -2
  258. package/icon/icon-base.d.ts.map +1 -1
  259. package/icon/icon.d.ts.map +1 -1
  260. package/image/image.d.ts +1 -0
  261. package/image/image.d.ts.map +1 -1
  262. package/image.js +24 -24
  263. package/index.d.ts +18 -0
  264. package/index.js +18 -0
  265. package/map-container.js +8 -8
  266. package/navigation/navigation-marker/navigation-marker.d.ts.map +1 -1
  267. package/option/optgroup/optgroup-base-element.d.ts +28 -0
  268. package/option/optgroup/optgroup-base-element.d.ts.map +1 -0
  269. package/option/optgroup/optgroup.d.ts +7 -20
  270. package/option/optgroup/optgroup.d.ts.map +1 -1
  271. package/option/optgroup.d.ts +1 -0
  272. package/option/optgroup.d.ts.map +1 -1
  273. package/option/optgroup.js +80 -60
  274. package/option/option/option-base-element.d.ts +69 -0
  275. package/option/option/option-base-element.d.ts.map +1 -0
  276. package/option/option/option.d.ts +14 -57
  277. package/option/option/option.d.ts.map +1 -1
  278. package/option/option.d.ts +1 -0
  279. package/option/option.d.ts.map +1 -1
  280. package/option/option.js +186 -145
  281. package/package.json +56 -1
  282. package/radio-button/common/radio-button-common.d.ts +1 -1
  283. package/radio-button/common/radio-button-common.d.ts.map +1 -1
  284. package/radio-button/common.js +6 -15
  285. package/radio-button/radio-button/radio-button.d.ts +7 -0
  286. package/radio-button/radio-button/radio-button.d.ts.map +1 -1
  287. package/radio-button/radio-button-group/radio-button-group.d.ts +1 -1
  288. package/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  289. package/radio-button/radio-button-panel/radio-button-panel.d.ts +7 -0
  290. package/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -1
  291. package/radio-button/radio-button-panel.js +35 -22
  292. package/radio-button/radio-button.js +32 -19
  293. package/skiplink-list/skiplink-list.d.ts +1 -0
  294. package/skiplink-list/skiplink-list.d.ts.map +1 -1
  295. package/standard-theme.css +3 -1
  296. package/status/status.d.ts +1 -1
  297. package/status/status.d.ts.map +1 -1
  298. package/status.js +17 -13
  299. package/tabs/tab-group.js +19 -19
  300. package/tabs/tab.js +10 -10
  301. package/timetable-occupancy-icon/timetable-occupancy-icon.d.ts.map +1 -1
  302. package/timetable-occupancy-icon.js +22 -24
  303. package/visual-checkbox/visual-checkbox.d.ts +3 -0
  304. package/visual-checkbox/visual-checkbox.d.ts.map +1 -1
  305. package/visual-checkbox.js +23 -20
@@ -1,14 +1,232 @@
1
- import { css, LitElement, html, nothing } from "lit";
1
+ import { LitElement, html, nothing, css } from "lit";
2
2
  import { property, state, customElement } from "lit/decorators.js";
3
+ import { slotState, hostAttributes } from "../core/decorators.js";
4
+ import { EventEmitter } from "../core/eventing.js";
3
5
  import { SbbConnectedAbortController } from "../core/controllers.js";
4
- import { hostAttributes, slotState } from "../core/decorators.js";
5
6
  import { setOrRemoveAttribute, isAndroid, isSafari } from "../core/dom.js";
6
- import { EventEmitter } from "../core/eventing.js";
7
7
  import { SbbDisabledMixin, SbbHydrationMixin } from "../core/mixins.js";
8
8
  import { AgnosticMutationObserver } from "../core/observers.js";
9
9
  import { SbbIconNameMixin } from "../icon.js";
10
10
  import "../screen-reader-only.js";
11
11
  import "../visual-checkbox.js";
12
+ var __defProp$1 = Object.defineProperty;
13
+ var __getOwnPropDesc$1 = Object.getOwnPropertyDescriptor;
14
+ var __decorateClass$1 = (decorators, target, key, kind) => {
15
+ var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$1(target, key) : target;
16
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
17
+ if (decorator = decorators[i])
18
+ result = (kind ? decorator(target, key, result) : decorator(result)) || result;
19
+ if (kind && result) __defProp$1(target, key, result);
20
+ return result;
21
+ };
22
+ let nextId = 0;
23
+ const inertAriaGroups = isSafari;
24
+ const optionObserverConfig = {
25
+ attributeFilter: ["data-group-disabled", "data-negative"]
26
+ };
27
+ let SbbOptionBaseElement = class extends SbbDisabledMixin(
28
+ SbbIconNameMixin(SbbHydrationMixin(LitElement))
29
+ ) {
30
+ constructor() {
31
+ super();
32
+ this.negative = false;
33
+ this.disabledFromGroup = false;
34
+ this.disableLabelHighlight = false;
35
+ this._highlightString = null;
36
+ this._inertAriaGroups = false;
37
+ this._abort = new SbbConnectedAbortController(this);
38
+ this._optionAttributeObserver = new AgnosticMutationObserver(
39
+ (mutationsList) => this.onOptionAttributesChange(mutationsList)
40
+ );
41
+ if (inertAriaGroups) {
42
+ if (this.hydrationRequired) {
43
+ this.hydrationComplete.then(() => this._inertAriaGroups = inertAriaGroups);
44
+ } else {
45
+ this._inertAriaGroups = inertAriaGroups;
46
+ }
47
+ }
48
+ }
49
+ set value(value) {
50
+ this.setAttribute("value", `${value}`);
51
+ }
52
+ get value() {
53
+ return this.getAttribute("value") ?? "";
54
+ }
55
+ set selected(value) {
56
+ this.toggleAttribute("selected", value);
57
+ this._updateAriaSelected();
58
+ }
59
+ get selected() {
60
+ return this.hasAttribute("selected");
61
+ }
62
+ updateDisableHighlight(disabled) {
63
+ this.disableLabelHighlight = disabled;
64
+ this.toggleAttribute("data-disable-highlight", disabled);
65
+ }
66
+ attributeChangedCallback(name, old, value) {
67
+ if (name !== "value" || old !== value) {
68
+ super.attributeChangedCallback(name, old, value);
69
+ }
70
+ }
71
+ /**
72
+ * Highlight the label of the option
73
+ * @param value the highlighted portion of the label
74
+ * @internal
75
+ */
76
+ highlight(value) {
77
+ this._highlightString = value;
78
+ }
79
+ /**
80
+ * @internal
81
+ */
82
+ setSelectedViaUserInteraction(selected) {
83
+ this.selected = selected;
84
+ this.selectionChange.emit();
85
+ if (this.selected) {
86
+ this.optionSelected.emit();
87
+ }
88
+ }
89
+ connectedCallback() {
90
+ super.connectedCallback();
91
+ this.id || (this.id = `${this.optionId}-${nextId++}`);
92
+ if (this.hydrationRequired) {
93
+ this.hydrationComplete.then(() => this.init());
94
+ } else {
95
+ this.init();
96
+ }
97
+ }
98
+ willUpdate(changedProperties) {
99
+ super.willUpdate(changedProperties);
100
+ if (changedProperties.has("disabled")) {
101
+ setOrRemoveAttribute(this, "tabindex", isAndroid && !this.disabled && 0);
102
+ this.updateAriaDisabled();
103
+ }
104
+ }
105
+ firstUpdated(changedProperties) {
106
+ super.firstUpdated(changedProperties);
107
+ this._updateAriaSelected();
108
+ }
109
+ disconnectedCallback() {
110
+ super.disconnectedCallback();
111
+ this._optionAttributeObserver.disconnect();
112
+ }
113
+ init() {
114
+ this.setAttributeFromParent();
115
+ this._optionAttributeObserver.observe(this, optionObserverConfig);
116
+ const signal = this._abort.signal;
117
+ this.addEventListener("click", (e) => this.selectByClick(e), {
118
+ signal,
119
+ passive: true
120
+ });
121
+ }
122
+ updateAriaDisabled() {
123
+ setOrRemoveAttribute(
124
+ this,
125
+ "aria-disabled",
126
+ this.disabled || this.disabledFromGroup ? "true" : null
127
+ );
128
+ }
129
+ _updateAriaSelected() {
130
+ this.setAttribute("aria-selected", `${this.selected}`);
131
+ }
132
+ /** Observe changes on data attributes and set the appropriate values. */
133
+ onOptionAttributesChange(mutationsList) {
134
+ for (const mutation of mutationsList) {
135
+ if (mutation.attributeName === "data-group-disabled") {
136
+ this.disabledFromGroup = this.hasAttribute("data-group-disabled");
137
+ this.updateAriaDisabled();
138
+ } else if (mutation.attributeName === "data-negative") {
139
+ this.negative = this.hasAttribute("data-negative");
140
+ }
141
+ }
142
+ }
143
+ handleHighlightState() {
144
+ const slotNodes = Array.from(this.childNodes ?? []).filter(
145
+ (n) => n.nodeType !== Node.COMMENT_NODE && (!(n instanceof Element) || n.slot !== "icon")
146
+ );
147
+ const labelNodes = slotNodes.filter((el) => el.nodeType === Node.TEXT_NODE);
148
+ if (labelNodes.length === 0 || slotNodes.filter((n) => !(n instanceof Element) || n.localName !== "template").length !== labelNodes.length) {
149
+ this.updateDisableHighlight(true);
150
+ return;
151
+ }
152
+ this.label = labelNodes.map((l) => l.wholeText).filter((l) => l.trim()).join();
153
+ }
154
+ getHighlightedLabel() {
155
+ if (!this._highlightString || !this._highlightString.trim()) {
156
+ return html`${this.label}`;
157
+ }
158
+ const matchIndex = this.label.toLowerCase().indexOf(this._highlightString.toLowerCase());
159
+ if (matchIndex === -1) {
160
+ return html`${this.label}`;
161
+ }
162
+ const prefix = this.label.substring(0, matchIndex);
163
+ const highlighted = this.label.substring(
164
+ matchIndex,
165
+ matchIndex + this._highlightString.length
166
+ );
167
+ const postfix = this.label.substring(matchIndex + this._highlightString.length);
168
+ return html`
169
+ <span class="sbb-option__label--highlight">${prefix}</span><span>${highlighted}</span
170
+ ><span class="sbb-option__label--highlight">${postfix}</span>
171
+ `;
172
+ }
173
+ renderIcon() {
174
+ return html` <span class="sbb-option__icon"> ${this.renderIconSlot()} </span>`;
175
+ }
176
+ renderLabel() {
177
+ return this.label && !this.disableLabelHighlight ? this.getHighlightedLabel() : nothing;
178
+ }
179
+ renderTick() {
180
+ return nothing;
181
+ }
182
+ render() {
183
+ return html`
184
+ <div class="sbb-option__container">
185
+ <div class="sbb-option">
186
+ ${this.renderIcon()}
187
+ <span class="sbb-option__label">
188
+ <slot @slotchange=${this.handleHighlightState}></slot>
189
+ ${this.renderLabel()}
190
+ ${this._inertAriaGroups && this.getAttribute("data-group-label") ? html` <sbb-screen-reader-only>
191
+ (${this.getAttribute("data-group-label")})</sbb-screen-reader-only
192
+ >` : nothing}
193
+ </span>
194
+ ${this.renderTick()}
195
+ </div>
196
+ </div>
197
+ `;
198
+ }
199
+ };
200
+ __decorateClass$1([
201
+ property()
202
+ ], SbbOptionBaseElement.prototype, "value", 1);
203
+ __decorateClass$1([
204
+ property({ reflect: true, type: Boolean })
205
+ ], SbbOptionBaseElement.prototype, "active", 2);
206
+ __decorateClass$1([
207
+ property({ type: Boolean })
208
+ ], SbbOptionBaseElement.prototype, "selected", 1);
209
+ __decorateClass$1([
210
+ state()
211
+ ], SbbOptionBaseElement.prototype, "negative", 2);
212
+ __decorateClass$1([
213
+ state()
214
+ ], SbbOptionBaseElement.prototype, "disabledFromGroup", 2);
215
+ __decorateClass$1([
216
+ state()
217
+ ], SbbOptionBaseElement.prototype, "label", 2);
218
+ __decorateClass$1([
219
+ state()
220
+ ], SbbOptionBaseElement.prototype, "disableLabelHighlight", 2);
221
+ __decorateClass$1([
222
+ state()
223
+ ], SbbOptionBaseElement.prototype, "_highlightString", 2);
224
+ __decorateClass$1([
225
+ state()
226
+ ], SbbOptionBaseElement.prototype, "_inertAriaGroups", 2);
227
+ SbbOptionBaseElement = __decorateClass$1([
228
+ slotState()
229
+ ], SbbOptionBaseElement);
12
230
  const style = css`/**
13
231
  * Better font rendering (on OS X)
14
232
  * http://maximilianhoffmann.com/posts/better-font-rendering-on-osx
@@ -178,53 +396,18 @@ var __decorateClass = (decorators, target, key, kind) => {
178
396
  if (kind && result) __defProp(target, key, result);
179
397
  return result;
180
398
  };
181
- const inertAriaGroups = isSafari;
182
- let nextId = 0;
183
- const optionObserverConfig = {
184
- attributeFilter: ["data-group-disabled", "data-negative"]
185
- };
186
- let SbbOptionElement = class extends SbbDisabledMixin(
187
- SbbIconNameMixin(SbbHydrationMixin(LitElement))
188
- ) {
399
+ let SbbOptionElement = class extends SbbOptionBaseElement {
189
400
  constructor() {
190
- super();
191
- this._selectionChange = new EventEmitter(
401
+ super(...arguments);
402
+ this.optionId = `sbb-option`;
403
+ this.selectionChange = new EventEmitter(
192
404
  this,
193
405
  SbbOptionElement.events.selectionChange
194
406
  );
195
- this._optionSelected = new EventEmitter(
407
+ this.optionSelected = new EventEmitter(
196
408
  this,
197
409
  SbbOptionElement.events.optionSelected
198
410
  );
199
- this._negative = false;
200
- this._disabledFromGroup = false;
201
- this._highlightString = null;
202
- this._disableLabelHighlight = false;
203
- this._inertAriaGroups = false;
204
- this._abort = new SbbConnectedAbortController(this);
205
- this._optionAttributeObserver = new AgnosticMutationObserver(
206
- (mutationsList) => this._onOptionAttributesChange(mutationsList)
207
- );
208
- if (inertAriaGroups) {
209
- if (this.hydrationRequired) {
210
- this.hydrationComplete.then(() => this._inertAriaGroups = inertAriaGroups);
211
- } else {
212
- this._inertAriaGroups = inertAriaGroups;
213
- }
214
- }
215
- }
216
- set value(value) {
217
- this.setAttribute("value", `${value}`);
218
- }
219
- get value() {
220
- return this.getAttribute("value") ?? "";
221
- }
222
- set selected(value) {
223
- this.toggleAttribute("selected", value);
224
- this._updateAriaSelected();
225
- }
226
- get selected() {
227
- return this.hasAttribute("selected");
228
411
  }
229
412
  set _variant(state2) {
230
413
  if (state2) {
@@ -240,35 +423,23 @@ let SbbOptionElement = class extends SbbDisabledMixin(
240
423
  get _isMultiple() {
241
424
  return !this.hydrationRequired && this.hasAttribute("data-multiple");
242
425
  }
243
- attributeChangedCallback(name, old, value) {
244
- if (name !== "value" || old !== value) {
245
- super.attributeChangedCallback(name, old, value);
246
- }
247
- }
248
- /**
249
- * Highlight the label of the option
250
- * @param value the highlighted portion of the label
251
- * @internal
252
- */
253
- highlight(value) {
254
- this._highlightString = value;
255
- }
256
- /**
257
- * @internal
258
- */
259
- setSelectedViaUserInteraction(selected) {
260
- this.selected = selected;
261
- this._selectionChange.emit();
262
- if (this.selected) {
263
- this._optionSelected.emit();
426
+ setAttributeFromParent() {
427
+ var _a, _b;
428
+ const parentGroup = (_a = this.closest) == null ? void 0 : _a.call(this, "sbb-optgroup");
429
+ if (parentGroup) {
430
+ this.disabledFromGroup = parentGroup.disabled;
431
+ this.updateAriaDisabled();
264
432
  }
433
+ this.negative = !!((_b = this.closest) == null ? void 0 : _b.call(
434
+ this,
435
+ // :is() selector not possible due to test environment
436
+ `sbb-autocomplete[negative],sbb-form-field[negative]`
437
+ ));
438
+ this.toggleAttribute("data-negative", this.negative);
439
+ this.toggleAttribute("data-multiple", this._isMultiple);
265
440
  }
266
- _updateDisableHighlight(disabled) {
267
- this._disableLabelHighlight = disabled;
268
- this.toggleAttribute("data-disable-highlight", disabled);
269
- }
270
- _selectByClick(event) {
271
- if (this.disabled || this._disabledFromGroup) {
441
+ selectByClick(event) {
442
+ if (this.disabled || this.disabledFromGroup) {
272
443
  event.stopPropagation();
273
444
  return;
274
445
  }
@@ -281,59 +452,11 @@ let SbbOptionElement = class extends SbbDisabledMixin(
281
452
  }
282
453
  connectedCallback() {
283
454
  super.connectedCallback();
284
- this.id || (this.id = `sbb-option-${nextId++}`);
285
- if (this.hydrationRequired) {
286
- this.hydrationComplete.then(() => this._init());
287
- } else {
288
- this._init();
289
- }
290
- }
291
- willUpdate(changedProperties) {
292
- super.willUpdate(changedProperties);
293
- if (changedProperties.has("disabled")) {
294
- setOrRemoveAttribute(this, "tabindex", isAndroid && !this.disabled && 0);
295
- this._updateAriaDisabled();
296
- }
297
- }
298
- firstUpdated(changedProperties) {
299
- super.firstUpdated(changedProperties);
300
- this._updateAriaSelected();
301
455
  }
302
- _init() {
303
- var _a, _b;
304
- const signal = this._abort.signal;
305
- const parentGroup = (_a = this.closest) == null ? void 0 : _a.call(this, "sbb-optgroup");
306
- if (parentGroup) {
307
- this._disabledFromGroup = parentGroup.disabled;
308
- this._updateAriaDisabled();
309
- }
310
- this._optionAttributeObserver.observe(this, optionObserverConfig);
311
- this._negative = !!((_b = this.closest) == null ? void 0 : _b.call(
312
- this,
313
- // :is() selector not possible due to test environment
314
- `sbb-autocomplete[negative],sbb-select[negative],sbb-form-field[negative]`
315
- ));
316
- this.toggleAttribute("data-negative", this._negative);
456
+ init() {
457
+ super.init();
317
458
  this._setVariantByContext();
318
- this._handleHighlightState();
319
- this.addEventListener("click", (e) => this._selectByClick(e), {
320
- signal,
321
- passive: true
322
- });
323
- }
324
- _updateAriaDisabled() {
325
- setOrRemoveAttribute(
326
- this,
327
- "aria-disabled",
328
- this.disabled || this._disabledFromGroup ? "true" : null
329
- );
330
- }
331
- _updateAriaSelected() {
332
- this.setAttribute("aria-selected", `${this.selected}`);
333
- }
334
- disconnectedCallback() {
335
- super.disconnectedCallback();
336
- this._optionAttributeObserver.disconnect();
459
+ this.handleHighlightState();
337
460
  }
338
461
  _setVariantByContext() {
339
462
  var _a, _b, _c;
@@ -344,124 +467,48 @@ let SbbOptionElement = class extends SbbDisabledMixin(
344
467
  }
345
468
  this._isMultiple = !!((_c = this.closest) == null ? void 0 : _c.call(this, "sbb-select[multiple]"));
346
469
  }
347
- /** Observe changes on data attributes and set the appropriate values. */
348
- _onOptionAttributesChange(mutationsList) {
349
- for (const mutation of mutationsList) {
350
- if (mutation.attributeName === "data-group-disabled") {
351
- this._disabledFromGroup = this.hasAttribute("data-group-disabled");
352
- this._updateAriaDisabled();
353
- } else if (mutation.attributeName === "data-negative") {
354
- this._negative = this.hasAttribute("data-negative");
355
- }
356
- }
357
- }
358
- _handleHighlightState() {
470
+ handleHighlightState() {
359
471
  if (this._variant !== "autocomplete") {
360
- this._updateDisableHighlight(true);
361
- return;
362
- }
363
- const slotNodes = Array.from(this.childNodes ?? []).filter(
364
- (n) => !(n instanceof Element) || n.slot !== "icon"
365
- );
366
- const labelNodes = slotNodes.filter((el) => el.nodeType === Node.TEXT_NODE);
367
- if (labelNodes.length === 0 || slotNodes.filter((n) => !(n instanceof Element) || n.localName !== "template").length !== labelNodes.length) {
368
- this._updateDisableHighlight(true);
472
+ this.updateDisableHighlight(true);
369
473
  return;
370
474
  }
371
- this._label = labelNodes.map((l) => l.wholeText).filter((l) => l.trim()).join();
475
+ super.handleHighlightState();
372
476
  }
373
- _getHighlightedLabel() {
374
- if (!this._highlightString || !this._highlightString.trim()) {
375
- return html`${this._label}`;
376
- }
377
- const matchIndex = this._label.toLowerCase().indexOf(this._highlightString.toLowerCase());
378
- if (matchIndex === -1) {
379
- return html`${this._label}`;
380
- }
381
- const prefix = this._label.substring(0, matchIndex);
382
- const highlighted = this._label.substring(
383
- matchIndex,
384
- matchIndex + this._highlightString.length
385
- );
386
- const postfix = this._label.substring(matchIndex + this._highlightString.length);
477
+ renderIcon() {
387
478
  return html`
388
- <span class="sbb-option__label--highlight">${prefix}</span><span>${highlighted}</span
389
- ><span class="sbb-option__label--highlight">${postfix}</span>
390
- `;
391
- }
392
- render() {
393
- const isMultiple = this._isMultiple;
394
- return html`
395
- <div class="sbb-option__container">
396
- <div class="sbb-option">
397
- <!-- Icon -->
398
- ${!isMultiple ? html` <span class="sbb-option__icon"> ${this.renderIconSlot()} </span>` : nothing}
479
+ <!-- Icon -->
480
+ ${!this._isMultiple ? html` <span class="sbb-option__icon"> ${this.renderIconSlot()} </span>` : nothing}
399
481
 
400
- <!-- Checkbox -->
401
- ${isMultiple ? html` <sbb-visual-checkbox
402
- ?checked=${this.selected}
403
- ?disabled=${this.disabled || this._disabledFromGroup}
404
- ?negative=${this._negative}
405
- ></sbb-visual-checkbox>` : nothing}
406
-
407
- <!-- Label -->
408
- <span class="sbb-option__label">
409
- <slot @slotchange=${this._handleHighlightState}></slot>
410
-
411
- <!-- Search highlight -->
412
- ${this._variant === "autocomplete" && this._label && !this._disableLabelHighlight ? this._getHighlightedLabel() : nothing}
413
- ${this._inertAriaGroups && this.getAttribute("data-group-label") ? html` <sbb-screen-reader-only>
414
- (${this.getAttribute("data-group-label")})</sbb-screen-reader-only
415
- >` : nothing}
416
- </span>
417
-
418
- <!-- Selected tick -->
419
- ${this._variant === "select" && !isMultiple && this.selected ? html`<sbb-icon name="tick-small"></sbb-icon>` : nothing}
420
- </div>
421
- </div>
482
+ <!-- Checkbox -->
483
+ ${this._isMultiple ? html`
484
+ <sbb-visual-checkbox
485
+ ?checked=${this.selected}
486
+ ?disabled=${this.disabled || this.disabledFromGroup}
487
+ ?negative=${this.negative}
488
+ ></sbb-visual-checkbox>
489
+ ` : nothing}
422
490
  `;
423
491
  }
492
+ renderLabel() {
493
+ return this._variant === "autocomplete" && this.label && !this.disableLabelHighlight ? this.getHighlightedLabel() : nothing;
494
+ }
495
+ renderTick() {
496
+ return this._variant === "select" && !this._isMultiple && this.selected ? html`<sbb-icon name="tick-small"></sbb-icon>` : nothing;
497
+ }
424
498
  };
425
499
  SbbOptionElement.styles = style;
426
500
  SbbOptionElement.events = {
427
501
  selectionChange: "optionSelectionChange",
428
502
  optionSelected: "optionSelected"
429
503
  };
430
- __decorateClass([
431
- property()
432
- ], SbbOptionElement.prototype, "value", 1);
433
- __decorateClass([
434
- property({ reflect: true, type: Boolean })
435
- ], SbbOptionElement.prototype, "active", 2);
436
- __decorateClass([
437
- property({ type: Boolean })
438
- ], SbbOptionElement.prototype, "selected", 1);
439
- __decorateClass([
440
- state()
441
- ], SbbOptionElement.prototype, "_negative", 2);
442
- __decorateClass([
443
- state()
444
- ], SbbOptionElement.prototype, "_disabledFromGroup", 2);
445
- __decorateClass([
446
- state()
447
- ], SbbOptionElement.prototype, "_label", 2);
448
- __decorateClass([
449
- state()
450
- ], SbbOptionElement.prototype, "_highlightString", 2);
451
- __decorateClass([
452
- state()
453
- ], SbbOptionElement.prototype, "_disableLabelHighlight", 2);
454
- __decorateClass([
455
- state()
456
- ], SbbOptionElement.prototype, "_inertAriaGroups", 2);
457
504
  SbbOptionElement = __decorateClass([
458
505
  customElement("sbb-option"),
459
506
  hostAttributes({
460
507
  role: "option"
461
- }),
462
- slotState()
508
+ })
463
509
  ], SbbOptionElement);
464
510
  export {
511
+ SbbOptionBaseElement,
465
512
  SbbOptionElement
466
513
  };
467
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"option.js","sources":["../../../../src/elements/option/option/option.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  LitElement,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\n\nimport { SbbConnectedAbortController } from '../../core/controllers.js';\nimport { hostAttributes, slotState } from '../../core/decorators.js';\nimport { isAndroid, isSafari, setOrRemoveAttribute } from '../../core/dom.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport { SbbDisabledMixin, SbbHydrationMixin } from '../../core/mixins.js';\nimport { AgnosticMutationObserver } from '../../core/observers.js';\nimport { SbbIconNameMixin } from '../../icon.js';\n\nimport style from './option.scss?lit&inline';\n\nimport '../../screen-reader-only.js';\nimport '../../visual-checkbox.js';\n\n/**\n * On Safari, the groups labels are not read by VoiceOver.\n * To solve the problem, we remove the role=\"group\" and add an hidden span containing the group name\n * TODO: We should periodically check if it has been solved and, if so, remove the property.\n */\nconst inertAriaGroups = isSafari;\n\nlet nextId = 0;\n\n/** Configuration for the attribute to look at if component is nested in a sbb-checkbox-group */\nconst optionObserverConfig: MutationObserverInit = {\n  attributeFilter: ['data-group-disabled', 'data-negative'],\n};\n\nexport type SbbOptionVariant = 'autocomplete' | 'select' | null;\n\n/**\n * It displays on option item which can be used in `sbb-select` or `sbb-autocomplete`.\n *\n * @slot - Use the unnamed slot to add content to the option label.\n * @slot icon - Use this slot to provide an icon. If `icon-name` is set, a sbb-icon will be used.\n * @event {CustomEvent<void>} optionSelectionChange - Emits when the option selection status changes.\n * @event {CustomEvent<void>} optionSelected - Emits when an option was selected by user.\n * @cssprop [--sbb-option-icon-container-display=none] - Can be used to reserve space even\n * when preserve-icon-space on autocomplete is not set or iconName is not set.\n */\n@customElement('sbb-option')\n@hostAttributes({\n  role: 'option',\n})\n@slotState()\nexport class SbbOptionElement extends SbbDisabledMixin(\n  SbbIconNameMixin(SbbHydrationMixin(LitElement)),\n) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    selectionChange: 'optionSelectionChange',\n    optionSelected: 'optionSelected',\n  } as const;\n\n  /**\n   * Value of the option.\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 value(value: string) {\n    this.setAttribute('value', `${value}`);\n  }\n  public get value(): string {\n    return this.getAttribute('value') ?? '';\n  }\n\n  /** Whether the option is currently active. */\n  @property({ reflect: true, type: Boolean }) public active?: boolean;\n\n  /** Whether the option is selected. */\n  @property({ type: Boolean })\n  public set selected(value: boolean) {\n    this.toggleAttribute('selected', value);\n    this._updateAriaSelected();\n  }\n  public get selected(): boolean {\n    return this.hasAttribute('selected');\n  }\n\n  /** Emits when the option selection status changes. */\n  private _selectionChange: EventEmitter = new EventEmitter(\n    this,\n    SbbOptionElement.events.selectionChange,\n  );\n\n  /** Emits when an option was selected by user. */\n  private _optionSelected: EventEmitter = new EventEmitter(\n    this,\n    SbbOptionElement.events.optionSelected,\n  );\n\n  /** Whether to apply the negative styling */\n  @state() private _negative = false;\n\n  /** Whether the component must be set disabled due disabled attribute on sbb-checkbox-group. */\n  @state() private _disabledFromGroup = false;\n\n  @state() private _label?: string;\n\n  /** The portion of the highlighted label. */\n  @state() private _highlightString: string | null = null;\n\n  /** Disable the highlight of the label. */\n  @state() private _disableLabelHighlight: boolean = false;\n\n  @state() private _inertAriaGroups = false;\n\n  private set _variant(state: SbbOptionVariant) {\n    if (state) {\n      this.setAttribute('data-variant', state);\n    }\n  }\n  private get _variant(): SbbOptionVariant {\n    return this.getAttribute('data-variant') as SbbOptionVariant;\n  }\n\n  private set _isMultiple(isMultiple: boolean) {\n    this.toggleAttribute('data-multiple', isMultiple);\n  }\n  private get _isMultiple(): boolean {\n    return !this.hydrationRequired && this.hasAttribute('data-multiple');\n  }\n\n  private _abort = new SbbConnectedAbortController(this);\n\n  /** MutationObserver on data attributes. */\n  private _optionAttributeObserver = new AgnosticMutationObserver((mutationsList) =>\n    this._onOptionAttributesChange(mutationsList),\n  );\n\n  public constructor() {\n    super();\n\n    if (inertAriaGroups) {\n      if (this.hydrationRequired) {\n        this.hydrationComplete.then(() => (this._inertAriaGroups = inertAriaGroups));\n      } else {\n        this._inertAriaGroups = inertAriaGroups;\n      }\n    }\n  }\n\n  public override attributeChangedCallback(\n    name: string,\n    old: string | null,\n    value: string | null,\n  ): void {\n    if (name !== 'value' || old !== value) {\n      super.attributeChangedCallback(name, old, value);\n    }\n  }\n\n  /**\n   * Highlight the label of the option\n   * @param value the highlighted portion of the label\n   * @internal\n   */\n  public highlight(value: string): void {\n    this._highlightString = value;\n  }\n\n  /**\n   * @internal\n   */\n  public setSelectedViaUserInteraction(selected: boolean): void {\n    this.selected = selected;\n    this._selectionChange.emit();\n    if (this.selected) {\n      this._optionSelected.emit();\n    }\n  }\n\n  private _updateDisableHighlight(disabled: boolean): void {\n    this._disableLabelHighlight = disabled;\n    this.toggleAttribute('data-disable-highlight', disabled);\n  }\n\n  private _selectByClick(event: MouseEvent): void {\n    if (this.disabled || this._disabledFromGroup) {\n      event.stopPropagation();\n      return;\n    }\n\n    if (this._isMultiple) {\n      event.stopPropagation();\n      this.setSelectedViaUserInteraction(!this.selected);\n    } else {\n      this.setSelectedViaUserInteraction(true);\n    }\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n\n    this.id ||= `sbb-option-${nextId++}`;\n\n    if (this.hydrationRequired) {\n      this.hydrationComplete.then(() => this._init());\n    } else {\n      this._init();\n    }\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('disabled')) {\n      setOrRemoveAttribute(this, 'tabindex', isAndroid && !this.disabled && 0);\n      this._updateAriaDisabled();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // Init first select state because false would not call setter of selected property.\n    this._updateAriaSelected();\n  }\n\n  private _init(): void {\n    const signal = this._abort.signal;\n    const parentGroup = this.closest?.('sbb-optgroup');\n    if (parentGroup) {\n      this._disabledFromGroup = parentGroup.disabled;\n      this._updateAriaDisabled();\n    }\n    this._optionAttributeObserver.observe(this, optionObserverConfig);\n\n    this._negative = !!this.closest?.(\n      // :is() selector not possible due to test environment\n      `sbb-autocomplete[negative],sbb-select[negative],sbb-form-field[negative]`,\n    );\n    this.toggleAttribute('data-negative', this._negative);\n\n    this._setVariantByContext();\n    // We need to check highlight state both on slot change, but also when connecting\n    // the element to the DOM. The slot change events might be swallowed when using declarative\n    // shadow DOM with SSR or if the DOM is changed when disconnected.\n    this._handleHighlightState();\n\n    this.addEventListener('click', (e: MouseEvent) => this._selectByClick(e), {\n      signal,\n      passive: true,\n    });\n  }\n\n  private _updateAriaDisabled(): void {\n    setOrRemoveAttribute(\n      this,\n      'aria-disabled',\n      this.disabled || this._disabledFromGroup ? 'true' : null,\n    );\n  }\n\n  private _updateAriaSelected(): void {\n    this.setAttribute('aria-selected', `${this.selected}`);\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._optionAttributeObserver.disconnect();\n  }\n\n  private _setVariantByContext(): void {\n    if (this.closest?.('sbb-autocomplete')) {\n      this._variant = 'autocomplete';\n    } else if (this.closest?.('sbb-select')) {\n      this._variant = 'select';\n    }\n    this._isMultiple = !!this.closest?.('sbb-select[multiple]');\n  }\n\n  /** Observe changes on data attributes and set the appropriate values. */\n  private _onOptionAttributesChange(mutationsList: MutationRecord[]): void {\n    for (const mutation of mutationsList) {\n      if (mutation.attributeName === 'data-group-disabled') {\n        this._disabledFromGroup = this.hasAttribute('data-group-disabled');\n        this._updateAriaDisabled();\n      } else if (mutation.attributeName === 'data-negative') {\n        this._negative = this.hasAttribute('data-negative');\n      }\n    }\n  }\n\n  private _handleHighlightState(): void {\n    if (this._variant !== 'autocomplete') {\n      this._updateDisableHighlight(true);\n      return;\n    }\n\n    const slotNodes = Array.from(this.childNodes ?? []).filter(\n      (n) => !(n instanceof Element) || n.slot !== 'icon',\n    );\n    const labelNodes = slotNodes.filter((el) => el.nodeType === Node.TEXT_NODE) as Text[];\n\n    // Disable the highlight if the slot contain more than just text nodes.\n    // We need to ignore template elements, as SSR adds a declarative shadow DOM\n    // in the form of a template element.\n    if (\n      labelNodes.length === 0 ||\n      slotNodes.filter((n) => !(n instanceof Element) || n.localName !== 'template').length !==\n        labelNodes.length\n    ) {\n      this._updateDisableHighlight(true);\n      return;\n    }\n    this._label = labelNodes\n      .map((l) => l.wholeText)\n      .filter((l) => l.trim())\n      .join();\n  }\n\n  private _getHighlightedLabel(): TemplateResult {\n    if (!this._highlightString || !this._highlightString.trim()) {\n      return html`${this._label}`;\n    }\n\n    const matchIndex = this._label!.toLowerCase().indexOf(this._highlightString.toLowerCase());\n\n    if (matchIndex === -1) {\n      return html`${this._label}`;\n    }\n\n    const prefix = this._label!.substring(0, matchIndex);\n    const highlighted = this._label!.substring(\n      matchIndex,\n      matchIndex + this._highlightString.length,\n    );\n    const postfix = this._label!.substring(matchIndex + this._highlightString.length);\n\n    return html`\n      <span class=\"sbb-option__label--highlight\">${prefix}</span><span>${highlighted}</span\n      ><span class=\"sbb-option__label--highlight\">${postfix}</span>\n    `;\n  }\n\n  protected override render(): TemplateResult {\n    const isMultiple = this._isMultiple;\n\n    return html`\n      <div class=\"sbb-option__container\">\n        <div class=\"sbb-option\">\n          <!-- Icon -->\n          ${!isMultiple\n            ? html` <span class=\"sbb-option__icon\"> ${this.renderIconSlot()} </span>`\n            : nothing}\n\n          <!-- Checkbox -->\n          ${isMultiple\n            ? html` <sbb-visual-checkbox\n                ?checked=${this.selected}\n                ?disabled=${this.disabled || this._disabledFromGroup}\n                ?negative=${this._negative}\n              ></sbb-visual-checkbox>`\n            : nothing}\n\n          <!-- Label -->\n          <span class=\"sbb-option__label\">\n            <slot @slotchange=${this._handleHighlightState}></slot>\n\n            <!-- Search highlight -->\n            ${this._variant === 'autocomplete' && this._label && !this._disableLabelHighlight\n              ? this._getHighlightedLabel()\n              : nothing}\n            ${this._inertAriaGroups && this.getAttribute('data-group-label')\n              ? html` <sbb-screen-reader-only>\n                  (${this.getAttribute('data-group-label')})</sbb-screen-reader-only\n                >`\n              : nothing}\n          </span>\n\n          <!-- Selected tick -->\n          ${this._variant === 'select' && !isMultiple && this.selected\n            ? html`<sbb-icon name=\"tick-small\"></sbb-icon>`\n            : nothing}\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-option': SbbOptionElement;\n  }\n\n  interface GlobalEventHandlersEventMap {\n    optionSelectionChange: CustomEvent<void>;\n  }\n}\n"],"names":["state"],"mappings":"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"}
514
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"option.js","sources":["../../../../src/elements/option/option/option-base-element.ts","../../../../src/elements/option/option/option.ts"],"sourcesContent":["import { html, LitElement, nothing, type PropertyValues, type TemplateResult } from 'lit';\nimport { property, state } from 'lit/decorators.js';\n\nimport { SbbConnectedAbortController } from '../../core/controllers.js';\nimport { slotState } from '../../core/decorators.js';\nimport { isAndroid, isSafari, setOrRemoveAttribute } from '../../core/dom.js';\nimport type { EventEmitter } from '../../core/eventing.js';\nimport { SbbDisabledMixin, SbbHydrationMixin } from '../../core/mixins.js';\nimport { AgnosticMutationObserver } from '../../core/observers.js';\nimport { SbbIconNameMixin } from '../../icon.js';\nimport '../../screen-reader-only.js';\n\nlet nextId = 0;\n\n/**\n * On Safari, the groups labels are not read by VoiceOver.\n * To solve the problem, we remove the role=\"group\" and add an hidden span containing the group name\n * TODO: We should periodically check if it has been solved and, if so, remove the property.\n */\nconst inertAriaGroups = isSafari;\n\n/** Configuration for the attribute to look at if component is nested in an option group */\nconst optionObserverConfig: MutationObserverInit = {\n  attributeFilter: ['data-group-disabled', 'data-negative'],\n};\n\n@slotState()\nexport abstract class SbbOptionBaseElement extends SbbDisabledMixin(\n  SbbIconNameMixin(SbbHydrationMixin(LitElement)),\n) {\n  protected abstract optionId: string;\n\n  /**\n   * Value of the option.\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 value(value: string) {\n    this.setAttribute('value', `${value}`);\n  }\n  public get value(): string {\n    return this.getAttribute('value') ?? '';\n  }\n\n  /** Whether the option is currently active. */\n  @property({ reflect: true, type: Boolean }) public active?: boolean;\n\n  /** Whether the option is selected. */\n  @property({ type: Boolean })\n  public set selected(value: boolean) {\n    this.toggleAttribute('selected', value);\n    this._updateAriaSelected();\n  }\n  public get selected(): boolean {\n    return this.hasAttribute('selected');\n  }\n\n  /** Emits when the option selection status changes. */\n  protected abstract selectionChange: EventEmitter;\n\n  /** Emits when an option was selected by user. */\n  protected abstract optionSelected: EventEmitter;\n\n  /** Whether to apply the negative styling */\n  @state() protected negative = false;\n\n  /** Whether the component must be set disabled due disabled attribute on sbb-optgroup. */\n  @state() protected disabledFromGroup = false;\n\n  @state() protected label?: string;\n\n  /** Disable the highlight of the label. */\n  @state() protected disableLabelHighlight: boolean = false;\n\n  /** The portion of the highlighted label. */\n  @state() private _highlightString: string | null = null;\n\n  @state() private _inertAriaGroups = false;\n\n  private _abort = new SbbConnectedAbortController(this);\n  protected abstract selectByClick(event: MouseEvent): void;\n  protected abstract setAttributeFromParent(): void;\n\n  protected updateDisableHighlight(disabled: boolean): void {\n    this.disableLabelHighlight = disabled;\n    this.toggleAttribute('data-disable-highlight', disabled);\n  }\n\n  /** MutationObserver on data attributes. */\n  private _optionAttributeObserver = new AgnosticMutationObserver((mutationsList) =>\n    this.onOptionAttributesChange(mutationsList),\n  );\n\n  public constructor() {\n    super();\n\n    if (inertAriaGroups) {\n      if (this.hydrationRequired) {\n        this.hydrationComplete.then(() => (this._inertAriaGroups = inertAriaGroups));\n      } else {\n        this._inertAriaGroups = inertAriaGroups;\n      }\n    }\n  }\n\n  public override attributeChangedCallback(\n    name: string,\n    old: string | null,\n    value: string | null,\n  ): void {\n    if (name !== 'value' || old !== value) {\n      super.attributeChangedCallback(name, old, value);\n    }\n  }\n\n  /**\n   * Highlight the label of the option\n   * @param value the highlighted portion of the label\n   * @internal\n   */\n  public highlight(value: string): void {\n    this._highlightString = value;\n  }\n\n  /**\n   * @internal\n   */\n  public setSelectedViaUserInteraction(selected: boolean): void {\n    this.selected = selected;\n    this.selectionChange.emit();\n    if (this.selected) {\n      this.optionSelected.emit();\n    }\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.id ||= `${this.optionId}-${nextId++}`;\n    if (this.hydrationRequired) {\n      this.hydrationComplete.then(() => this.init());\n    } else {\n      this.init();\n    }\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('disabled')) {\n      setOrRemoveAttribute(this, 'tabindex', isAndroid && !this.disabled && 0);\n      this.updateAriaDisabled();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // Init first select state because false would not call setter of selected property.\n    this._updateAriaSelected();\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._optionAttributeObserver.disconnect();\n  }\n\n  protected init(): void {\n    this.setAttributeFromParent();\n    this._optionAttributeObserver.observe(this, optionObserverConfig);\n    const signal = this._abort.signal;\n    this.addEventListener('click', (e: MouseEvent) => this.selectByClick(e), {\n      signal,\n      passive: true,\n    });\n  }\n\n  protected updateAriaDisabled(): void {\n    setOrRemoveAttribute(\n      this,\n      'aria-disabled',\n      this.disabled || this.disabledFromGroup ? 'true' : null,\n    );\n  }\n\n  private _updateAriaSelected(): void {\n    this.setAttribute('aria-selected', `${this.selected}`);\n  }\n\n  /** Observe changes on data attributes and set the appropriate values. */\n  protected onOptionAttributesChange(mutationsList: MutationRecord[]): void {\n    for (const mutation of mutationsList) {\n      if (mutation.attributeName === 'data-group-disabled') {\n        this.disabledFromGroup = this.hasAttribute('data-group-disabled');\n        this.updateAriaDisabled();\n      } else if (mutation.attributeName === 'data-negative') {\n        this.negative = this.hasAttribute('data-negative');\n      }\n    }\n  }\n\n  protected handleHighlightState(): void {\n    const slotNodes = Array.from(this.childNodes ?? []).filter(\n      (n) => n.nodeType !== Node.COMMENT_NODE && (!(n instanceof Element) || n.slot !== 'icon'),\n    );\n    const labelNodes = slotNodes.filter((el) => el.nodeType === Node.TEXT_NODE) as Text[];\n\n    // Disable the highlight if the slot contain more than just text nodes.\n    // We need to ignore template elements, as SSR adds a declarative shadow DOM\n    // in the form of a template element.\n    if (\n      labelNodes.length === 0 ||\n      slotNodes.filter((n) => !(n instanceof Element) || n.localName !== 'template').length !==\n        labelNodes.length\n    ) {\n      this.updateDisableHighlight(true);\n      return;\n    }\n    this.label = labelNodes\n      .map((l) => l.wholeText)\n      .filter((l) => l.trim())\n      .join();\n  }\n\n  protected getHighlightedLabel(): TemplateResult {\n    if (!this._highlightString || !this._highlightString.trim()) {\n      return html`${this.label}`;\n    }\n\n    const matchIndex = this.label!.toLowerCase().indexOf(this._highlightString.toLowerCase());\n\n    if (matchIndex === -1) {\n      return html`${this.label}`;\n    }\n\n    const prefix = this.label!.substring(0, matchIndex);\n    const highlighted = this.label!.substring(\n      matchIndex,\n      matchIndex + this._highlightString.length,\n    );\n    const postfix = this.label!.substring(matchIndex + this._highlightString.length);\n\n    return html`\n      <span class=\"sbb-option__label--highlight\">${prefix}</span><span>${highlighted}</span\n      ><span class=\"sbb-option__label--highlight\">${postfix}</span>\n    `;\n  }\n\n  protected renderIcon(): TemplateResult {\n    return html` <span class=\"sbb-option__icon\"> ${this.renderIconSlot()} </span>`;\n  }\n\n  protected renderLabel(): TemplateResult | typeof nothing {\n    return this.label && !this.disableLabelHighlight ? this.getHighlightedLabel() : nothing;\n  }\n\n  protected renderTick(): TemplateResult | typeof nothing {\n    return nothing;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-option__container\">\n        <div class=\"sbb-option\">\n          ${this.renderIcon()}\n          <span class=\"sbb-option__label\">\n            <slot @slotchange=${this.handleHighlightState}></slot>\n            ${this.renderLabel()}\n            ${this._inertAriaGroups && this.getAttribute('data-group-label')\n              ? html` <sbb-screen-reader-only>\n                  (${this.getAttribute('data-group-label')})</sbb-screen-reader-only\n                >`\n              : nothing}\n          </span>\n          ${this.renderTick()}\n        </div>\n      </div>\n    `;\n  }\n}\n","import type { CSSResultGroup, TemplateResult } from 'lit';\nimport { html, nothing } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { hostAttributes } from '../../core/decorators.js';\nimport { EventEmitter } from '../../core/eventing.js';\n\nimport { SbbOptionBaseElement } from './option-base-element.js';\nimport style from './option.scss?lit&inline';\nimport '../../visual-checkbox.js';\n\nexport type SbbOptionVariant = 'autocomplete' | 'select' | null;\n\n/**\n * It displays on option item which can be used in `sbb-select` or `sbb-autocomplete`.\n *\n * @slot - Use the unnamed slot to add content to the option label.\n * @slot icon - Use this slot to provide an icon. If `icon-name` is set, a sbb-icon will be used.\n * @event {CustomEvent<void>} optionSelectionChange - Emits when the option selection status changes.\n * @event {CustomEvent<void>} optionSelected - Emits when an option was selected by user.\n * @cssprop [--sbb-option-icon-container-display=none] - Can be used to reserve space even\n * when preserve-icon-space on autocomplete is not set or iconName is not set.\n */\n@customElement('sbb-option')\n@hostAttributes({\n  role: 'option',\n})\nexport class SbbOptionElement extends SbbOptionBaseElement {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    selectionChange: 'optionSelectionChange',\n    optionSelected: 'optionSelected',\n  } as const;\n\n  protected optionId = `sbb-option`;\n\n  /** Emits when the option selection status changes. */\n  protected selectionChange: EventEmitter = new EventEmitter(\n    this,\n    SbbOptionElement.events.selectionChange,\n  );\n\n  /** Emits when an option was selected by user. */\n  protected optionSelected: EventEmitter = new EventEmitter(\n    this,\n    SbbOptionElement.events.optionSelected,\n  );\n\n  private set _variant(state: SbbOptionVariant) {\n    if (state) {\n      this.setAttribute('data-variant', state);\n    }\n  }\n  private get _variant(): SbbOptionVariant {\n    return this.getAttribute('data-variant') as SbbOptionVariant;\n  }\n\n  private set _isMultiple(isMultiple: boolean) {\n    this.toggleAttribute('data-multiple', isMultiple);\n  }\n  private get _isMultiple(): boolean {\n    return !this.hydrationRequired && this.hasAttribute('data-multiple');\n  }\n\n  protected setAttributeFromParent(): void {\n    const parentGroup = this.closest?.('sbb-optgroup');\n    if (parentGroup) {\n      this.disabledFromGroup = parentGroup.disabled;\n      this.updateAriaDisabled();\n    }\n\n    this.negative = !!this.closest?.(\n      // :is() selector not possible due to test environment\n      `sbb-autocomplete[negative],sbb-form-field[negative]`,\n    );\n    this.toggleAttribute('data-negative', this.negative);\n\n    this.toggleAttribute('data-multiple', this._isMultiple);\n  }\n\n  protected selectByClick(event: MouseEvent): void {\n    if (this.disabled || this.disabledFromGroup) {\n      event.stopPropagation();\n      return;\n    }\n\n    if (this._isMultiple) {\n      event.stopPropagation();\n      this.setSelectedViaUserInteraction(!this.selected);\n    } else {\n      this.setSelectedViaUserInteraction(true);\n    }\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n  }\n\n  protected override init(): void {\n    super.init();\n    this._setVariantByContext();\n    // We need to check highlight state both on slot change, but also when connecting\n    // the element to the DOM. The slot change events might be swallowed when using declarative\n    // shadow DOM with SSR or if the DOM is changed when disconnected.\n    this.handleHighlightState();\n  }\n\n  private _setVariantByContext(): void {\n    if (this.closest?.('sbb-autocomplete')) {\n      this._variant = 'autocomplete';\n    } else if (this.closest?.('sbb-select')) {\n      this._variant = 'select';\n    }\n    this._isMultiple = !!this.closest?.('sbb-select[multiple]');\n  }\n\n  protected override handleHighlightState(): void {\n    if (this._variant !== 'autocomplete') {\n      this.updateDisableHighlight(true);\n      return;\n    }\n\n    super.handleHighlightState();\n  }\n\n  protected override renderIcon(): TemplateResult {\n    return html`\n      <!-- Icon -->\n      ${!this._isMultiple\n        ? html` <span class=\"sbb-option__icon\"> ${this.renderIconSlot()} </span>`\n        : nothing}\n\n      <!-- Checkbox -->\n      ${this._isMultiple\n        ? html`\n            <sbb-visual-checkbox\n              ?checked=${this.selected}\n              ?disabled=${this.disabled || this.disabledFromGroup}\n              ?negative=${this.negative}\n            ></sbb-visual-checkbox>\n          `\n        : nothing}\n    `;\n  }\n\n  protected override renderLabel(): TemplateResult | typeof nothing {\n    return this._variant === 'autocomplete' && this.label && !this.disableLabelHighlight\n      ? this.getHighlightedLabel()\n      : nothing;\n  }\n\n  protected override renderTick(): TemplateResult | typeof nothing {\n    return this._variant === 'select' && !this._isMultiple && this.selected\n      ? html`<sbb-icon name=\"tick-small\"></sbb-icon>`\n      : nothing;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-option': SbbOptionElement;\n  }\n\n  interface GlobalEventHandlersEventMap {\n    optionSelectionChange: CustomEvent<void>;\n  }\n}\n"],"names":["__decorateClass","state"],"mappings":"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"}