@sbb-esta/lyne-elements 1.3.0 → 1.4.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 (221) 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.js +18 -18
  52. package/checkbox/common.js +13 -13
  53. package/container/container.js +3 -3
  54. package/core/mixins/form-associated-mixin.d.ts.map +1 -1
  55. package/core/mixins.js +3 -1
  56. package/core/overlay/overlay-trigger-attributes.d.ts +1 -1
  57. package/core/overlay/overlay-trigger-attributes.d.ts.map +1 -1
  58. package/core/overlay.js +2 -2
  59. package/core/styles/core.scss +1 -0
  60. package/core/styles/mixins/buttons.scss +13 -8
  61. package/core/styles/mixins/helpers.scss +1 -0
  62. package/core/styles/mixins/pearl-chain-bullet.scss +1 -1
  63. package/core/styles/node_modules_@sbb-esta_lyne-design-tokens_dist_scss_sbb-variables.scss +1 -0
  64. package/core/styles/node_modules_@sbb-esta_lyne-design-tokens_dist_scss_sbb-variables_css--mixin.scss +2 -1
  65. package/core.css +3 -1
  66. package/custom-elements.json +13897 -9149
  67. package/datepicker/datepicker-next-day.js +12 -12
  68. package/datepicker/datepicker-previous-day.js +1 -1
  69. package/development/autocomplete/autocomplete-base-element.d.ts +93 -0
  70. package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -0
  71. package/development/autocomplete/autocomplete.d.ts +13 -86
  72. package/development/autocomplete/autocomplete.d.ts.map +1 -1
  73. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.d.ts +45 -0
  74. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.d.ts.map +1 -0
  75. package/development/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.d.ts +33 -0
  76. package/development/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.d.ts.map +1 -0
  77. package/development/autocomplete-grid/autocomplete-grid-button.d.ts +2 -0
  78. package/development/autocomplete-grid/autocomplete-grid-button.d.ts.map +1 -0
  79. package/development/autocomplete-grid/autocomplete-grid-button.js +224 -0
  80. package/development/autocomplete-grid/autocomplete-grid-cell/autocomplete-grid-cell.d.ts +17 -0
  81. package/development/autocomplete-grid/autocomplete-grid-cell/autocomplete-grid-cell.d.ts.map +1 -0
  82. package/development/autocomplete-grid/autocomplete-grid-cell.d.ts +2 -0
  83. package/development/autocomplete-grid/autocomplete-grid-cell.d.ts.map +1 -0
  84. package/development/autocomplete-grid/autocomplete-grid-cell.js +67 -0
  85. package/development/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.d.ts +21 -0
  86. package/development/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.d.ts.map +1 -0
  87. package/development/autocomplete-grid/autocomplete-grid-optgroup/index.d.ts +2 -0
  88. package/development/autocomplete-grid/autocomplete-grid-optgroup/index.d.ts.map +1 -0
  89. package/development/autocomplete-grid/autocomplete-grid-optgroup.d.ts +2 -0
  90. package/development/autocomplete-grid/autocomplete-grid-optgroup.d.ts.map +1 -0
  91. package/development/autocomplete-grid/autocomplete-grid-optgroup.js +45 -0
  92. package/development/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.d.ts +40 -0
  93. package/development/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.d.ts.map +1 -0
  94. package/development/autocomplete-grid/autocomplete-grid-option.d.ts +2 -0
  95. package/development/autocomplete-grid/autocomplete-grid-option.d.ts.map +1 -0
  96. package/development/autocomplete-grid/autocomplete-grid-option.js +174 -0
  97. package/development/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.d.ts +18 -0
  98. package/development/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.d.ts.map +1 -0
  99. package/development/autocomplete-grid/autocomplete-grid-row.d.ts +2 -0
  100. package/development/autocomplete-grid/autocomplete-grid-row.d.ts.map +1 -0
  101. package/development/autocomplete-grid/autocomplete-grid-row.js +143 -0
  102. package/development/autocomplete-grid/autocomplete-grid.d.ts +2 -0
  103. package/development/autocomplete-grid/autocomplete-grid.d.ts.map +1 -0
  104. package/development/autocomplete-grid/autocomplete-grid.js +185 -0
  105. package/development/autocomplete-grid.d.ts +7 -0
  106. package/development/autocomplete-grid.d.ts.map +1 -0
  107. package/development/autocomplete-grid.js +7 -0
  108. package/development/autocomplete.d.ts +1 -0
  109. package/development/autocomplete.d.ts.map +1 -1
  110. package/development/autocomplete.js +168 -143
  111. package/development/breadcrumb/breadcrumb-group/breadcrumb-group.d.ts.map +1 -1
  112. package/development/breadcrumb/breadcrumb-group.js +1 -1
  113. package/development/button/mini-button/mini-button-base-element.d.ts +9 -0
  114. package/development/button/mini-button/mini-button-base-element.d.ts.map +1 -0
  115. package/development/button/mini-button/mini-button.d.ts +3 -4
  116. package/development/button/mini-button/mini-button.d.ts.map +1 -1
  117. package/development/button/mini-button.d.ts +1 -0
  118. package/development/button/mini-button.d.ts.map +1 -1
  119. package/development/button/mini-button.js +32 -16
  120. package/development/checkbox/checkbox.js +7 -1
  121. package/development/checkbox/common.js +1 -3
  122. package/development/container/container.js +2 -1
  123. package/development/core/mixins/form-associated-mixin.d.ts.map +1 -1
  124. package/development/core/mixins.js +4 -2
  125. package/development/core/overlay/overlay-trigger-attributes.d.ts +1 -1
  126. package/development/core/overlay/overlay-trigger-attributes.d.ts.map +1 -1
  127. package/development/core/overlay.js +3 -3
  128. package/development/datepicker/datepicker-next-day.js +8 -7
  129. package/development/datepicker/datepicker-previous-day.js +8 -7
  130. package/development/form-field/form-field-clear/form-field-clear.d.ts.map +1 -1
  131. package/development/form-field/form-field-clear.js +8 -7
  132. package/development/form-field/form-field.js +3 -3
  133. package/development/icon/icon-base.d.ts.map +1 -1
  134. package/development/icon/icon.d.ts.map +1 -1
  135. package/development/icon.js +1 -1
  136. package/development/image/image.d.ts +1 -0
  137. package/development/image/image.d.ts.map +1 -1
  138. package/development/image.js +10 -4
  139. package/development/map-container.js +12 -14
  140. package/development/navigation/navigation-marker/navigation-marker.d.ts.map +1 -1
  141. package/development/navigation/navigation-marker.js +1 -1
  142. package/development/option/optgroup/optgroup-base-element.d.ts +28 -0
  143. package/development/option/optgroup/optgroup-base-element.d.ts.map +1 -0
  144. package/development/option/optgroup/optgroup.d.ts +7 -20
  145. package/development/option/optgroup/optgroup.d.ts.map +1 -1
  146. package/development/option/optgroup.d.ts +1 -0
  147. package/development/option/optgroup.d.ts.map +1 -1
  148. package/development/option/optgroup.js +74 -49
  149. package/development/option/option/option-base-element.d.ts +69 -0
  150. package/development/option/option/option-base-element.d.ts.map +1 -0
  151. package/development/option/option/option.d.ts +14 -57
  152. package/development/option/option/option.d.ts.map +1 -1
  153. package/development/option/option.d.ts +1 -0
  154. package/development/option/option.d.ts.map +1 -1
  155. package/development/option/option.js +267 -220
  156. package/development/radio-button/common/radio-button-common.d.ts +1 -1
  157. package/development/radio-button/common/radio-button-common.d.ts.map +1 -1
  158. package/development/radio-button/common.js +13 -12
  159. package/development/radio-button/radio-button/radio-button.d.ts +7 -0
  160. package/development/radio-button/radio-button/radio-button.d.ts.map +1 -1
  161. package/development/radio-button/radio-button-group/radio-button-group.d.ts +1 -1
  162. package/development/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  163. package/development/radio-button/radio-button-group.js +1 -1
  164. package/development/radio-button/radio-button-panel/radio-button-panel.d.ts +7 -0
  165. package/development/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -1
  166. package/development/radio-button/radio-button-panel.js +16 -2
  167. package/development/radio-button/radio-button.js +16 -2
  168. package/development/skiplink-list/skiplink-list.d.ts +1 -0
  169. package/development/skiplink-list/skiplink-list.d.ts.map +1 -1
  170. package/development/skiplink-list.js +1 -1
  171. package/development/tabs/tab-group.js +2 -9
  172. package/development/tabs/tab.js +10 -2
  173. package/development/tag/tag-group.js +1 -1
  174. package/development/timetable-occupancy-icon/timetable-occupancy-icon.d.ts.map +1 -1
  175. package/development/timetable-occupancy-icon.js +3 -6
  176. package/development/toggle/toggle.js +1 -1
  177. package/form-field/form-field-clear/form-field-clear.d.ts.map +1 -1
  178. package/form-field/form-field-clear.js +11 -11
  179. package/form-field/form-field.js +2 -2
  180. package/icon/icon-base.d.ts.map +1 -1
  181. package/icon/icon.d.ts.map +1 -1
  182. package/image/image.d.ts +1 -0
  183. package/image/image.d.ts.map +1 -1
  184. package/image.js +24 -24
  185. package/index.d.ts +12 -0
  186. package/index.js +12 -0
  187. package/map-container.js +8 -8
  188. package/navigation/navigation-marker/navigation-marker.d.ts.map +1 -1
  189. package/option/optgroup/optgroup-base-element.d.ts +28 -0
  190. package/option/optgroup/optgroup-base-element.d.ts.map +1 -0
  191. package/option/optgroup/optgroup.d.ts +7 -20
  192. package/option/optgroup/optgroup.d.ts.map +1 -1
  193. package/option/optgroup.d.ts +1 -0
  194. package/option/optgroup.d.ts.map +1 -1
  195. package/option/optgroup.js +80 -60
  196. package/option/option/option-base-element.d.ts +69 -0
  197. package/option/option/option-base-element.d.ts.map +1 -0
  198. package/option/option/option.d.ts +14 -57
  199. package/option/option/option.d.ts.map +1 -1
  200. package/option/option.d.ts +1 -0
  201. package/option/option.d.ts.map +1 -1
  202. package/option/option.js +186 -145
  203. package/package.json +36 -1
  204. package/radio-button/common/radio-button-common.d.ts +1 -1
  205. package/radio-button/common/radio-button-common.d.ts.map +1 -1
  206. package/radio-button/common.js +6 -15
  207. package/radio-button/radio-button/radio-button.d.ts +7 -0
  208. package/radio-button/radio-button/radio-button.d.ts.map +1 -1
  209. package/radio-button/radio-button-group/radio-button-group.d.ts +1 -1
  210. package/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  211. package/radio-button/radio-button-panel/radio-button-panel.d.ts +7 -0
  212. package/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -1
  213. package/radio-button/radio-button-panel.js +35 -22
  214. package/radio-button/radio-button.js +32 -19
  215. package/skiplink-list/skiplink-list.d.ts +1 -0
  216. package/skiplink-list/skiplink-list.d.ts.map +1 -1
  217. package/standard-theme.css +3 -1
  218. package/tabs/tab-group.js +19 -19
  219. package/tabs/tab.js +10 -10
  220. package/timetable-occupancy-icon/timetable-occupancy-icon.d.ts.map +1 -1
  221. package/timetable-occupancy-icon.js +22 -24
@@ -1,13 +1,13 @@
1
- import { css, isServer, html, nothing } from "lit";
2
1
  import { property, customElement } from "lit/decorators.js";
3
- import { ref } from "lit/directives/ref.js";
4
2
  import { getNextElementIndex } from "./core/a11y.js";
3
+ import { hostAttributes } from "./core/decorators.js";
4
+ import { findReferencedElement, isSafari, getDocumentWritingMode } from "./core/dom.js";
5
+ import { isEventOnElement, setOverlayPosition, removeAriaComboBoxAttributes, overlayGapFixCorners, setAriaComboBoxAttributes } from "./core/overlay.js";
6
+ import { css, isServer, html, nothing } from "lit";
7
+ import { ref } from "lit/directives/ref.js";
5
8
  import { SbbOpenCloseBaseElement } from "./core/base-elements.js";
6
9
  import { SbbConnectedAbortController } from "./core/controllers.js";
7
- import { hostAttributes } from "./core/decorators.js";
8
- import { findReferencedElement, getDocumentWritingMode, isSafari } from "./core/dom.js";
9
10
  import { SbbNegativeMixin, SbbHydrationMixin } from "./core/mixins.js";
10
- import { isEventOnElement, setOverlayPosition, setAriaComboBoxAttributes, removeAriaComboBoxAttributes, overlayGapFixCorners } from "./core/overlay.js";
11
11
  const style = css`/**
12
12
  * Better font rendering (on OS X)
13
13
  * http://maximilianhoffmann.com/posts/better-font-rendering-on-osx
@@ -96,6 +96,7 @@ const style = css`/**
96
96
  );
97
97
  --sbb-options-panel-background-color: var(--sbb-color-white);
98
98
  --sbb-focus-outline-color: var(--sbb-focus-outline-color-default);
99
+ --sbb-options-pointer-events: all;
99
100
  --sbb-options-panel-internal-z-index: var(
100
101
  --sbb-autocomplete-z-index,
101
102
  var(--sbb-overlay-default-z-index)
@@ -113,6 +114,7 @@ const style = css`/**
113
114
  :host(:not([data-state])),
114
115
  :host([data-state=closed]) {
115
116
  --sbb-options-panel-visibility: hidden;
117
+ --sbb-options-pointer-events: none;
116
118
  }
117
119
 
118
120
  :host([data-state=opening]) {
@@ -243,6 +245,7 @@ const style = css`/**
243
245
  animation-name: var(--sbb-options-panel-animation-name);
244
246
  animation-duration: var(--sbb-options-panel-animation-duration);
245
247
  animation-timing-function: var(--sbb-options-panel-animation-timing-function);
248
+ pointer-events: var(--sbb-options-pointer-events);
246
249
  }
247
250
  .sbb-autocomplete__options::-webkit-scrollbar {
248
251
  width: var(--sbb-scrollbar-width);
@@ -298,28 +301,24 @@ const style = css`/**
298
301
  opacity: 0;
299
302
  }
300
303
  }`;
301
- var __defProp = Object.defineProperty;
302
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
303
- var __decorateClass = (decorators, target, key, kind) => {
304
- var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
304
+ var __defProp$1 = Object.defineProperty;
305
+ var __decorateClass$1 = (decorators, target, key, kind) => {
306
+ var result = void 0;
305
307
  for (var i = decorators.length - 1, decorator; i >= 0; i--)
306
308
  if (decorator = decorators[i])
307
- result = (kind ? decorator(target, key, result) : decorator(result)) || result;
308
- if (kind && result) __defProp(target, key, result);
309
+ result = decorator(target, key, result) || result;
310
+ if (result) __defProp$1(target, key, result);
309
311
  return result;
310
312
  };
311
- let nextId = 0;
312
- const ariaRoleOnHost = isSafari;
313
- let SbbAutocompleteElement = class extends SbbNegativeMixin(
313
+ const ariaRoleOnHost$1 = isSafari;
314
+ const _SbbAutocompleteBaseElement = class _SbbAutocompleteBaseElement extends SbbNegativeMixin(
314
315
  SbbHydrationMixin(SbbOpenCloseBaseElement)
315
316
  ) {
316
317
  constructor() {
317
318
  super(...arguments);
318
- this._overlayId = `sbb-autocomplete-${++nextId}`;
319
- this._activeItemIndex = -1;
319
+ this.abort = new SbbConnectedAbortController(this);
320
320
  this._didLoad = false;
321
321
  this._isPointerDownEventOnMenu = false;
322
- this._abort = new SbbConnectedAbortController(this);
323
322
  this._pointerDownListener = (event) => {
324
323
  this._isPointerDownEventOnMenu = isEventOnElement(this._overlay, event);
325
324
  };
@@ -340,18 +339,9 @@ let SbbAutocompleteElement = class extends SbbNegativeMixin(
340
339
  get triggerElement() {
341
340
  return this._triggerElement;
342
341
  }
343
- /** The autocomplete should inherit 'readonly' state from the trigger. */
344
- get _readonly() {
345
- var _a;
346
- return ((_a = this.triggerElement) == null ? void 0 : _a.hasAttribute("readonly")) ?? false;
347
- }
348
- get _options() {
349
- var _a;
350
- return Array.from(((_a = this.querySelectorAll) == null ? void 0 : _a.call(this, "sbb-option")) ?? []);
351
- }
352
342
  /** Opens the autocomplete. */
353
343
  open() {
354
- if (this.state !== "closed" || !this._overlay || this._options.length === 0 || this._readonly) {
344
+ if (this.state !== "closed" || !this._overlay || this.options.length === 0 || this._readonly) {
355
345
  return;
356
346
  }
357
347
  if (!this.willOpen.emit()) {
@@ -371,59 +361,21 @@ let SbbAutocompleteElement = class extends SbbNegativeMixin(
371
361
  this.state = "closing";
372
362
  this._openPanelEventsController.abort();
373
363
  }
374
- /** Removes trigger click listener on trigger change. */
375
- _resetOriginClickListener(newValue, oldValue) {
376
- if (newValue !== oldValue) {
377
- this._componentSetup();
378
- }
379
- }
380
- /** Removes trigger click listener on trigger change. */
381
- _resetTriggerClickListener(newValue, oldValue) {
382
- if (newValue !== oldValue) {
383
- this._componentSetup();
384
- }
385
- }
386
- /** When an option is selected, update the input value and close the autocomplete. */
387
- _onOptionSelected(event) {
388
- const target = event.target;
389
- if (!target.selected) {
390
- return;
391
- }
392
- this._options.filter((option) => option.id !== target.id && option.selected).forEach((option) => option.selected = false);
393
- if (this.triggerElement) {
394
- this.triggerElement.value = target.value;
395
- this.triggerElement.dispatchEvent(new Event("change", { bubbles: true }));
396
- this.triggerElement.dispatchEvent(new InputEvent("input", { bubbles: true, composed: true }));
397
- }
398
- this.close();
399
- }
400
- _onOptionClick(event) {
401
- if (event.target.localName !== "sbb-option" || event.target.disabled) {
402
- return;
403
- }
404
- this.close();
405
- }
406
364
  connectedCallback() {
407
- var _a, _b;
408
365
  super.connectedCallback();
409
- if (ariaRoleOnHost) {
410
- this.id || (this.id = this._overlayId);
366
+ if (ariaRoleOnHost$1) {
367
+ this.id || (this.id = this.overlayId);
411
368
  }
412
- const signal = this._abort.signal;
413
- const formField = ((_a = this.closest) == null ? void 0 : _a.call(this, "sbb-form-field")) ?? ((_b = this.closest) == null ? void 0 : _b.call(this, "[data-form-field]"));
369
+ const signal = this.abort.signal;
370
+ const formField = this.closest("sbb-form-field") ?? this.closest("[data-form-field]");
414
371
  if (formField) {
415
372
  this.negative = formField.hasAttribute("negative");
416
373
  }
417
374
  if (this._didLoad) {
418
375
  this._componentSetup();
419
376
  }
420
- this._syncNegative();
421
- this.addEventListener(
422
- "optionSelectionChange",
423
- (e) => this._onOptionSelected(e),
424
- { signal }
425
- );
426
- this.addEventListener("click", (e) => this._onOptionClick(e), { signal });
377
+ this.syncNegative();
378
+ this.addEventListener("click", (e) => this.onOptionClick(e), { signal });
427
379
  }
428
380
  willUpdate(changedProperties) {
429
381
  super.willUpdate(changedProperties);
@@ -434,7 +386,7 @@ let SbbAutocompleteElement = class extends SbbNegativeMixin(
434
386
  this._resetTriggerClickListener(this.trigger, changedProperties.get("trigger"));
435
387
  }
436
388
  if (changedProperties.has("negative")) {
437
- this._syncNegative();
389
+ this.syncNegative();
438
390
  }
439
391
  }
440
392
  firstUpdated(changedProperties) {
@@ -442,20 +394,47 @@ let SbbAutocompleteElement = class extends SbbNegativeMixin(
442
394
  this._componentSetup();
443
395
  this._didLoad = true;
444
396
  }
445
- _syncNegative() {
446
- var _a, _b;
447
- (_a = this.querySelectorAll) == null ? void 0 : _a.call(this, "sbb-divider").forEach((divider) => divider.negative = this.negative);
448
- (_b = this.querySelectorAll) == null ? void 0 : _b.call(
449
- this,
450
- "sbb-option, sbb-optgroup"
451
- ).forEach((element) => element.toggleAttribute("data-negative", this.negative));
452
- }
453
397
  disconnectedCallback() {
454
398
  var _a, _b;
455
399
  super.disconnectedCallback();
456
400
  (_a = this._triggerEventsController) == null ? void 0 : _a.abort();
457
401
  (_b = this._openPanelEventsController) == null ? void 0 : _b.abort();
458
402
  }
403
+ /** When an option is selected, update the input value and close the autocomplete. */
404
+ onOptionSelected(event) {
405
+ const target = event.target;
406
+ if (!target.selected) {
407
+ return;
408
+ }
409
+ this.options.filter((option) => option.id !== target.id && option.selected).forEach((option) => option.selected = false);
410
+ if (this.triggerElement) {
411
+ this.triggerElement.value = target.value;
412
+ this.triggerElement.dispatchEvent(new Event("change", { bubbles: true }));
413
+ this.triggerElement.dispatchEvent(new InputEvent("input", { bubbles: true, composed: true }));
414
+ }
415
+ this.close();
416
+ }
417
+ _handleSlotchange() {
418
+ var _a;
419
+ this._highlightOptions((_a = this.triggerElement) == null ? void 0 : _a.value);
420
+ }
421
+ /** The autocomplete should inherit 'readonly' state from the trigger. */
422
+ get _readonly() {
423
+ var _a;
424
+ return ((_a = this.triggerElement) == null ? void 0 : _a.hasAttribute("readonly")) ?? false;
425
+ }
426
+ /** Removes trigger click listener on trigger change. */
427
+ _resetOriginClickListener(newValue, oldValue) {
428
+ if (newValue !== oldValue) {
429
+ this._componentSetup();
430
+ }
431
+ }
432
+ /** Removes trigger click listener on trigger change. */
433
+ _resetTriggerClickListener(newValue, oldValue) {
434
+ if (newValue !== oldValue) {
435
+ this._componentSetup();
436
+ }
437
+ }
459
438
  _componentSetup() {
460
439
  var _a, _b, _c, _d;
461
440
  if (isServer) {
@@ -511,7 +490,7 @@ let SbbAutocompleteElement = class extends SbbNegativeMixin(
511
490
  return;
512
491
  }
513
492
  this._removeTriggerAttributes(this.triggerElement);
514
- this._setTriggerAttributes(triggerElem);
493
+ this.setTriggerAttributes(triggerElem);
515
494
  this._triggerElement = triggerElem;
516
495
  this._setupTriggerEvents();
517
496
  }
@@ -570,7 +549,7 @@ let SbbAutocompleteElement = class extends SbbNegativeMixin(
570
549
  var _a;
571
550
  this.state = "closed";
572
551
  (_a = this.triggerElement) == null ? void 0 : _a.setAttribute("aria-expanded", "false");
573
- this._resetActiveElement();
552
+ this.resetActiveElement();
574
553
  this._optionContainer.scrollTop = 0;
575
554
  this.didClose.emit();
576
555
  }
@@ -593,7 +572,7 @@ let SbbAutocompleteElement = class extends SbbNegativeMixin(
593
572
  });
594
573
  (_a = this.triggerElement) == null ? void 0 : _a.addEventListener(
595
574
  "keydown",
596
- (event) => this._openedPanelKeyboardInteraction(event),
575
+ (event) => this.openedPanelKeyboardInteraction(event),
597
576
  {
598
577
  signal: this._openPanelEventsController.signal
599
578
  }
@@ -611,7 +590,100 @@ let SbbAutocompleteElement = class extends SbbNegativeMixin(
611
590
  break;
612
591
  }
613
592
  }
614
- _openedPanelKeyboardInteraction(event) {
593
+ /** Highlight the searched text on the options. */
594
+ _highlightOptions(searchTerm) {
595
+ if (searchTerm === null || searchTerm === void 0) {
596
+ return;
597
+ }
598
+ this.options.forEach((option) => option.highlight(searchTerm));
599
+ }
600
+ _removeTriggerAttributes(element) {
601
+ removeAriaComboBoxAttributes(element);
602
+ }
603
+ render() {
604
+ return html`
605
+ <div class="sbb-autocomplete__gap-fix"></div>
606
+ <div class="sbb-autocomplete__container">
607
+ <div class="sbb-autocomplete__gap-fix">${overlayGapFixCorners()}</div>
608
+ <div
609
+ @animationend=${this._onAnimationEnd}
610
+ class="sbb-autocomplete__panel"
611
+ ?data-open=${this.state === "opened" || this.state === "opening"}
612
+ ${ref((overlayRef) => this._overlay = overlayRef)}
613
+ >
614
+ <div class="sbb-autocomplete__wrapper">
615
+ <div
616
+ class="sbb-autocomplete__options"
617
+ role=${!ariaRoleOnHost$1 ? this.panelRole : nothing}
618
+ id=${!ariaRoleOnHost$1 ? this.overlayId : nothing}
619
+ ${ref((containerRef) => this._optionContainer = containerRef)}
620
+ >
621
+ <slot @slotchange=${this._handleSlotchange}></slot>
622
+ </div>
623
+ </div>
624
+ </div>
625
+ </div>
626
+ `;
627
+ }
628
+ };
629
+ _SbbAutocompleteBaseElement.styles = style;
630
+ let SbbAutocompleteBaseElement = _SbbAutocompleteBaseElement;
631
+ __decorateClass$1([
632
+ property()
633
+ ], SbbAutocompleteBaseElement.prototype, "origin");
634
+ __decorateClass$1([
635
+ property()
636
+ ], SbbAutocompleteBaseElement.prototype, "trigger");
637
+ __decorateClass$1([
638
+ property({ attribute: "preserve-icon-space", reflect: true, type: Boolean })
639
+ ], SbbAutocompleteBaseElement.prototype, "preserveIconSpace");
640
+ var __defProp = Object.defineProperty;
641
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
642
+ var __decorateClass = (decorators, target, key, kind) => {
643
+ var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
644
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
645
+ if (decorator = decorators[i])
646
+ result = (kind ? decorator(target, key, result) : decorator(result)) || result;
647
+ if (kind && result) __defProp(target, key, result);
648
+ return result;
649
+ };
650
+ let nextId = 0;
651
+ const ariaRoleOnHost = isSafari;
652
+ let SbbAutocompleteElement = class extends SbbAutocompleteBaseElement {
653
+ constructor() {
654
+ super(...arguments);
655
+ this.overlayId = `sbb-autocomplete-${++nextId}`;
656
+ this.panelRole = "listbox";
657
+ this._activeItemIndex = -1;
658
+ }
659
+ get options() {
660
+ var _a;
661
+ return Array.from(((_a = this.querySelectorAll) == null ? void 0 : _a.call(this, "sbb-option")) ?? []);
662
+ }
663
+ onOptionClick(event) {
664
+ if (event.target.localName !== "sbb-option" || event.target.disabled) {
665
+ return;
666
+ }
667
+ this.close();
668
+ }
669
+ connectedCallback() {
670
+ super.connectedCallback();
671
+ const signal = this.abort.signal;
672
+ this.addEventListener(
673
+ "optionSelectionChange",
674
+ (e) => this.onOptionSelected(e),
675
+ { signal }
676
+ );
677
+ }
678
+ syncNegative() {
679
+ var _a, _b;
680
+ (_a = this.querySelectorAll) == null ? void 0 : _a.call(this, "sbb-divider").forEach((divider) => divider.negative = this.negative);
681
+ (_b = this.querySelectorAll) == null ? void 0 : _b.call(
682
+ this,
683
+ "sbb-option, sbb-optgroup"
684
+ ).forEach((element) => element.toggleAttribute("data-negative", this.negative));
685
+ }
686
+ openedPanelKeyboardInteraction(event) {
615
687
  if (this.state !== "opened") {
616
688
  return;
617
689
  }
@@ -621,23 +693,23 @@ let SbbAutocompleteElement = class extends SbbNegativeMixin(
621
693
  this.close();
622
694
  break;
623
695
  case "Enter":
624
- this._selectByKeyboard();
696
+ this.selectByKeyboard();
625
697
  break;
626
698
  case "ArrowDown":
627
699
  case "ArrowUp":
628
- this._setNextActiveOption(event);
700
+ this.setNextActiveOption(event);
629
701
  break;
630
702
  }
631
703
  }
632
- _selectByKeyboard() {
633
- const activeOption = this._options[this._activeItemIndex];
704
+ selectByKeyboard() {
705
+ const activeOption = this.options[this._activeItemIndex];
634
706
  if (activeOption) {
635
707
  activeOption.setSelectedViaUserInteraction(true);
636
708
  }
637
709
  }
638
- _setNextActiveOption(event) {
710
+ setNextActiveOption(event) {
639
711
  var _a;
640
- const filteredOptions = this._options.filter(
712
+ const filteredOptions = this.options.filter(
641
713
  (opt) => !opt.disabled && !opt.hasAttribute("data-group-disabled")
642
714
  );
643
715
  const next = getNextElementIndex(event, this._activeItemIndex, filteredOptions.length);
@@ -651,67 +723,19 @@ let SbbAutocompleteElement = class extends SbbNegativeMixin(
651
723
  }
652
724
  this._activeItemIndex = next;
653
725
  }
654
- _resetActiveElement() {
726
+ resetActiveElement() {
655
727
  var _a;
656
- const activeElement = this._options[this._activeItemIndex];
728
+ const activeElement = this.options[this._activeItemIndex];
657
729
  if (activeElement) {
658
730
  activeElement.active = false;
659
731
  }
660
732
  this._activeItemIndex = -1;
661
733
  (_a = this.triggerElement) == null ? void 0 : _a.removeAttribute("aria-activedescendant");
662
734
  }
663
- /** Highlight the searched text on the options. */
664
- _highlightOptions(searchTerm) {
665
- if (!searchTerm) {
666
- return;
667
- }
668
- this._options.forEach((option) => option.highlight(searchTerm));
669
- }
670
- _setTriggerAttributes(element) {
671
- setAriaComboBoxAttributes(element, this.id || this._overlayId, false);
672
- }
673
- _removeTriggerAttributes(element) {
674
- removeAriaComboBoxAttributes(element);
675
- }
676
- _handleSlotchange() {
677
- var _a;
678
- this._highlightOptions((_a = this.triggerElement) == null ? void 0 : _a.value);
679
- }
680
- render() {
681
- return html`
682
- <div class="sbb-autocomplete__gap-fix"></div>
683
- <div class="sbb-autocomplete__container">
684
- <div class="sbb-autocomplete__gap-fix">${overlayGapFixCorners()}</div>
685
- <div
686
- @animationend=${this._onAnimationEnd}
687
- class="sbb-autocomplete__panel"
688
- ${ref((overlayRef) => this._overlay = overlayRef)}
689
- >
690
- <div class="sbb-autocomplete__wrapper">
691
- <div
692
- class="sbb-autocomplete__options"
693
- role=${!ariaRoleOnHost ? "listbox" : nothing}
694
- id=${!ariaRoleOnHost ? this._overlayId : nothing}
695
- ${ref((containerRef) => this._optionContainer = containerRef)}
696
- >
697
- <slot @slotchange=${this._handleSlotchange}></slot>
698
- </div>
699
- </div>
700
- </div>
701
- </div>
702
- `;
735
+ setTriggerAttributes(element) {
736
+ setAriaComboBoxAttributes(element, ariaRoleOnHost ? this.id : this.overlayId, false);
703
737
  }
704
738
  };
705
- SbbAutocompleteElement.styles = style;
706
- __decorateClass([
707
- property()
708
- ], SbbAutocompleteElement.prototype, "origin", 2);
709
- __decorateClass([
710
- property()
711
- ], SbbAutocompleteElement.prototype, "trigger", 2);
712
- __decorateClass([
713
- property({ attribute: "preserve-icon-space", reflect: true, type: Boolean })
714
- ], SbbAutocompleteElement.prototype, "preserveIconSpace", 2);
715
739
  SbbAutocompleteElement = __decorateClass([
716
740
  customElement("sbb-autocomplete"),
717
741
  hostAttributes({
@@ -720,6 +744,7 @@ SbbAutocompleteElement = __decorateClass([
720
744
  })
721
745
  ], SbbAutocompleteElement);
722
746
  export {
747
+ SbbAutocompleteBaseElement,
723
748
  SbbAutocompleteElement
724
749
  };
725
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"autocomplete.js","sources":["../../../src/elements/autocomplete/autocomplete.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, isServer, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { getNextElementIndex } from '../core/a11y.js';\nimport { SbbOpenCloseBaseElement } from '../core/base-elements.js';\nimport { SbbConnectedAbortController } from '../core/controllers.js';\nimport { hostAttributes } from '../core/decorators.js';\nimport { findReferencedElement, getDocumentWritingMode, isSafari } from '../core/dom.js';\nimport { SbbHydrationMixin, SbbNegativeMixin } from '../core/mixins.js';\nimport {\n  isEventOnElement,\n  overlayGapFixCorners,\n  removeAriaComboBoxAttributes,\n  setAriaComboBoxAttributes,\n  setOverlayPosition,\n} from '../core/overlay.js';\nimport type { SbbOptGroupElement, SbbOptionElement } from '../option.js';\n\nimport style from './autocomplete.scss?lit&inline';\n\nlet nextId = 0;\n\n/**\n * On Safari, the aria role 'listbox' must be on the host element, or else VoiceOver won't work at all.\n * On the other hand, JAWS and NVDA need the role to be \"closer\" to the options, or else optgroups won't work.\n */\nconst ariaRoleOnHost = isSafari;\n\n/**\n * Combined with a native input, it displays a panel with a list of available options.\n *\n * @slot - Use the unnamed slot to add `sbb-option` or `sbb-optgroup` elements to the `sbb-autocomplete`.\n * @event {CustomEvent<void>} willOpen - Emits whenever the `sbb-autocomplete` starts the opening transition. Can be canceled.\n * @event {CustomEvent<void>} didOpen - Emits whenever the `sbb-autocomplete` is opened.\n * @event {CustomEvent<void>} willClose - Emits whenever the `sbb-autocomplete` begins the closing transition. Can be canceled.\n * @event {CustomEvent<void>} didClose - Emits whenever the `sbb-autocomplete` is closed.\n * @cssprop [--sbb-autocomplete-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,\n * the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the\n * component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.\n */\n@customElement('sbb-autocomplete')\n@hostAttributes({\n  dir: getDocumentWritingMode(),\n  role: ariaRoleOnHost ? 'listbox' : null,\n})\nexport class SbbAutocompleteElement extends SbbNegativeMixin(\n  SbbHydrationMixin(SbbOpenCloseBaseElement),\n) {\n  public static override styles: CSSResultGroup = style;\n\n  /**\n   * The element where the autocomplete will attach; accepts both an element's id or an HTMLElement.\n   * If not set, will search for the first 'sbb-form-field' ancestor.\n   */\n  @property() public origin?: string | HTMLElement;\n\n  /**\n   * The input element that will trigger the autocomplete opening; accepts both an element's id or an HTMLElement.\n   * By default, the autocomplete will open on focus, click, input or `ArrowDown` keypress of the 'trigger' element.\n   * If not set, will search for the first 'input' child of a 'sbb-form-field' ancestor.\n   */\n  @property() public trigger?: string | HTMLInputElement;\n\n  /** Whether the icon space is preserved when no icon is set. */\n  @property({ attribute: 'preserve-icon-space', reflect: true, type: Boolean })\n  public preserveIconSpace?: boolean;\n\n  private _overlay!: HTMLElement;\n  private _optionContainer!: HTMLElement;\n\n  /** Returns the element where autocomplete overlay is attached to. */\n  public get originElement(): HTMLElement {\n    if (!this._originElement) {\n      this._originElement = this._findOriginElement();\n    }\n    return this._originElement;\n  }\n  private _originElement?: HTMLElement;\n\n  /** Returns the trigger element. */\n  public get triggerElement(): HTMLInputElement | undefined {\n    return this._triggerElement;\n  }\n  private _triggerElement: HTMLInputElement | undefined;\n\n  private _triggerEventsController!: AbortController;\n  private _openPanelEventsController!: AbortController;\n  private _overlayId = `sbb-autocomplete-${++nextId}`;\n  private _activeItemIndex = -1;\n  private _didLoad = false;\n  private _isPointerDownEventOnMenu: boolean = false;\n  private _abort = new SbbConnectedAbortController(this);\n\n  /** The autocomplete should inherit 'readonly' state from the trigger. */\n  private get _readonly(): boolean {\n    return this.triggerElement?.hasAttribute('readonly') ?? false;\n  }\n\n  private get _options(): SbbOptionElement[] {\n    return Array.from(this.querySelectorAll?.('sbb-option') ?? []);\n  }\n\n  /** Opens the autocomplete. */\n  public open(): void {\n    if (this.state !== 'closed' || !this._overlay || this._options.length === 0 || this._readonly) {\n      return;\n    }\n    if (!this.willOpen.emit()) {\n      return;\n    }\n\n    this.state = 'opening';\n    this._setOverlayPosition();\n  }\n\n  /** Closes the autocomplete. */\n  public close(): void {\n    if (this.state !== 'opened') {\n      return;\n    }\n    if (!this.willClose.emit()) {\n      return;\n    }\n\n    this.state = 'closing';\n    this._openPanelEventsController.abort();\n  }\n\n  /** Removes trigger click listener on trigger change. */\n  private _resetOriginClickListener(\n    newValue?: string | HTMLElement,\n    oldValue?: string | HTMLElement,\n  ): void {\n    if (newValue !== oldValue) {\n      this._componentSetup();\n    }\n  }\n\n  /** Removes trigger click listener on trigger change. */\n  private _resetTriggerClickListener(\n    newValue?: string | HTMLElement,\n    oldValue?: string | HTMLElement,\n  ): void {\n    if (newValue !== oldValue) {\n      this._componentSetup();\n    }\n  }\n\n  /** When an option is selected, update the input value and close the autocomplete. */\n  private _onOptionSelected(event: CustomEvent): void {\n    const target = event.target as SbbOptionElement;\n    if (!target.selected) {\n      return;\n    }\n\n    // Deselect the previous options\n    this._options\n      .filter((option) => option.id !== target.id && option.selected)\n      .forEach((option) => (option.selected = false));\n\n    if (this.triggerElement) {\n      // Set the option value\n      this.triggerElement.value = target.value as string;\n\n      // Manually trigger the change events\n      this.triggerElement.dispatchEvent(new Event('change', { bubbles: true }));\n      this.triggerElement.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n    }\n\n    this.close();\n  }\n\n  private _onOptionClick(event: MouseEvent): void {\n    if (\n      (event.target as Element).localName !== 'sbb-option' ||\n      (event.target as SbbOptionElement).disabled\n    ) {\n      return;\n    }\n    this.close();\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    if (ariaRoleOnHost) {\n      this.id ||= this._overlayId;\n    }\n\n    const signal = this._abort.signal;\n    const formField = this.closest?.('sbb-form-field') ?? this.closest?.('[data-form-field]');\n\n    if (formField) {\n      this.negative = formField.hasAttribute('negative');\n    }\n\n    if (this._didLoad) {\n      this._componentSetup();\n    }\n    this._syncNegative();\n\n    this.addEventListener(\n      'optionSelectionChange',\n      (e: CustomEvent<void>) => this._onOptionSelected(e),\n      { signal },\n    );\n    this.addEventListener('click', (e: MouseEvent) => this._onOptionClick(e), { signal });\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('origin')) {\n      this._resetOriginClickListener(this.origin, changedProperties.get('origin'));\n    }\n    if (changedProperties.has('trigger')) {\n      this._resetTriggerClickListener(this.trigger, changedProperties.get('trigger'));\n    }\n    if (changedProperties.has('negative')) {\n      this._syncNegative();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    this._componentSetup();\n    this._didLoad = true;\n  }\n\n  private _syncNegative(): void {\n    this.querySelectorAll?.('sbb-divider').forEach((divider) => (divider.negative = this.negative));\n\n    this.querySelectorAll?.<SbbOptionElement | SbbOptGroupElement>(\n      'sbb-option, sbb-optgroup',\n    ).forEach((element) => element.toggleAttribute('data-negative', this.negative));\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._triggerEventsController?.abort();\n    this._openPanelEventsController?.abort();\n  }\n\n  private _componentSetup(): void {\n    if (isServer) {\n      return;\n    }\n    this._triggerEventsController?.abort();\n    this._openPanelEventsController?.abort();\n\n    this._originElement = undefined;\n    this.toggleAttribute(\n      'data-option-panel-origin-borderless',\n      !!this.closest?.('sbb-form-field')?.hasAttribute('borderless'),\n    );\n\n    this._bindTo(this._getTriggerElement());\n  }\n\n  /**\n   * Retrieve the element where the autocomplete will be attached.\n   * @returns 'origin' or the first 'sbb-form-field' ancestor.\n   */\n  private _findOriginElement(): HTMLElement {\n    let result: HTMLElement | undefined | null;\n\n    if (!this.origin) {\n      result = this.closest?.('sbb-form-field')?.shadowRoot?.querySelector?.('#overlay-anchor');\n    } else {\n      result = findReferencedElement(this.origin);\n    }\n\n    if (!result) {\n      throw new Error(\n        'Cannot find the origin element. Please specify a valid element or read the \"origin\" prop documentation',\n      );\n    }\n\n    return result;\n  }\n\n  /**\n   * Retrieve the element that will trigger the autocomplete opening.\n   * @returns 'trigger' or the first 'input' inside the origin element.\n   */\n  private _getTriggerElement(): HTMLInputElement {\n    if (!this.trigger) {\n      return this.closest?.('sbb-form-field')?.querySelector('input') as HTMLInputElement;\n    }\n\n    const result = findReferencedElement<HTMLInputElement>(this.trigger);\n\n    if (!result) {\n      throw new Error(\n        'Cannot find the trigger element. Please specify a valid element or read the \"trigger\" prop documentation',\n      );\n    }\n\n    return result;\n  }\n\n  private _bindTo(triggerElem: HTMLInputElement): void {\n    if (!triggerElem) {\n      return;\n    }\n\n    // Reset attributes to the old trigger and add them to the new one\n    this._removeTriggerAttributes(this.triggerElement);\n    this._setTriggerAttributes(triggerElem);\n\n    this._triggerElement = triggerElem;\n\n    this._setupTriggerEvents();\n  }\n\n  private _setupTriggerEvents(): void {\n    this._triggerEventsController = new AbortController();\n\n    // Open the overlay on focus, click, input and `ArrowDown` event\n    this.triggerElement?.addEventListener('focus', () => this.open(), {\n      signal: this._triggerEventsController.signal,\n    });\n    this.triggerElement?.addEventListener('click', () => this.open(), {\n      signal: this._triggerEventsController.signal,\n    });\n    this.triggerElement?.addEventListener(\n      'input',\n      (event) => {\n        this.open();\n        this._highlightOptions((event.target as HTMLInputElement).value);\n      },\n      { signal: this._triggerEventsController.signal },\n    );\n    this.triggerElement?.addEventListener(\n      'keydown',\n      (event: KeyboardEvent) => this._closedPanelKeyboardInteraction(event),\n      { signal: this._triggerEventsController.signal },\n    );\n  }\n\n  // Set overlay position, width and max height\n  private _setOverlayPosition(): void {\n    setOverlayPosition(\n      this._overlay,\n      this.originElement,\n      this._optionContainer,\n      this.shadowRoot!.querySelector('.sbb-autocomplete__container')!,\n      this,\n    );\n  }\n\n  /** On open/close animation end.\n   *  In rare cases it can be that the animationEnd event is triggered twice.\n   *  To avoid entering a corrupt state, exit when state is not expected.\n   */\n  private _onAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open' && this.state === 'opening') {\n      this._onOpenAnimationEnd();\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._onCloseAnimationEnd();\n    }\n  }\n\n  private _onOpenAnimationEnd(): void {\n    this.state = 'opened';\n    this._attachOpenPanelEvents();\n    this.triggerElement?.setAttribute('aria-expanded', 'true');\n    this.didOpen.emit();\n  }\n\n  private _onCloseAnimationEnd(): void {\n    this.state = 'closed';\n    this.triggerElement?.setAttribute('aria-expanded', 'false');\n    this._resetActiveElement();\n    this._optionContainer.scrollTop = 0;\n    this.didClose.emit();\n  }\n\n  private _attachOpenPanelEvents(): void {\n    this._openPanelEventsController = new AbortController();\n\n    // Recalculate the overlay position on scroll and window resize\n    document.addEventListener('scroll', () => this._setOverlayPosition(), {\n      passive: true,\n      signal: this._openPanelEventsController.signal,\n    });\n    window.addEventListener('resize', () => this._setOverlayPosition(), {\n      passive: true,\n      signal: this._openPanelEventsController.signal,\n    });\n\n    // Close autocomplete on backdrop click\n    window.addEventListener('pointerdown', (ev) => this._pointerDownListener(ev), {\n      signal: this._openPanelEventsController.signal,\n    });\n    window.addEventListener('pointerup', (ev) => this._closeOnBackdropClick(ev), {\n      signal: this._openPanelEventsController.signal,\n    });\n\n    // Keyboard interactions\n    this.triggerElement?.addEventListener(\n      'keydown',\n      (event: KeyboardEvent) => this._openedPanelKeyboardInteraction(event),\n      {\n        signal: this._openPanelEventsController.signal,\n      },\n    );\n  }\n\n  // Check if the pointerdown event target is triggered on the menu.\n  private _pointerDownListener = (event: PointerEvent): void => {\n    this._isPointerDownEventOnMenu = isEventOnElement(this._overlay, event);\n  };\n\n  // If the click is outside the autocomplete, closes the panel.\n  private _closeOnBackdropClick = (event: PointerEvent): void => {\n    if (\n      !this._isPointerDownEventOnMenu &&\n      !isEventOnElement(this._overlay, event) &&\n      !isEventOnElement(this.originElement, event)\n    ) {\n      this.close();\n    }\n  };\n\n  private _closedPanelKeyboardInteraction(event: KeyboardEvent): void {\n    if (this.state !== 'closed') {\n      return;\n    }\n\n    switch (event.key) {\n      case 'Enter':\n      case 'ArrowDown':\n      case 'ArrowUp':\n        this.open();\n        break;\n    }\n  }\n\n  private _openedPanelKeyboardInteraction(event: KeyboardEvent): void {\n    if (this.state !== 'opened') {\n      return;\n    }\n\n    switch (event.key) {\n      case 'Escape':\n      case 'Tab':\n        this.close();\n        break;\n\n      case 'Enter':\n        this._selectByKeyboard();\n        break;\n\n      case 'ArrowDown':\n      case 'ArrowUp':\n        this._setNextActiveOption(event);\n        break;\n    }\n  }\n\n  private _selectByKeyboard(): void {\n    const activeOption = this._options[this._activeItemIndex];\n\n    if (activeOption) {\n      activeOption.setSelectedViaUserInteraction(true);\n    }\n  }\n\n  private _setNextActiveOption(event: KeyboardEvent): void {\n    const filteredOptions = this._options.filter(\n      (opt) => !opt.disabled && !opt.hasAttribute('data-group-disabled'),\n    );\n\n    // Get and activate the next active option\n    const next = getNextElementIndex(event, this._activeItemIndex, filteredOptions.length);\n    const nextActiveOption = filteredOptions[next];\n    nextActiveOption.active = true;\n    this.triggerElement?.setAttribute('aria-activedescendant', nextActiveOption.id);\n    nextActiveOption.scrollIntoView({ block: 'nearest' });\n\n    // Reset the previous active option\n    const lastActiveOption = filteredOptions[this._activeItemIndex];\n    if (lastActiveOption) {\n      lastActiveOption.active = false;\n    }\n\n    this._activeItemIndex = next;\n  }\n\n  private _resetActiveElement(): void {\n    const activeElement = this._options[this._activeItemIndex];\n\n    if (activeElement) {\n      activeElement.active = false;\n    }\n    this._activeItemIndex = -1;\n    this.triggerElement?.removeAttribute('aria-activedescendant');\n  }\n\n  /** Highlight the searched text on the options. */\n  private _highlightOptions(searchTerm?: string): void {\n    if (!searchTerm) {\n      return;\n    }\n    this._options.forEach((option) => option.highlight(searchTerm));\n  }\n\n  private _setTriggerAttributes(element: HTMLInputElement): void {\n    setAriaComboBoxAttributes(element, this.id || this._overlayId, false);\n  }\n\n  private _removeTriggerAttributes(element?: HTMLInputElement): void {\n    removeAriaComboBoxAttributes(element);\n  }\n\n  private _handleSlotchange(): void {\n    this._highlightOptions(this.triggerElement?.value);\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-autocomplete__gap-fix\"></div>\n      <div class=\"sbb-autocomplete__container\">\n        <div class=\"sbb-autocomplete__gap-fix\">${overlayGapFixCorners()}</div>\n        <div\n          @animationend=${this._onAnimationEnd}\n          class=\"sbb-autocomplete__panel\"\n          ${ref((overlayRef?: Element) => (this._overlay = overlayRef as HTMLElement))}\n        >\n          <div class=\"sbb-autocomplete__wrapper\">\n            <div\n              class=\"sbb-autocomplete__options\"\n              role=${!ariaRoleOnHost ? 'listbox' : nothing}\n              id=${!ariaRoleOnHost ? this._overlayId : nothing}\n              ${ref((containerRef) => (this._optionContainer = containerRef as HTMLElement))}\n            >\n              <slot @slotchange=${this._handleSlotchange}></slot>\n            </div>\n          </div>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-autocomplete': SbbAutocompleteElement;\n  }\n}\n"],"names":[],"mappings":"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"}
750
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"autocomplete.js","sources":["../../../src/elements/autocomplete/autocomplete-base-element.ts","../../../src/elements/autocomplete/autocomplete.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { SbbOpenCloseBaseElement } from '../core/base-elements.js';\nimport { SbbConnectedAbortController } from '../core/controllers.js';\nimport { findReferencedElement, isSafari } from '../core/dom.js';\nimport { SbbNegativeMixin, SbbHydrationMixin } from '../core/mixins.js';\nimport {\n  isEventOnElement,\n  overlayGapFixCorners,\n  removeAriaComboBoxAttributes,\n  setOverlayPosition,\n} from '../core/overlay.js';\nimport type { SbbOptionBaseElement } from '../option.js';\n\nimport style from './autocomplete-base-element.scss?lit&inline';\n\n/**\n * On Safari, the aria role 'listbox' must be on the host element, or else VoiceOver won't work at all.\n * On the other hand, JAWS and NVDA need the role to be \"closer\" to the options, or else optgroups won't work.\n */\nconst ariaRoleOnHost = isSafari;\n\nexport abstract class SbbAutocompleteBaseElement extends SbbNegativeMixin(\n  SbbHydrationMixin(SbbOpenCloseBaseElement),\n) {\n  public static override styles: CSSResultGroup = style;\n\n  /**\n   * The element where the autocomplete will attach; accepts both an element's id or an HTMLElement.\n   * If not set, it will search for the first 'sbb-form-field' ancestor.\n   */\n  @property() public origin?: string | HTMLElement;\n\n  /**\n   * The input element that will trigger the autocomplete opening; accepts both an element's id or an HTMLElement.\n   * By default, the autocomplete will open on focus, click, input or `ArrowDown` keypress of the 'trigger' element.\n   * If not set, will search for the first 'input' child of a 'sbb-form-field' ancestor.\n   */\n  @property() public trigger?: string | HTMLInputElement;\n\n  /** Whether the icon space is preserved when no icon is set. */\n  @property({ attribute: 'preserve-icon-space', reflect: true, type: Boolean })\n  public preserveIconSpace?: boolean;\n\n  /** Returns the element where autocomplete overlay is attached to. */\n  public get originElement(): HTMLElement {\n    if (!this._originElement) {\n      this._originElement = this._findOriginElement();\n    }\n    return this._originElement;\n  }\n  private _originElement?: HTMLElement;\n\n  /** Returns the trigger element. */\n  public get triggerElement(): HTMLInputElement | undefined {\n    return this._triggerElement;\n  }\n  private _triggerElement: HTMLInputElement | undefined;\n\n  protected abstract overlayId: string;\n  protected abstract panelRole: string;\n  protected abort = new SbbConnectedAbortController(this);\n  private _overlay!: HTMLElement;\n  private _optionContainer!: HTMLElement;\n  private _triggerEventsController!: AbortController;\n  private _openPanelEventsController!: AbortController;\n  private _didLoad = false;\n  private _isPointerDownEventOnMenu: boolean = false;\n\n  protected abstract get options(): SbbOptionBaseElement[];\n  protected abstract syncNegative(): void;\n  protected abstract setTriggerAttributes(element: HTMLInputElement): void;\n  protected abstract openedPanelKeyboardInteraction(event: KeyboardEvent): void;\n  protected abstract selectByKeyboard(event: KeyboardEvent): void;\n  protected abstract setNextActiveOption(event: KeyboardEvent): void;\n  protected abstract resetActiveElement(): void;\n  protected abstract onOptionClick(event: MouseEvent): void;\n\n  /** Opens the autocomplete. */\n  public open(): void {\n    if (this.state !== 'closed' || !this._overlay || this.options.length === 0 || this._readonly) {\n      return;\n    }\n    if (!this.willOpen.emit()) {\n      return;\n    }\n\n    this.state = 'opening';\n    this._setOverlayPosition();\n  }\n\n  /** Closes the autocomplete. */\n  public close(): void {\n    if (this.state !== 'opened') {\n      return;\n    }\n    if (!this.willClose.emit()) {\n      return;\n    }\n\n    this.state = 'closing';\n    this._openPanelEventsController.abort();\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    if (ariaRoleOnHost) {\n      this.id ||= this.overlayId;\n    }\n    const signal = this.abort.signal;\n    const formField = this.closest('sbb-form-field') ?? this.closest('[data-form-field]');\n\n    if (formField) {\n      this.negative = formField.hasAttribute('negative');\n    }\n\n    if (this._didLoad) {\n      this._componentSetup();\n    }\n    this.syncNegative();\n\n    this.addEventListener('click', (e: MouseEvent) => this.onOptionClick(e), { signal });\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('origin')) {\n      this._resetOriginClickListener(this.origin, changedProperties.get('origin'));\n    }\n    if (changedProperties.has('trigger')) {\n      this._resetTriggerClickListener(this.trigger, changedProperties.get('trigger'));\n    }\n    if (changedProperties.has('negative')) {\n      this.syncNegative();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._componentSetup();\n    this._didLoad = true;\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._triggerEventsController?.abort();\n    this._openPanelEventsController?.abort();\n  }\n\n  /** When an option is selected, update the input value and close the autocomplete. */\n  protected onOptionSelected(event: CustomEvent): void {\n    const target = event.target as SbbOptionBaseElement;\n    if (!target.selected) {\n      return;\n    }\n\n    // Deselect the previous options\n    this.options\n      .filter((option) => option.id !== target.id && option.selected)\n      .forEach((option) => (option.selected = false));\n\n    if (this.triggerElement) {\n      // Set the option value\n      this.triggerElement.value = target.value as string;\n\n      // Manually trigger the change events\n      this.triggerElement.dispatchEvent(new Event('change', { bubbles: true }));\n      this.triggerElement.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n    }\n\n    this.close();\n  }\n\n  private _handleSlotchange(): void {\n    this._highlightOptions(this.triggerElement?.value);\n  }\n\n  /** The autocomplete should inherit 'readonly' state from the trigger. */\n  private get _readonly(): boolean {\n    return this.triggerElement?.hasAttribute('readonly') ?? false;\n  }\n\n  /** Removes trigger click listener on trigger change. */\n  private _resetOriginClickListener(\n    newValue?: string | HTMLElement,\n    oldValue?: string | HTMLElement,\n  ): void {\n    if (newValue !== oldValue) {\n      this._componentSetup();\n    }\n  }\n\n  /** Removes trigger click listener on trigger change. */\n  private _resetTriggerClickListener(\n    newValue?: string | HTMLElement,\n    oldValue?: string | HTMLElement,\n  ): void {\n    if (newValue !== oldValue) {\n      this._componentSetup();\n    }\n  }\n\n  private _componentSetup(): void {\n    if (isServer) {\n      return;\n    }\n    this._triggerEventsController?.abort();\n    this._openPanelEventsController?.abort();\n\n    this._originElement = undefined;\n    this.toggleAttribute(\n      'data-option-panel-origin-borderless',\n      !!this.closest?.('sbb-form-field')?.hasAttribute('borderless'),\n    );\n\n    this._bindTo(this._getTriggerElement());\n  }\n\n  /**\n   * Retrieve the element where the autocomplete will be attached.\n   * @returns 'origin' or the first 'sbb-form-field' ancestor.\n   */\n  private _findOriginElement(): HTMLElement {\n    let result: HTMLElement | undefined | null;\n\n    if (!this.origin) {\n      result = this.closest?.('sbb-form-field')?.shadowRoot?.querySelector?.('#overlay-anchor');\n    } else {\n      result = findReferencedElement(this.origin);\n    }\n\n    if (!result) {\n      throw new Error(\n        'Cannot find the origin element. Please specify a valid element or read the \"origin\" prop documentation',\n      );\n    }\n\n    return result;\n  }\n\n  /**\n   * Retrieve the element that will trigger the autocomplete opening.\n   * @returns 'trigger' or the first 'input' inside the origin element.\n   */\n  private _getTriggerElement(): HTMLInputElement {\n    if (!this.trigger) {\n      return this.closest?.('sbb-form-field')?.querySelector('input') as HTMLInputElement;\n    }\n\n    const result = findReferencedElement<HTMLInputElement>(this.trigger);\n\n    if (!result) {\n      throw new Error(\n        'Cannot find the trigger element. Please specify a valid element or read the \"trigger\" prop documentation',\n      );\n    }\n\n    return result;\n  }\n\n  private _bindTo(triggerElem: HTMLInputElement): void {\n    if (!triggerElem) {\n      return;\n    }\n\n    // Reset attributes to the old trigger and add them to the new one\n    this._removeTriggerAttributes(this.triggerElement);\n    this.setTriggerAttributes(triggerElem);\n\n    this._triggerElement = triggerElem;\n\n    this._setupTriggerEvents();\n  }\n\n  private _setupTriggerEvents(): void {\n    this._triggerEventsController = new AbortController();\n\n    // Open the overlay on focus, click, input and `ArrowDown` event\n    this.triggerElement?.addEventListener('focus', () => this.open(), {\n      signal: this._triggerEventsController.signal,\n    });\n    this.triggerElement?.addEventListener('click', () => this.open(), {\n      signal: this._triggerEventsController.signal,\n    });\n    this.triggerElement?.addEventListener(\n      'input',\n      (event) => {\n        this.open();\n        this._highlightOptions((event.target as HTMLInputElement).value);\n      },\n      { signal: this._triggerEventsController.signal },\n    );\n    this.triggerElement?.addEventListener(\n      'keydown',\n      (event: KeyboardEvent) => this._closedPanelKeyboardInteraction(event),\n      { signal: this._triggerEventsController.signal },\n    );\n  }\n\n  // Set overlay position, width and max height\n  private _setOverlayPosition(): void {\n    setOverlayPosition(\n      this._overlay,\n      this.originElement,\n      this._optionContainer,\n      this.shadowRoot!.querySelector('.sbb-autocomplete__container')!,\n      this,\n    );\n  }\n\n  /** On open/close animation end.\n   *  In rare cases it can be that the animationEnd event is triggered twice.\n   *  To avoid entering a corrupt state, exit when state is not expected.\n   */\n  private _onAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open' && this.state === 'opening') {\n      this._onOpenAnimationEnd();\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._onCloseAnimationEnd();\n    }\n  }\n\n  private _onOpenAnimationEnd(): void {\n    this.state = 'opened';\n    this._attachOpenPanelEvents();\n    this.triggerElement?.setAttribute('aria-expanded', 'true');\n    this.didOpen.emit();\n  }\n\n  private _onCloseAnimationEnd(): void {\n    this.state = 'closed';\n    this.triggerElement?.setAttribute('aria-expanded', 'false');\n    this.resetActiveElement();\n    this._optionContainer.scrollTop = 0;\n    this.didClose.emit();\n  }\n\n  private _attachOpenPanelEvents(): void {\n    this._openPanelEventsController = new AbortController();\n\n    // Recalculate the overlay position on scroll and window resize\n    document.addEventListener('scroll', () => this._setOverlayPosition(), {\n      passive: true,\n      signal: this._openPanelEventsController.signal,\n    });\n    window.addEventListener('resize', () => this._setOverlayPosition(), {\n      passive: true,\n      signal: this._openPanelEventsController.signal,\n    });\n\n    // Close autocomplete on backdrop click\n    window.addEventListener('pointerdown', (ev) => this._pointerDownListener(ev), {\n      signal: this._openPanelEventsController.signal,\n    });\n    window.addEventListener('pointerup', (ev) => this._closeOnBackdropClick(ev), {\n      signal: this._openPanelEventsController.signal,\n    });\n\n    // Keyboard interactions\n    this.triggerElement?.addEventListener(\n      'keydown',\n      (event: KeyboardEvent) => this.openedPanelKeyboardInteraction(event),\n      {\n        signal: this._openPanelEventsController.signal,\n      },\n    );\n  }\n\n  // Check if the pointerdown event target is triggered on the menu.\n  private _pointerDownListener = (event: PointerEvent): void => {\n    this._isPointerDownEventOnMenu = isEventOnElement(this._overlay, event);\n  };\n\n  // If the click is outside the autocomplete, closes the panel.\n  private _closeOnBackdropClick = (event: PointerEvent): void => {\n    if (\n      !this._isPointerDownEventOnMenu &&\n      !isEventOnElement(this._overlay, event) &&\n      !isEventOnElement(this.originElement, event)\n    ) {\n      this.close();\n    }\n  };\n\n  private _closedPanelKeyboardInteraction(event: KeyboardEvent): void {\n    if (this.state !== 'closed') {\n      return;\n    }\n\n    switch (event.key) {\n      case 'Enter':\n      case 'ArrowDown':\n      case 'ArrowUp':\n        this.open();\n        break;\n    }\n  }\n\n  /** Highlight the searched text on the options. */\n  private _highlightOptions(searchTerm?: string): void {\n    if (searchTerm === null || searchTerm === undefined) {\n      return;\n    }\n    this.options.forEach((option) => option.highlight(searchTerm));\n  }\n\n  private _removeTriggerAttributes(element?: HTMLInputElement): void {\n    removeAriaComboBoxAttributes(element);\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-autocomplete__gap-fix\"></div>\n      <div class=\"sbb-autocomplete__container\">\n        <div class=\"sbb-autocomplete__gap-fix\">${overlayGapFixCorners()}</div>\n        <div\n          @animationend=${this._onAnimationEnd}\n          class=\"sbb-autocomplete__panel\"\n          ?data-open=${this.state === 'opened' || this.state === 'opening'}\n          ${ref((overlayRef?: Element) => (this._overlay = overlayRef as HTMLElement))}\n        >\n          <div class=\"sbb-autocomplete__wrapper\">\n            <div\n              class=\"sbb-autocomplete__options\"\n              role=${!ariaRoleOnHost ? this.panelRole : nothing}\n              id=${!ariaRoleOnHost ? this.overlayId : nothing}\n              ${ref((containerRef) => (this._optionContainer = containerRef as HTMLElement))}\n            >\n              <slot @slotchange=${this._handleSlotchange}></slot>\n            </div>\n          </div>\n        </div>\n      </div>\n    `;\n  }\n}\n","import { customElement } from 'lit/decorators.js';\n\nimport { getNextElementIndex } from '../core/a11y.js';\nimport { hostAttributes } from '../core/decorators.js';\nimport { getDocumentWritingMode, isSafari } from '../core/dom.js';\nimport { setAriaComboBoxAttributes } from '../core/overlay.js';\nimport type { SbbOptGroupElement, SbbOptionElement } from '../option.js';\n\nimport { SbbAutocompleteBaseElement } from './autocomplete-base-element.js';\n\nlet nextId = 0;\n\n/**\n * On Safari, the aria role 'listbox' must be on the host element, or else VoiceOver won't work at all.\n * On the other hand, JAWS and NVDA need the role to be \"closer\" to the options, or else optgroups won't work.\n */\nconst ariaRoleOnHost = isSafari;\n\n/**\n * Combined with a native input, it displays a panel with a list of available options.\n *\n * @slot - Use the unnamed slot to add `sbb-option` or `sbb-optgroup` elements to the `sbb-autocomplete`.\n * @event {CustomEvent<void>} willOpen - Emits whenever the `sbb-autocomplete` starts the opening transition. Can be canceled.\n * @event {CustomEvent<void>} didOpen - Emits whenever the `sbb-autocomplete` is opened.\n * @event {CustomEvent<void>} willClose - Emits whenever the `sbb-autocomplete` begins the closing transition. Can be canceled.\n * @event {CustomEvent<void>} didClose - Emits whenever the `sbb-autocomplete` is closed.\n * @cssprop [--sbb-autocomplete-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,\n * the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the\n * component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.\n */\n@customElement('sbb-autocomplete')\n@hostAttributes({\n  dir: getDocumentWritingMode(),\n  role: ariaRoleOnHost ? 'listbox' : null,\n})\nexport class SbbAutocompleteElement extends SbbAutocompleteBaseElement {\n  protected overlayId = `sbb-autocomplete-${++nextId}`;\n  protected panelRole = 'listbox';\n  private _activeItemIndex = -1;\n\n  protected get options(): SbbOptionElement[] {\n    return Array.from(this.querySelectorAll?.('sbb-option') ?? []);\n  }\n\n  protected onOptionClick(event: MouseEvent): void {\n    if (\n      (event.target as Element).localName !== 'sbb-option' ||\n      (event.target as SbbOptionElement).disabled\n    ) {\n      return;\n    }\n    this.close();\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this.abort.signal;\n    this.addEventListener(\n      'optionSelectionChange',\n      (e: CustomEvent<void>) => this.onOptionSelected(e),\n      { signal },\n    );\n  }\n\n  protected syncNegative(): void {\n    this.querySelectorAll?.('sbb-divider').forEach((divider) => (divider.negative = this.negative));\n\n    this.querySelectorAll?.<SbbOptionElement | SbbOptGroupElement>(\n      'sbb-option, sbb-optgroup',\n    ).forEach((element) => element.toggleAttribute('data-negative', this.negative));\n  }\n\n  protected openedPanelKeyboardInteraction(event: KeyboardEvent): void {\n    if (this.state !== 'opened') {\n      return;\n    }\n\n    switch (event.key) {\n      case 'Escape':\n      case 'Tab':\n        this.close();\n        break;\n\n      case 'Enter':\n        this.selectByKeyboard();\n        break;\n\n      case 'ArrowDown':\n      case 'ArrowUp':\n        this.setNextActiveOption(event);\n        break;\n    }\n  }\n\n  protected selectByKeyboard(): void {\n    const activeOption = this.options[this._activeItemIndex];\n\n    if (activeOption) {\n      activeOption.setSelectedViaUserInteraction(true);\n    }\n  }\n\n  protected setNextActiveOption(event: KeyboardEvent): void {\n    const filteredOptions = this.options.filter(\n      (opt) => !opt.disabled && !opt.hasAttribute('data-group-disabled'),\n    );\n\n    // Get and activate the next active option\n    const next = getNextElementIndex(event, this._activeItemIndex, filteredOptions.length);\n    const nextActiveOption = filteredOptions[next];\n    nextActiveOption.active = true;\n    this.triggerElement?.setAttribute('aria-activedescendant', nextActiveOption.id);\n    nextActiveOption.scrollIntoView({ block: 'nearest' });\n\n    // Reset the previous active option\n    const lastActiveOption = filteredOptions[this._activeItemIndex];\n    if (lastActiveOption) {\n      lastActiveOption.active = false;\n    }\n\n    this._activeItemIndex = next;\n  }\n\n  protected resetActiveElement(): void {\n    const activeElement = this.options[this._activeItemIndex];\n\n    if (activeElement) {\n      activeElement.active = false;\n    }\n    this._activeItemIndex = -1;\n    this.triggerElement?.removeAttribute('aria-activedescendant');\n  }\n\n  protected setTriggerAttributes(element: HTMLInputElement): void {\n    setAriaComboBoxAttributes(element, ariaRoleOnHost ? this.id : this.overlayId, false);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-autocomplete': SbbAutocompleteElement;\n  }\n}\n"],"names":["ariaRoleOnHost","__decorateClass"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"breadcrumb-group.d.ts","sourceRoot":"","sources":["../../../../../src/elements/breadcrumb/breadcrumb-group/breadcrumb-group.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAGnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAYb,OAAO,EAAyB,KAAK,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAEpF,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAI7D,OAAO,eAAe,CAAC;;AAIvB;;;;GAIG;AACH,qBAIa,yBAA0B,SAAQ,8BAGlC;IACX,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,mBAA4B,mBAAmB,WAAsB;IAIrE,OAAO,KAAK,MAAM,QAEjB;IACD,OAAO,KAAK,MAAM,GAEjB;IAED,OAAO,CAAC,eAAe,CAAoE;IAC3F,OAAO,CAAC,MAAM,CAAyC;IACvD,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,aAAa,CAAS;IAE9B,OAAO,CAAC,cAAc;IAiBN,iBAAiB,IAAI,IAAI;cAMtB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAM9D,oBAAoB,IAAI,IAAI;cAKzB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI;cAQ3E,OAAO,CAAC,iBAAiB,EAAE,cAAc,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI;IAa3F,2EAA2E;IAC3E,OAAO,CAAC,gBAAgB;IAaxB;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAS3B,OAAO,CAAC,UAAU;IAYlB;;;OAGG;IACH,OAAO,CAAC,kBAAkB;IAK1B,kGAAkG;IAClG,OAAO,CAAC,uBAAuB;IAW/B,OAAO,CAAC,gBAAgB;IA8BxB,OAAO,CAAC,eAAe;cAgBJ,MAAM,IAAI,cAAc;CAQ5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,sBAAsB,EAAE,yBAAyB,CAAC;KACnD;CACF"}
1
+ {"version":3,"file":"breadcrumb-group.d.ts","sourceRoot":"","sources":["../../../../../src/elements/breadcrumb/breadcrumb-group/breadcrumb-group.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAGnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAYb,OAAO,EAAyB,KAAK,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAEpF,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAI7D,OAAO,eAAe,CAAC;;AAIvB;;;;GAIG;AACH,qBAIa,yBAA0B,SAAQ,8BAGlC;IACX,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,mBAA4B,mBAAmB,WAAsB;IAIrE,OAAO,KAAK,MAAM,QAEjB;IACD,OAAO,KAAK,MAAM,GAEjB;IAED,OAAO,CAAC,eAAe,CAAoE;IAC3F,OAAO,CAAC,MAAM,CAAyC;IACvD,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,aAAa,CAAS;IAE9B,OAAO,CAAC,cAAc;IAiBN,iBAAiB,IAAI,IAAI;cAMtB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO9D,oBAAoB,IAAI,IAAI;cAKzB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI;cAQ3E,OAAO,CAAC,iBAAiB,EAAE,cAAc,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI;IAa3F,2EAA2E;IAC3E,OAAO,CAAC,gBAAgB;IAaxB;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAS3B,OAAO,CAAC,UAAU;IAYlB;;;OAGG;IACH,OAAO,CAAC,kBAAkB;IAK1B,kGAAkG;IAClG,OAAO,CAAC,uBAAuB;IAW/B,OAAO,CAAC,gBAAgB;IA8BxB,OAAO,CAAC,eAAe;cAgBJ,MAAM,IAAI,cAAc;CAQ5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,sBAAsB,EAAE,yBAAyB,CAAC;KACnD;CACF"}