@sbb-esta/lyne-elements 2.5.1 → 2.6.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 (226) hide show
  1. package/autocomplete/autocomplete-base-element.d.ts +19 -20
  2. package/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  3. package/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.d.ts.map +1 -1
  4. package/autocomplete-grid/autocomplete-grid-button.js +7 -7
  5. package/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.d.ts +2 -2
  6. package/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.d.ts.map +1 -1
  7. package/autocomplete.js +143 -134
  8. package/chip/chip/chip.d.ts +32 -0
  9. package/chip/chip/chip.d.ts.map +1 -0
  10. package/chip/chip-group/chip-group.d.ts +100 -0
  11. package/chip/chip-group/chip-group.d.ts.map +1 -0
  12. package/chip/chip-group.d.ts +2 -0
  13. package/chip/chip-group.d.ts.map +1 -0
  14. package/chip/chip-group.js +225 -0
  15. package/chip/chip.d.ts +2 -0
  16. package/chip/chip.d.ts.map +1 -0
  17. package/chip/chip.js +85 -0
  18. package/chip.d.ts +3 -0
  19. package/chip.d.ts.map +1 -0
  20. package/chip.js +2 -0
  21. package/clock/clock.d.ts.map +1 -1
  22. package/clock.js +1 -1
  23. package/core/controllers/id-observer-controller.d.ts +21 -0
  24. package/core/controllers/id-observer-controller.d.ts.map +1 -0
  25. package/core/controllers/media-matchers-controller.d.ts.map +1 -1
  26. package/core/controllers.d.ts +2 -1
  27. package/core/controllers.d.ts.map +1 -1
  28. package/core/controllers.js +135 -80
  29. package/core/datetime/native-date-adapter.d.ts.map +1 -1
  30. package/core/datetime.js +8 -3
  31. package/core/dom/find-referenced-element.d.ts +1 -0
  32. package/core/dom/find-referenced-element.d.ts.map +1 -1
  33. package/core/dom/input-element.d.ts +3 -1
  34. package/core/dom/input-element.d.ts.map +1 -1
  35. package/core/i18n/i18n.d.ts +3 -0
  36. package/core/i18n/i18n.d.ts.map +1 -1
  37. package/core/i18n.js +135 -117
  38. package/core/mixins/form-associated-input-mixin.d.ts.map +1 -1
  39. package/core/mixins.js +64 -59
  40. package/core/overlay/overlay-trigger-attributes.d.ts +1 -1
  41. package/core/overlay/overlay-trigger-attributes.d.ts.map +1 -1
  42. package/core/overlay/position.d.ts +1 -1
  43. package/core/overlay/position.d.ts.map +1 -1
  44. package/core/styles/core.scss +89 -24
  45. package/core/styles/image.scss +1 -1
  46. package/core/styles/mixins/table.scss +63 -26
  47. package/core/styles/table.scss +16 -0
  48. package/core/testing/scroll.d.ts +1 -0
  49. package/core/testing/scroll.d.ts.map +1 -1
  50. package/core/testing/wait-for-image-ready.d.ts.map +1 -1
  51. package/core/testing.js +8 -5
  52. package/core.css +90 -34
  53. package/custom-elements.json +1588 -650
  54. package/datepicker/datepicker/datepicker.d.ts +4 -4
  55. package/datepicker/datepicker/datepicker.d.ts.map +1 -1
  56. package/datepicker/datepicker-toggle/datepicker-toggle.d.ts +0 -3
  57. package/datepicker/datepicker-toggle/datepicker-toggle.d.ts.map +1 -1
  58. package/datepicker/datepicker-toggle.js +30 -34
  59. package/datepicker/datepicker.js +103 -105
  60. package/development/autocomplete/autocomplete-base-element.d.ts +19 -20
  61. package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  62. package/development/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.d.ts.map +1 -1
  63. package/development/autocomplete-grid/autocomplete-grid-button.js +3 -3
  64. package/development/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.d.ts +2 -2
  65. package/development/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.d.ts.map +1 -1
  66. package/development/autocomplete-grid/autocomplete-grid-optgroup.js +1 -1
  67. package/development/autocomplete.js +103 -79
  68. package/development/chip/chip/chip.d.ts +32 -0
  69. package/development/chip/chip/chip.d.ts.map +1 -0
  70. package/development/chip/chip-group/chip-group.d.ts +100 -0
  71. package/development/chip/chip-group/chip-group.d.ts.map +1 -0
  72. package/development/chip/chip-group.d.ts +2 -0
  73. package/development/chip/chip-group.d.ts.map +1 -0
  74. package/development/chip/chip-group.js +349 -0
  75. package/development/chip/chip.d.ts +2 -0
  76. package/development/chip/chip.d.ts.map +1 -0
  77. package/development/chip/chip.js +212 -0
  78. package/development/chip.d.ts +3 -0
  79. package/development/chip.d.ts.map +1 -0
  80. package/development/chip.js +3 -0
  81. package/development/clock/clock.d.ts.map +1 -1
  82. package/development/clock.js +5 -2
  83. package/development/core/controllers/id-observer-controller.d.ts +21 -0
  84. package/development/core/controllers/id-observer-controller.d.ts.map +1 -0
  85. package/development/core/controllers/media-matchers-controller.d.ts.map +1 -1
  86. package/development/core/controllers.d.ts +2 -1
  87. package/development/core/controllers.d.ts.map +1 -1
  88. package/development/core/controllers.js +116 -44
  89. package/development/core/datetime/native-date-adapter.d.ts.map +1 -1
  90. package/development/core/datetime.js +6 -2
  91. package/development/core/dom/find-referenced-element.d.ts +1 -0
  92. package/development/core/dom/find-referenced-element.d.ts.map +1 -1
  93. package/development/core/dom/input-element.d.ts +3 -1
  94. package/development/core/dom/input-element.d.ts.map +1 -1
  95. package/development/core/dom.js +1 -1
  96. package/development/core/i18n/i18n.d.ts +3 -0
  97. package/development/core/i18n/i18n.d.ts.map +1 -1
  98. package/development/core/i18n.js +23 -2
  99. package/development/core/mixins/form-associated-input-mixin.d.ts.map +1 -1
  100. package/development/core/mixins.js +12 -3
  101. package/development/core/overlay/overlay-trigger-attributes.d.ts +1 -1
  102. package/development/core/overlay/overlay-trigger-attributes.d.ts.map +1 -1
  103. package/development/core/overlay/position.d.ts +1 -1
  104. package/development/core/overlay/position.d.ts.map +1 -1
  105. package/development/core/overlay.js +1 -1
  106. package/development/core/testing/scroll.d.ts +1 -0
  107. package/development/core/testing/scroll.d.ts.map +1 -1
  108. package/development/core/testing/wait-for-image-ready.d.ts.map +1 -1
  109. package/development/core/testing.js +6 -2
  110. package/development/datepicker/datepicker/datepicker.d.ts +4 -4
  111. package/development/datepicker/datepicker/datepicker.d.ts.map +1 -1
  112. package/development/datepicker/datepicker-toggle/datepicker-toggle.d.ts +0 -3
  113. package/development/datepicker/datepicker-toggle/datepicker-toggle.d.ts.map +1 -1
  114. package/development/datepicker/datepicker-toggle.js +4 -12
  115. package/development/datepicker/datepicker.js +46 -43
  116. package/development/dialog/dialog-title/dialog-title.d.ts +0 -1
  117. package/development/dialog/dialog-title/dialog-title.d.ts.map +1 -1
  118. package/development/dialog/dialog-title.js +2 -5
  119. package/development/expansion-panel/expansion-panel/expansion-panel.d.ts +0 -2
  120. package/development/expansion-panel/expansion-panel/expansion-panel.d.ts.map +1 -1
  121. package/development/expansion-panel/expansion-panel.js +2 -7
  122. package/development/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -1
  123. package/development/flip-card/flip-card-details.js +3 -3
  124. package/development/form-field/form-field/form-field.d.ts.map +1 -1
  125. package/development/form-field/form-field.js +12 -145
  126. package/development/header/header/header.d.ts +6 -7
  127. package/development/header/header/header.d.ts.map +1 -1
  128. package/development/header/header.js +45 -34
  129. package/development/menu/menu/menu.d.ts +7 -8
  130. package/development/menu/menu/menu.d.ts.map +1 -1
  131. package/development/menu/menu.js +42 -41
  132. package/development/navigation/navigation/navigation.d.ts +7 -8
  133. package/development/navigation/navigation/navigation.d.ts.map +1 -1
  134. package/development/navigation/navigation-marker/navigation-marker.d.ts.map +1 -1
  135. package/development/navigation/navigation-marker.js +3 -3
  136. package/development/navigation/navigation-section/navigation-section.d.ts +8 -9
  137. package/development/navigation/navigation-section/navigation-section.d.ts.map +1 -1
  138. package/development/navigation/navigation-section.js +50 -47
  139. package/development/navigation/navigation.js +42 -40
  140. package/development/option/optgroup/optgroup-base-element.d.ts.map +1 -1
  141. package/development/option/optgroup/optgroup.d.ts +2 -2
  142. package/development/option/optgroup/optgroup.d.ts.map +1 -1
  143. package/development/option/optgroup.js +3 -3
  144. package/development/option/option/option-base-element.d.ts.map +1 -1
  145. package/development/option/option.js +3 -3
  146. package/development/paginator/paginator.js +12 -1
  147. package/development/popover/popover/popover.d.ts +8 -7
  148. package/development/popover/popover/popover.d.ts.map +1 -1
  149. package/development/popover/popover.js +28 -35
  150. package/development/select/select.d.ts +1 -1
  151. package/development/select/select.d.ts.map +1 -1
  152. package/development/select.js +15 -15
  153. package/development/selection-expansion-panel/selection-expansion-panel.d.ts +0 -2
  154. package/development/selection-expansion-panel/selection-expansion-panel.d.ts.map +1 -1
  155. package/development/selection-expansion-panel.js +2 -7
  156. package/development/sidebar/sidebar/sidebar.d.ts.map +1 -1
  157. package/development/sidebar/sidebar.js +3 -3
  158. package/development/stepper/step/step.d.ts +15 -1
  159. package/development/stepper/step/step.d.ts.map +1 -1
  160. package/development/stepper/step-label.js +2 -2
  161. package/development/stepper/step.js +23 -3
  162. package/development/stepper/stepper/stepper.d.ts +1 -0
  163. package/development/stepper/stepper/stepper.d.ts.map +1 -1
  164. package/development/stepper/stepper.js +5 -1
  165. package/development/table/table-wrapper.js +2 -1
  166. package/development/time-input/time-input.d.ts +6 -8
  167. package/development/time-input/time-input.d.ts.map +1 -1
  168. package/development/time-input.js +42 -44
  169. package/dialog/dialog-title/dialog-title.d.ts +0 -1
  170. package/dialog/dialog-title/dialog-title.d.ts.map +1 -1
  171. package/dialog/dialog-title.js +18 -21
  172. package/expansion-panel/expansion-panel/expansion-panel.d.ts +0 -2
  173. package/expansion-panel/expansion-panel/expansion-panel.d.ts.map +1 -1
  174. package/expansion-panel/expansion-panel.js +53 -56
  175. package/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -1
  176. package/flip-card/flip-card-details.js +8 -8
  177. package/form-field/form-field/form-field.d.ts.map +1 -1
  178. package/form-field/form-field.js +102 -97
  179. package/header/header/header.d.ts +6 -7
  180. package/header/header/header.d.ts.map +1 -1
  181. package/header/header.js +72 -70
  182. package/index.d.ts +4 -0
  183. package/index.js +4 -0
  184. package/menu/menu/menu.d.ts +7 -8
  185. package/menu/menu/menu.d.ts.map +1 -1
  186. package/menu/menu.js +73 -73
  187. package/navigation/navigation/navigation.d.ts +7 -8
  188. package/navigation/navigation/navigation.d.ts.map +1 -1
  189. package/navigation/navigation-marker/navigation-marker.d.ts.map +1 -1
  190. package/navigation/navigation-marker.js +4 -4
  191. package/navigation/navigation-section/navigation-section.d.ts +8 -9
  192. package/navigation/navigation-section/navigation-section.d.ts.map +1 -1
  193. package/navigation/navigation-section.js +75 -77
  194. package/navigation/navigation.js +70 -70
  195. package/option/optgroup/optgroup-base-element.d.ts.map +1 -1
  196. package/option/optgroup/optgroup.d.ts +2 -2
  197. package/option/optgroup/optgroup.d.ts.map +1 -1
  198. package/option/optgroup.js +13 -13
  199. package/option/option/option-base-element.d.ts.map +1 -1
  200. package/option/option.js +2 -2
  201. package/package.json +16 -1
  202. package/paginator/paginator.js +44 -44
  203. package/popover/popover/popover.d.ts +8 -7
  204. package/popover/popover/popover.d.ts.map +1 -1
  205. package/popover/popover.js +73 -73
  206. package/select/select.d.ts +1 -1
  207. package/select/select.d.ts.map +1 -1
  208. package/select.js +68 -67
  209. package/selection-expansion-panel/selection-expansion-panel.d.ts +0 -2
  210. package/selection-expansion-panel/selection-expansion-panel.d.ts.map +1 -1
  211. package/selection-expansion-panel.js +10 -13
  212. package/sidebar/sidebar/sidebar.d.ts.map +1 -1
  213. package/sidebar/sidebar.js +2 -2
  214. package/standard-theme.css +166 -79
  215. package/stepper/step/step.d.ts +15 -1
  216. package/stepper/step/step.d.ts.map +1 -1
  217. package/stepper/step-label.js +1 -1
  218. package/stepper/step.js +36 -22
  219. package/stepper/stepper/stepper.d.ts +1 -0
  220. package/stepper/stepper/stepper.d.ts.map +1 -1
  221. package/stepper/stepper.js +19 -16
  222. package/table/table-wrapper.js +4 -4
  223. package/table.css +75 -44
  224. package/time-input/time-input.d.ts +6 -8
  225. package/time-input/time-input.d.ts.map +1 -1
  226. package/time-input.js +66 -73
@@ -9,12 +9,13 @@ import { __runInitializers, __esDecorate } from "tslib";
9
9
  import { property, customElement } from "lit/decorators.js";
10
10
  import { getNextElementIndex } from "./core/a11y.js";
11
11
  import { hostAttributes, forceType } from "./core/decorators.js";
12
- import { isZeroAnimationDuration, findReferencedElement, isSafari } from "./core/dom.js";
13
- import { isEventOnElement, setOverlayPosition, removeAriaComboBoxAttributes, overlayGapFixCorners, setAriaComboBoxAttributes } from "./core/overlay.js";
12
+ import { isZeroAnimationDuration, isSafari } from "./core/dom.js";
13
+ import { isEventOnElement, removeAriaComboBoxAttributes, setOverlayPosition, overlayGapFixCorners, setAriaComboBoxAttributes } from "./core/overlay.js";
14
+ import { ResizeController } from "@lit-labs/observers/resize-controller.js";
14
15
  import { css, isServer, nothing, html } from "lit";
15
16
  import { ref } from "lit/directives/ref.js";
16
17
  import { SbbOpenCloseBaseElement } from "./core/base-elements.js";
17
- import { SbbConnectedAbortController, SbbEscapableOverlayController } from "./core/controllers.js";
18
+ import { SbbConnectedAbortController, SbbIdReferenceController, SbbEscapableOverlayController } from "./core/controllers.js";
18
19
  import { SbbNegativeMixin, SbbHydrationMixin } from "./core/mixins.js";
19
20
  const style = css`*,
20
21
  ::before,
@@ -293,6 +294,7 @@ const style = css`*,
293
294
  }
294
295
  }`;
295
296
  const ariaRoleOnHost$1 = isSafari;
297
+ const inputAutocompleteEvent = "inputAutocomplete";
296
298
  let SbbAutocompleteBaseElement = (() => {
297
299
  var _origin_accessor_storage, _trigger_accessor_storage, _preserveIconSpace_accessor_storage, _a;
298
300
  let _classDecorators = [hostAttributes({
@@ -320,10 +322,27 @@ let SbbAutocompleteBaseElement = (() => {
320
322
  __privateSet(this, _origin_accessor_storage, __runInitializers(this, _origin_initializers, null));
321
323
  __privateSet(this, _trigger_accessor_storage, (__runInitializers(this, _origin_extraInitializers), __runInitializers(this, _trigger_initializers, null)));
322
324
  __privateSet(this, _preserveIconSpace_accessor_storage, (__runInitializers(this, _trigger_extraInitializers), __runInitializers(this, _preserveIconSpace_initializers, false)));
323
- this._originElement = __runInitializers(this, _preserveIconSpace_extraInitializers);
325
+ this._triggerElement = __runInitializers(this, _preserveIconSpace_extraInitializers);
324
326
  this.abort = new SbbConnectedAbortController(this);
327
+ this._originResizeObserver = new ResizeController(this, {
328
+ target: null,
329
+ skipInitial: true,
330
+ callback: () => {
331
+ if (this.state === "opened") {
332
+ this._setOverlayPosition();
333
+ }
334
+ }
335
+ });
336
+ this._triggerAttributeObserver = !isServer ? new MutationObserver((mutations) => {
337
+ const input = mutations[0].target;
338
+ if (input.hasAttribute("disabled") || input.hasAttribute("readonly")) {
339
+ this.close();
340
+ }
341
+ }) : null;
342
+ this._triggerIdReferenceController = new SbbIdReferenceController(this, "trigger");
343
+ this._originIdReferenceController = new SbbIdReferenceController(this, "origin");
325
344
  this._isPointerDownEventOnMenu = false;
326
- this._sbbEscapableOverlayController = new SbbEscapableOverlayController(this);
345
+ this._escapableOverlayController = new SbbEscapableOverlayController(this);
327
346
  this._pointerDownListener = (event) => {
328
347
  this._isPointerDownEventOnMenu = isEventOnElement(this._overlay, event);
329
348
  };
@@ -335,7 +354,9 @@ let SbbAutocompleteBaseElement = (() => {
335
354
  }
336
355
  /**
337
356
  * The element where the autocomplete will attach; accepts both an element's id or an HTMLElement.
338
- * If not set, it will search for the first 'sbb-form-field' ancestor.
357
+ * If not set, as fallback there are two elements which can act as origin with following priority order:
358
+ * 1. `sbb-form-field` if it is an ancestor.
359
+ * 2. trigger element if set.
339
360
  */
340
361
  get origin() {
341
362
  return __privateGet(this, _origin_accessor_storage);
@@ -363,14 +384,13 @@ let SbbAutocompleteBaseElement = (() => {
363
384
  }
364
385
  /** Returns the element where autocomplete overlay is attached to. */
365
386
  get originElement() {
366
- if (!this._originElement) {
367
- this._originElement = this._findOriginElement();
368
- }
369
- return this._originElement;
387
+ var _a2, _b, _c, _d;
388
+ return this.origin instanceof HTMLElement ? this.origin : this._originIdReferenceController.find() ?? ((_d = (_c = (_b = (_a2 = this.closest) == null ? void 0 : _a2.call(this, "sbb-form-field")) == null ? void 0 : _b.shadowRoot) == null ? void 0 : _c.querySelector) == null ? void 0 : _d.call(_c, "#overlay-anchor")) ?? this.triggerElement ?? null;
370
389
  }
390
+ // TODO: Breaking change: remove undefined as return type.
371
391
  /** Returns the trigger element. */
372
392
  get triggerElement() {
373
- return this._triggerElement;
393
+ return this._triggerElement ?? null;
374
394
  }
375
395
  /** Opens the autocomplete. */
376
396
  open() {
@@ -384,7 +404,11 @@ let SbbAutocompleteBaseElement = (() => {
384
404
  (_a2 = this.showPopover) == null ? void 0 : _a2.call(this);
385
405
  this.state = "opening";
386
406
  (_b = this._triggerElement) == null ? void 0 : _b.toggleAttribute("data-expanded", true);
387
- this._setOverlayPosition();
407
+ const originElement = this.originElement;
408
+ if (!originElement) {
409
+ throw new Error('Cannot find the origin element. Please specify a valid element or check the usage of the "origin" property from the documentation');
410
+ }
411
+ this._setOverlayPosition(originElement);
388
412
  if (this._isZeroAnimationDuration()) {
389
413
  this._handleOpening();
390
414
  }
@@ -401,6 +425,9 @@ let SbbAutocompleteBaseElement = (() => {
401
425
  this.state = "closing";
402
426
  (_a2 = this._triggerElement) == null ? void 0 : _a2.toggleAttribute("data-expanded", false);
403
427
  this._openPanelEventsController.abort();
428
+ if (this.originElement) {
429
+ this._originResizeObserver.unobserve(this.originElement);
430
+ }
404
431
  if (this._isZeroAnimationDuration()) {
405
432
  this._handleClosing();
406
433
  }
@@ -424,9 +451,6 @@ let SbbAutocompleteBaseElement = (() => {
424
451
  }
425
452
  willUpdate(changedProperties) {
426
453
  super.willUpdate(changedProperties);
427
- if (changedProperties.has("origin") && this.origin !== changedProperties.get("origin") || changedProperties.has("trigger") && this.trigger !== changedProperties.get("trigger")) {
428
- this._componentSetup();
429
- }
430
454
  if (changedProperties.has("negative")) {
431
455
  this.syncNegative();
432
456
  }
@@ -438,9 +462,21 @@ let SbbAutocompleteBaseElement = (() => {
438
462
  disconnectedCallback() {
439
463
  var _a2, _b;
440
464
  super.disconnectedCallback();
441
- (_a2 = this._triggerEventsController) == null ? void 0 : _a2.abort();
465
+ this._triggerElement = null;
466
+ (_a2 = this._triggerAbortController) == null ? void 0 : _a2.abort();
442
467
  (_b = this._openPanelEventsController) == null ? void 0 : _b.abort();
443
468
  }
469
+ requestUpdate(name, oldValue, options) {
470
+ super.requestUpdate(name, oldValue, options);
471
+ if (isServer || !this.hasUpdated) {
472
+ return;
473
+ }
474
+ if (!name || name === "trigger") {
475
+ this._configureTrigger();
476
+ } else if ((!name || name === "origin") && this.isOpen) {
477
+ this._setOverlayPosition();
478
+ }
479
+ }
444
480
  /** When an option is selected, update the input value and close the autocomplete. */
445
481
  onOptionSelected(event) {
446
482
  const target = event.target;
@@ -453,6 +489,7 @@ let SbbAutocompleteBaseElement = (() => {
453
489
  setValue.call(this.triggerElement, target.value);
454
490
  this.triggerElement.dispatchEvent(new Event("change", { bubbles: true }));
455
491
  this.triggerElement.dispatchEvent(new InputEvent("input", { bubbles: true, composed: true }));
492
+ this.triggerElement.dispatchEvent(new Event(inputAutocompleteEvent));
456
493
  this.triggerElement.focus();
457
494
  }
458
495
  this.close();
@@ -480,75 +517,58 @@ let SbbAutocompleteBaseElement = (() => {
480
517
  return ((_a2 = this.triggerElement) == null ? void 0 : _a2.hasAttribute("readonly")) ?? false;
481
518
  }
482
519
  _componentSetup() {
483
- var _a2, _b, _c, _d;
520
+ var _a2, _b;
484
521
  if (isServer) {
485
522
  return;
486
523
  }
487
- (_a2 = this._triggerEventsController) == null ? void 0 : _a2.abort();
488
- (_b = this._openPanelEventsController) == null ? void 0 : _b.abort();
489
- this._originElement = void 0;
490
- this.toggleAttribute("data-option-panel-origin-borderless", !!((_d = (_c = this.closest) == null ? void 0 : _c.call(this, "sbb-form-field")) == null ? void 0 : _d.hasAttribute("borderless")));
491
- this._bindTo(this._getTriggerElement());
524
+ this.toggleAttribute("data-option-panel-origin-borderless", !!((_b = (_a2 = this.closest) == null ? void 0 : _a2.call(this, "sbb-form-field")) == null ? void 0 : _b.hasAttribute("borderless")));
525
+ this._configureTrigger();
492
526
  }
493
- /**
494
- * Retrieve the element where the autocomplete will be attached.
495
- * @returns 'origin' or the first 'sbb-form-field' ancestor.
496
- */
497
- _findOriginElement() {
527
+ _configureTrigger() {
498
528
  var _a2, _b, _c, _d;
499
- let result;
500
- if (!this.origin) {
501
- result = (_d = (_c = (_b = (_a2 = this.closest) == null ? void 0 : _a2.call(this, "sbb-form-field")) == null ? void 0 : _b.shadowRoot) == null ? void 0 : _c.querySelector) == null ? void 0 : _d.call(_c, "#overlay-anchor");
502
- } else {
503
- result = findReferencedElement(this.origin);
504
- }
505
- if (!result) {
506
- throw new Error('Cannot find the origin element. Please specify a valid element or read the "origin" prop documentation');
507
- }
508
- return result;
509
- }
510
- /**
511
- * Retrieve the element that will trigger the autocomplete opening.
512
- * @returns 'trigger' or the first 'input' inside the origin element.
513
- */
514
- _getTriggerElement() {
515
- var _a2, _b;
516
- if (!this.trigger) {
517
- return (_b = (_a2 = this.closest) == null ? void 0 : _a2.call(this, "sbb-form-field")) == null ? void 0 : _b.querySelector("input");
518
- }
519
- const result = findReferencedElement(this.trigger);
520
- if (!result) {
521
- throw new Error('Cannot find the trigger element. Please specify a valid element or read the "trigger" prop documentation');
529
+ const triggerElement = this.trigger instanceof HTMLElement ? this.trigger : this.trigger ? this._triggerIdReferenceController.find() : (_b = (_a2 = this.closest) == null ? void 0 : _a2.call(this, "sbb-form-field")) == null ? void 0 : _b.querySelector("input");
530
+ if (triggerElement === this._triggerElement) {
531
+ return;
522
532
  }
523
- return result;
524
- }
525
- _bindTo(triggerElem) {
526
- if (!triggerElem) {
533
+ (_c = this._triggerAbortController) == null ? void 0 : _c.abort();
534
+ removeAriaComboBoxAttributes(this.triggerElement);
535
+ this._triggerElement = triggerElement;
536
+ if (!this.triggerElement) {
527
537
  return;
528
538
  }
529
- this._removeTriggerAttributes(this.triggerElement);
530
- this.setTriggerAttributes(triggerElem);
531
- this._triggerElement = triggerElem;
532
- this._setupTriggerEvents();
533
- }
534
- _setupTriggerEvents() {
535
- var _a2, _b, _c, _d;
536
- this._triggerEventsController = new AbortController();
537
- (_a2 = this.triggerElement) == null ? void 0 : _a2.addEventListener("focus", () => this.open(), {
538
- signal: this._triggerEventsController.signal
539
+ const originElement = this.originElement;
540
+ if (this.triggerElement === originElement && this.isOpen) {
541
+ this._setOverlayPosition(originElement);
542
+ }
543
+ (_d = this._triggerAttributeObserver) == null ? void 0 : _d.observe(this._triggerElement, {
544
+ attributes: true,
545
+ attributeFilter: ["disabled", "readonly"]
539
546
  });
540
- (_b = this.triggerElement) == null ? void 0 : _b.addEventListener("click", () => this.open(), {
541
- signal: this._triggerEventsController.signal
547
+ this.setTriggerAttributes(this.triggerElement);
548
+ this._triggerAbortController = new AbortController();
549
+ this.triggerElement.addEventListener("focus", () => this.open(), {
550
+ signal: this._triggerAbortController.signal
542
551
  });
543
- (_c = this.triggerElement) == null ? void 0 : _c.addEventListener("input", (event) => {
552
+ this.triggerElement.addEventListener("click", () => this.open(), {
553
+ signal: this._triggerAbortController.signal
554
+ });
555
+ this.triggerElement.addEventListener("input", (event) => {
544
556
  this.open();
545
557
  this._highlightOptions(event.target.value);
546
- }, { signal: this._triggerEventsController.signal });
547
- (_d = this.triggerElement) == null ? void 0 : _d.addEventListener("keydown", (event) => this._closedPanelKeyboardInteraction(event), { signal: this._triggerEventsController.signal });
558
+ }, { signal: this._triggerAbortController.signal });
559
+ this.triggerElement.addEventListener("keydown", (event) => this._closedPanelKeyboardInteraction(event), {
560
+ signal: this._triggerAbortController.signal,
561
+ // We need key event to run before any other subscription to guarantee a correct
562
+ // interaction with other components (necessary for the 'sbb-chip-group' use case).
563
+ capture: true
564
+ });
548
565
  }
549
566
  // Set overlay position, width and max height
550
- _setOverlayPosition() {
551
- setOverlayPosition(this._overlay, this.originElement, this._optionContainer, this.shadowRoot.querySelector(".sbb-autocomplete__container"), this);
567
+ _setOverlayPosition(originElement = this.originElement) {
568
+ if (!originElement) {
569
+ return;
570
+ }
571
+ setOverlayPosition(this._overlay, originElement, this._optionContainer, this.shadowRoot.querySelector(".sbb-autocomplete__container"), this);
552
572
  }
553
573
  /**
554
574
  * On open/close animation end.
@@ -566,8 +586,11 @@ let SbbAutocompleteBaseElement = (() => {
566
586
  var _a2;
567
587
  this.state = "opened";
568
588
  this._attachOpenPanelEvents();
589
+ if (this.originElement) {
590
+ this._originResizeObserver.observe(this.originElement);
591
+ }
569
592
  (_a2 = this.triggerElement) == null ? void 0 : _a2.setAttribute("aria-expanded", "true");
570
- this._sbbEscapableOverlayController.connect();
593
+ this._escapableOverlayController.connect();
571
594
  this.didOpen.emit();
572
595
  }
573
596
  _handleClosing() {
@@ -577,7 +600,7 @@ let SbbAutocompleteBaseElement = (() => {
577
600
  (_b = this.triggerElement) == null ? void 0 : _b.setAttribute("aria-expanded", "false");
578
601
  this.resetActiveElement();
579
602
  this._optionContainer.scrollTop = 0;
580
- this._sbbEscapableOverlayController.disconnect();
603
+ this._escapableOverlayController.disconnect();
581
604
  this.didClose.emit();
582
605
  }
583
606
  _attachOpenPanelEvents() {
@@ -601,7 +624,10 @@ let SbbAutocompleteBaseElement = (() => {
601
624
  signal: this._openPanelEventsController.signal
602
625
  });
603
626
  (_a2 = this.triggerElement) == null ? void 0 : _a2.addEventListener("keydown", (event) => this.openedPanelKeyboardInteraction(event), {
604
- signal: this._openPanelEventsController.signal
627
+ signal: this._openPanelEventsController.signal,
628
+ // We need key event to run before any other subscription to guarantee a correct
629
+ // interaction with other components (necessary for the 'sbb-chip-group' use case).
630
+ capture: true
605
631
  });
606
632
  }
607
633
  _closedPanelKeyboardInteraction(event) {
@@ -623,9 +649,6 @@ let SbbAutocompleteBaseElement = (() => {
623
649
  }
624
650
  this.options.forEach((option) => option.highlight(searchTerm));
625
651
  }
626
- _removeTriggerAttributes(element) {
627
- removeAriaComboBoxAttributes(element);
628
- }
629
652
  render() {
630
653
  return html`
631
654
  <div class="sbb-autocomplete__gap-fix"></div>
@@ -761,6 +784,7 @@ let SbbAutocompleteElement = (() => {
761
784
  })();
762
785
  export {
763
786
  SbbAutocompleteBaseElement,
764
- SbbAutocompleteElement
787
+ SbbAutocompleteElement,
788
+ inputAutocompleteEvent
765
789
  };
766
- //# 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, SbbEscapableOverlayController } from '../core/controllers.js';\nimport { forceType, hostAttributes } from '../core/decorators.js';\nimport { findReferencedElement, isSafari, isZeroAnimationDuration } from '../core/dom.js';\nimport { SbbHydrationMixin, SbbNegativeMixin } 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\n@hostAttributes({\n  popover: 'manual',\n})\nabstract 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 accessor origin: string | HTMLElement | null = null;\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 accessor trigger: string | HTMLInputElement | null = null;\n\n  /** Whether the icon space is preserved when no icon is set. */\n  @forceType()\n  @property({ attribute: 'preserve-icon-space', reflect: true, type: Boolean })\n  public accessor preserveIconSpace: boolean = false;\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  /** @deprecated No longer used internally. */\n  protected abort = new SbbConnectedAbortController(this);\n  private _overlay!: HTMLElement;\n  private _optionContainer!: HTMLElement;\n  private _triggerEventsController!: AbortController;\n  private _openPanelEventsController!: AbortController;\n  private _isPointerDownEventOnMenu: boolean = false;\n  private _sbbEscapableOverlayController = new SbbEscapableOverlayController(this);\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\n  /** Opens the autocomplete. */\n  public open(): void {\n    if (\n      this.state !== 'closed' ||\n      !this._overlay ||\n      this.options.length === 0 ||\n      this._readonly()\n    ) {\n      return;\n    }\n    if (!this.willOpen.emit()) {\n      return;\n    }\n\n    this.showPopover?.();\n    this.state = 'opening';\n    this._triggerElement?.toggleAttribute('data-expanded', true);\n    this._setOverlayPosition();\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `opened` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleOpening();\n    }\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._triggerElement?.toggleAttribute('data-expanded', false);\n    this._openPanelEventsController.abort();\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `closed` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleClosing();\n    }\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-options-panel-animation-duration');\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    if (ariaRoleOnHost) {\n      this.id ||= this.overlayId;\n    }\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.hasUpdated) {\n      this._componentSetup();\n    }\n    this.syncNegative();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (\n      (changedProperties.has('origin') && this.origin !== changedProperties.get('origin')) ||\n      (changedProperties.has('trigger') && this.trigger !== changedProperties.get('trigger'))\n    ) {\n      this._componentSetup();\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  }\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      // In order to support React onChange event, we have to get the setter and call it.\n      // https://github.com/facebook/react/issues/11600#issuecomment-345813130\n      const setValue = Object.getOwnPropertyDescriptor(HTMLInputElement.prototype, 'value')!.set!;\n      setValue.call(this.triggerElement, target.value);\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      this.triggerElement.focus();\n    }\n\n    this.close();\n  }\n\n  private _handleSlotchange(): void {\n    this._highlightOptions(this.triggerElement?.value);\n    this._openOnNewOptions();\n  }\n\n  /**\n   * If the 'input' is focused and there's a change in the number of options, open the autocomplete\n   */\n  private _openOnNewOptions(): void {\n    if (document?.activeElement === this.triggerElement) {\n      if (this.options.length > 0) {\n        this.open();\n      } else {\n        this.close();\n      }\n    }\n  }\n\n  /** The autocomplete should inherit 'readonly' state from the trigger. */\n  private _readonly(): boolean {\n    return this.triggerElement?.hasAttribute('readonly') ?? false;\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  /**\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._handleOpening();\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._handleClosing();\n    }\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n    this._attachOpenPanelEvents();\n    this.triggerElement?.setAttribute('aria-expanded', 'true');\n    this._sbbEscapableOverlayController.connect();\n    this.didOpen.emit();\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    this.hidePopover?.();\n    this.triggerElement?.setAttribute('aria-expanded', 'false');\n    this.resetActiveElement();\n    this._optionContainer.scrollTop = 0;\n    this._sbbEscapableOverlayController.disconnect();\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      // Without capture, other scroll contexts would not bubble to this event listener.\n      // Capture allows us to react to all scroll contexts in this DOM.\n      capture: true,\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 { 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 */\nexport\n@customElement('sbb-autocomplete')\n@hostAttributes({\n  role: ariaRoleOnHost ? 'listbox' : null,\n})\nclass 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  public constructor() {\n    super();\n    this.addEventListener?.('optionSelectionChange', (e: CustomEvent<void>) =>\n      this.onOptionSelected(e),\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 'Tab':\n        this.close();\n        break;\n\n      case 'Enter':\n        this.selectByKeyboard(event);\n        break;\n\n      case 'ArrowDown':\n      case 'ArrowUp':\n        this.setNextActiveOption(event);\n        break;\n    }\n  }\n\n  protected selectByKeyboard(event: KeyboardEvent): void {\n    event.preventDefault();\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.setActive(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.setActive(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.setActive(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","_a"],"mappings":"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"}
790
+ //# 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 { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  isServer,\n  nothing,\n  type PropertyDeclaration,\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 {\n  SbbConnectedAbortController,\n  SbbEscapableOverlayController,\n  SbbIdReferenceController,\n} from '../core/controllers.js';\nimport { forceType, hostAttributes } from '../core/decorators.js';\nimport { isSafari, isZeroAnimationDuration } from '../core/dom.js';\nimport { SbbHydrationMixin, SbbNegativeMixin } 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\n/**\n * Custom event emitted on the input when an option is selected\n */\nexport const inputAutocompleteEvent = 'inputAutocomplete';\n\nexport\n@hostAttributes({\n  popover: 'manual',\n})\nabstract 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, as fallback there are two elements which can act as origin with following priority order:\n   * 1. `sbb-form-field` if it is an ancestor.\n   * 2. trigger element if set.\n   */\n  @property() public accessor origin: string | HTMLElement | null = null;\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 accessor trigger: string | HTMLInputElement | null = null;\n\n  /** Whether the icon space is preserved when no icon is set. */\n  @forceType()\n  @property({ attribute: 'preserve-icon-space', reflect: true, type: Boolean })\n  public accessor preserveIconSpace: boolean = false;\n\n  /** Returns the element where autocomplete overlay is attached to. */\n  public get originElement(): HTMLElement | null {\n    return this.origin instanceof HTMLElement\n      ? this.origin\n      : (this._originIdReferenceController.find() ??\n          this.closest?.('sbb-form-field')?.shadowRoot?.querySelector?.('#overlay-anchor') ??\n          this.triggerElement ??\n          null);\n  }\n\n  // TODO: Breaking change: remove undefined as return type.\n  /** Returns the trigger element. */\n  public get triggerElement(): HTMLInputElement | null | undefined {\n    return this._triggerElement ?? null;\n  }\n  private _triggerElement: HTMLInputElement | null | undefined;\n\n  protected abstract overlayId: string;\n  protected abstract panelRole: string;\n  /** @deprecated No longer used internally. */\n  protected abort = new SbbConnectedAbortController(this);\n  private _originResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => {\n      if (this.state === 'opened') {\n        this._setOverlayPosition();\n      }\n    },\n  });\n  /** Listens to the changes on the `disabled` or `readonly` attribute of the trigger. */\n  private _triggerAttributeObserver = !isServer\n    ? new MutationObserver((mutations: MutationRecord[]): void => {\n        const input = mutations[0].target as HTMLInputElement;\n        if (input.hasAttribute('disabled') || input.hasAttribute('readonly')) {\n          this.close();\n        }\n      })\n    : null;\n  private _overlay!: HTMLElement;\n  private _optionContainer!: HTMLElement;\n  private _triggerAbortController!: AbortController;\n  private _triggerIdReferenceController = new SbbIdReferenceController(this, 'trigger');\n  private _originIdReferenceController = new SbbIdReferenceController(this, 'origin');\n  private _openPanelEventsController!: AbortController;\n  private _isPointerDownEventOnMenu: boolean = false;\n  private _escapableOverlayController = new SbbEscapableOverlayController(this);\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\n  /** Opens the autocomplete. */\n  public open(): void {\n    if (\n      this.state !== 'closed' ||\n      !this._overlay ||\n      this.options.length === 0 ||\n      this._readonly()\n    ) {\n      return;\n    }\n    if (!this.willOpen.emit()) {\n      return;\n    }\n\n    this.showPopover?.();\n    this.state = 'opening';\n    this._triggerElement?.toggleAttribute('data-expanded', true);\n    const originElement = this.originElement;\n    if (!originElement) {\n      throw new Error(\n        'Cannot find the origin element. Please specify a valid element or check the usage of the \"origin\" property from the documentation',\n      );\n    }\n    this._setOverlayPosition(originElement);\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `opened` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleOpening();\n    }\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._triggerElement?.toggleAttribute('data-expanded', false);\n    this._openPanelEventsController.abort();\n    if (this.originElement) {\n      this._originResizeObserver.unobserve(this.originElement);\n    }\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `closed` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleClosing();\n    }\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-options-panel-animation-duration');\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    if (ariaRoleOnHost) {\n      this.id ||= this.overlayId;\n    }\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.hasUpdated) {\n      this._componentSetup();\n    }\n    this.syncNegative();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\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  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._triggerElement = null;\n    this._triggerAbortController?.abort();\n    this._openPanelEventsController?.abort();\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n\n    if (isServer || !this.hasUpdated) {\n      return;\n    }\n    if (!name || name === 'trigger') {\n      this._configureTrigger();\n    } else if ((!name || name === 'origin') && this.isOpen) {\n      this._setOverlayPosition();\n    }\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      // In order to support React onChange event, we have to get the setter and call it.\n      // https://github.com/facebook/react/issues/11600#issuecomment-345813130\n      const setValue = Object.getOwnPropertyDescriptor(HTMLInputElement.prototype, 'value')!.set!;\n      setValue.call(this.triggerElement, target.value);\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      // Custom input event emitted when input value changes after an option is selected\n      this.triggerElement.dispatchEvent(new Event(inputAutocompleteEvent));\n      this.triggerElement.focus();\n    }\n\n    this.close();\n  }\n\n  private _handleSlotchange(): void {\n    this._highlightOptions(this.triggerElement?.value);\n    this._openOnNewOptions();\n  }\n\n  /**\n   * If the 'input' is focused and there's a change in the number of options, open the autocomplete\n   */\n  private _openOnNewOptions(): void {\n    if (document?.activeElement === this.triggerElement) {\n      if (this.options.length > 0) {\n        this.open();\n      } else {\n        this.close();\n      }\n    }\n  }\n\n  /** The autocomplete should inherit 'readonly' state from the trigger. */\n  private _readonly(): boolean {\n    return this.triggerElement?.hasAttribute('readonly') ?? false;\n  }\n\n  private _componentSetup(): void {\n    if (isServer) {\n      return;\n    }\n\n    this.toggleAttribute(\n      'data-option-panel-origin-borderless',\n      !!this.closest?.('sbb-form-field')?.hasAttribute('borderless'),\n    );\n\n    this._configureTrigger();\n  }\n\n  private _configureTrigger(): void {\n    const triggerElement = (\n      this.trigger instanceof HTMLElement\n        ? this.trigger\n        : this.trigger\n          ? this._triggerIdReferenceController.find()\n          : this.closest?.('sbb-form-field')?.querySelector('input')\n    ) as HTMLInputElement | null;\n\n    if (triggerElement === this._triggerElement) {\n      return;\n    }\n\n    this._triggerAbortController?.abort();\n    removeAriaComboBoxAttributes(this.triggerElement);\n    this._triggerElement = triggerElement;\n\n    if (!this.triggerElement) {\n      return;\n    }\n\n    // As the trigger can be the fallback of the origin, we eventually have to update the position.\n    const originElement = this.originElement;\n    if (this.triggerElement === originElement && this.isOpen) {\n      this._setOverlayPosition(originElement);\n    }\n\n    this._triggerAttributeObserver?.observe(this._triggerElement!, {\n      attributes: true,\n      attributeFilter: ['disabled', 'readonly'],\n    });\n\n    this.setTriggerAttributes(this.triggerElement);\n    this._triggerAbortController = new AbortController();\n\n    // Open the overlay on focus, click, input and `ArrowDown` event\n    this.triggerElement.addEventListener('focus', () => this.open(), {\n      signal: this._triggerAbortController.signal,\n    });\n    this.triggerElement.addEventListener('click', () => this.open(), {\n      signal: this._triggerAbortController.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._triggerAbortController.signal },\n    );\n    this.triggerElement.addEventListener(\n      'keydown',\n      (event: KeyboardEvent) => this._closedPanelKeyboardInteraction(event),\n      {\n        signal: this._triggerAbortController.signal,\n        // We need key event to run before any other subscription to guarantee a correct\n        // interaction with other components (necessary for the 'sbb-chip-group' use case).\n        capture: true,\n      },\n    );\n  }\n\n  // Set overlay position, width and max height\n  private _setOverlayPosition(originElement = this.originElement): void {\n    // An undefined originElement should only occur in the unlikely event\n    // that the autocomplete loses its originElement and triggerElement during an open state.\n    if (!originElement) {\n      return;\n    }\n    setOverlayPosition(\n      this._overlay,\n      originElement,\n      this._optionContainer,\n      this.shadowRoot!.querySelector('.sbb-autocomplete__container')!,\n      this,\n    );\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._handleOpening();\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._handleClosing();\n    }\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n    this._attachOpenPanelEvents();\n    if (this.originElement) {\n      this._originResizeObserver.observe(this.originElement);\n    }\n    this.triggerElement?.setAttribute('aria-expanded', 'true');\n    this._escapableOverlayController.connect();\n    this.didOpen.emit();\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    this.hidePopover?.();\n    this.triggerElement?.setAttribute('aria-expanded', 'false');\n    this.resetActiveElement();\n    this._optionContainer.scrollTop = 0;\n    this._escapableOverlayController.disconnect();\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      // Without capture, other scroll contexts would not bubble to this event listener.\n      // Capture allows us to react to all scroll contexts in this DOM.\n      capture: true,\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        // We need key event to run before any other subscription to guarantee a correct\n        // interaction with other components (necessary for the 'sbb-chip-group' use case).\n        capture: true,\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  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 { 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 */\nexport\n@customElement('sbb-autocomplete')\n@hostAttributes({\n  role: ariaRoleOnHost ? 'listbox' : null,\n})\nclass 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  public constructor() {\n    super();\n    this.addEventListener?.('optionSelectionChange', (e: CustomEvent<void>) =>\n      this.onOptionSelected(e),\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 'Tab':\n        this.close();\n        break;\n\n      case 'Enter':\n        this.selectByKeyboard(event);\n        break;\n\n      case 'ArrowDown':\n      case 'ArrowUp':\n        this.setNextActiveOption(event);\n        break;\n    }\n  }\n\n  protected selectByKeyboard(event: KeyboardEvent): void {\n    event.preventDefault();\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.setActive(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.setActive(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.setActive(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","_a"],"mappings":"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"}
@@ -0,0 +1,32 @@
1
+ import { CSSResultGroup, LitElement, PropertyValues, TemplateResult } from 'lit';
2
+ declare const SbbChipElement_base: import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbNegativeMixinType> & import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbDisabledMixinType> & typeof LitElement;
3
+ /**
4
+ * It displays a chip. Usually used in combination with `sbb-chip-group`.
5
+ *
6
+ * @slot - Use the unnamed slot to add the display value. If not provided, the 'value' will be used.
7
+ */
8
+ export declare class SbbChipElement extends SbbChipElement_base {
9
+ static styles: CSSResultGroup;
10
+ static readonly events: {
11
+ readonly requestDelete: "requestDelete";
12
+ };
13
+ /** The value of chip. Will be used as label if nothing is slotted. */
14
+ accessor value: string;
15
+ /** Whether the component is readonly */
16
+ accessor readonly: boolean;
17
+ /** @internal */
18
+ private _requestDelete;
19
+ private _language;
20
+ constructor();
21
+ protected willUpdate(changedProperties: PropertyValues<this>): void;
22
+ protected firstUpdated(_changedProperties: PropertyValues): void;
23
+ private _deleteButton;
24
+ protected render(): TemplateResult;
25
+ }
26
+ declare global {
27
+ interface HTMLElementTagNameMap {
28
+ 'sbb-chip': SbbChipElement;
29
+ }
30
+ }
31
+ export {};
32
+ //# sourceMappingURL=chip.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chip.d.ts","sourceRoot":"","sources":["../../../../../src/elements/chip/chip/chip.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAEnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AASb,OAAO,6BAA6B,CAAC;AACrC,OAAO,6BAA6B,CAAC;;AAIrC;;;;GAIG;AACH,qBAEM,cAAe,SAAQ,mBAA8C;IACzE,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;MAElB;IAEX,sEAAsE;IACtE,SAAyC,KAAK,EAAE,MAAM,CAAM;IAE5D,wCAAwC;IACxC,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C,gBAAgB;IAChB,OAAO,CAAC,cAAc,CAAoE;IAE1F,OAAO,CAAC,SAAS,CAAmC;;cASjC,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAYzD,YAAY,CAAC,kBAAkB,EAAE,cAAc,GAAG,IAAI;IAQzE,OAAO,CAAC,aAAa;cAIF,MAAM,IAAI,cAAc;CAmB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,UAAU,EAAE,cAAc,CAAC;KAC5B;CACF"}