@sbb-esta/lyne-elements 2.9.0 → 2.10.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 (60) hide show
  1. package/autocomplete/autocomplete-base-element.d.ts +3 -1
  2. package/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  3. package/autocomplete/autocomplete-base-element.js +73 -63
  4. package/autocomplete/autocomplete.component.d.ts +1 -1
  5. package/autocomplete/autocomplete.component.d.ts.map +1 -1
  6. package/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts +1 -1
  7. package/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts.map +1 -1
  8. package/core/a11y/arrow-navigation.d.ts +2 -2
  9. package/core/a11y/arrow-navigation.d.ts.map +1 -1
  10. package/core/a11y/arrow-navigation.js +1 -1
  11. package/core/dom/platform.d.ts.map +1 -1
  12. package/core/dom/platform.js +1 -1
  13. package/custom-elements.json +95 -33
  14. package/development/autocomplete/autocomplete-base-element.d.ts +3 -1
  15. package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  16. package/development/autocomplete/autocomplete-base-element.js +26 -4
  17. package/development/autocomplete/autocomplete.component.d.ts +1 -1
  18. package/development/autocomplete/autocomplete.component.d.ts.map +1 -1
  19. package/development/autocomplete/autocomplete.component.js +1 -1
  20. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts +1 -1
  21. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts.map +1 -1
  22. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.js +1 -1
  23. package/development/core/a11y/arrow-navigation.d.ts +2 -2
  24. package/development/core/a11y/arrow-navigation.d.ts.map +1 -1
  25. package/development/core/a11y/arrow-navigation.js +4 -4
  26. package/development/core/dom/platform.d.ts.map +1 -1
  27. package/development/core/dom/platform.js +2 -2
  28. package/development/journey-header/journey-header.component.d.ts.map +1 -1
  29. package/development/journey-header/journey-header.component.js +6 -17
  30. package/development/select/select.component.js +2 -2
  31. package/development/skiplink-list/skiplink-list.component.d.ts.map +1 -1
  32. package/development/skiplink-list/skiplink-list.component.js +4 -3
  33. package/development/slider/slider.component.js +2 -2
  34. package/development/toast/toast.component.d.ts +5 -9
  35. package/development/toast/toast.component.d.ts.map +1 -1
  36. package/development/toast/toast.component.js +20 -34
  37. package/development/toggle/toggle/toggle.component.d.ts +1 -5
  38. package/development/toggle/toggle/toggle.component.d.ts.map +1 -1
  39. package/development/toggle/toggle/toggle.component.js +16 -22
  40. package/development/toggle/toggle-option/toggle-option.component.d.ts +1 -0
  41. package/development/toggle/toggle-option/toggle-option.component.d.ts.map +1 -1
  42. package/development/toggle/toggle-option/toggle-option.component.js +11 -7
  43. package/development/train/train-formation/train-formation.component.js +5 -1
  44. package/journey-header/journey-header.component.d.ts.map +1 -1
  45. package/journey-header/journey-header.component.js +37 -49
  46. package/package.json +1 -1
  47. package/select/select.component.js +1 -1
  48. package/skiplink-list/skiplink-list.component.d.ts.map +1 -1
  49. package/skiplink-list/skiplink-list.component.js +10 -10
  50. package/slider/slider.component.js +1 -1
  51. package/toast/toast.component.d.ts +5 -9
  52. package/toast/toast.component.d.ts.map +1 -1
  53. package/toast/toast.component.js +35 -50
  54. package/toggle/toggle/toggle.component.d.ts +1 -5
  55. package/toggle/toggle/toggle.component.d.ts.map +1 -1
  56. package/toggle/toggle/toggle.component.js +34 -37
  57. package/toggle/toggle-option/toggle-option.component.d.ts +1 -0
  58. package/toggle/toggle-option/toggle-option.component.d.ts.map +1 -1
  59. package/toggle/toggle-option/toggle-option.component.js +51 -47
  60. package/train/train-formation/train-formation.component.js +14 -14
@@ -2300,6 +2300,17 @@
2300
2300
  "attribute": "preserve-icon-space",
2301
2301
  "reflects": true
2302
2302
  },
2303
+ {
2304
+ "kind": "field",
2305
+ "name": "autoActiveFirstOption",
2306
+ "type": {
2307
+ "text": "boolean"
2308
+ },
2309
+ "privacy": "public",
2310
+ "default": "false",
2311
+ "description": "Whether the first option is automatically activated when the autocomplete is opened.",
2312
+ "attribute": "auto-active-first-option"
2313
+ },
2303
2314
  {
2304
2315
  "kind": "field",
2305
2316
  "name": "originElement",
@@ -2507,6 +2518,7 @@
2507
2518
  "parameters": [
2508
2519
  {
2509
2520
  "name": "event",
2521
+ "optional": true,
2510
2522
  "type": {
2511
2523
  "text": "KeyboardEvent"
2512
2524
  }
@@ -2940,6 +2952,15 @@
2940
2952
  "description": "Whether the icon space is preserved when no icon is set.",
2941
2953
  "fieldName": "preserveIconSpace"
2942
2954
  },
2955
+ {
2956
+ "name": "auto-active-first-option",
2957
+ "type": {
2958
+ "text": "boolean"
2959
+ },
2960
+ "default": "false",
2961
+ "description": "Whether the first option is automatically activated when the autocomplete is opened.",
2962
+ "fieldName": "autoActiveFirstOption"
2963
+ },
2943
2964
  {
2944
2965
  "name": "negative",
2945
2966
  "type": {
@@ -3163,6 +3184,7 @@
3163
3184
  "parameters": [
3164
3185
  {
3165
3186
  "name": "event",
3187
+ "optional": true,
3166
3188
  "type": {
3167
3189
  "text": "KeyboardEvent"
3168
3190
  }
@@ -3321,6 +3343,21 @@
3321
3343
  "module": "autocomplete/autocomplete-base-element.js"
3322
3344
  }
3323
3345
  },
3346
+ {
3347
+ "kind": "field",
3348
+ "name": "autoActiveFirstOption",
3349
+ "type": {
3350
+ "text": "boolean"
3351
+ },
3352
+ "privacy": "public",
3353
+ "default": "false",
3354
+ "description": "Whether the first option is automatically activated when the autocomplete is opened.",
3355
+ "attribute": "auto-active-first-option",
3356
+ "inheritedFrom": {
3357
+ "name": "SbbAutocompleteBaseElement",
3358
+ "module": "autocomplete/autocomplete-base-element.js"
3359
+ }
3360
+ },
3324
3361
  {
3325
3362
  "kind": "field",
3326
3363
  "name": "originElement",
@@ -3974,6 +4011,19 @@
3974
4011
  "name": "SbbAutocompleteBaseElement",
3975
4012
  "module": "autocomplete/autocomplete-base-element.js"
3976
4013
  }
4014
+ },
4015
+ {
4016
+ "name": "auto-active-first-option",
4017
+ "type": {
4018
+ "text": "boolean"
4019
+ },
4020
+ "default": "false",
4021
+ "description": "Whether the first option is automatically activated when the autocomplete is opened.",
4022
+ "fieldName": "autoActiveFirstOption",
4023
+ "inheritedFrom": {
4024
+ "name": "SbbAutocompleteBaseElement",
4025
+ "module": "autocomplete/autocomplete-base-element.js"
4026
+ }
3977
4027
  }
3978
4028
  ]
3979
4029
  }
@@ -13199,7 +13249,8 @@
13199
13249
  "privacy": "public",
13200
13250
  "default": "false",
13201
13251
  "description": "Whether the select is readonly.",
13202
- "attribute": "readonly"
13252
+ "attribute": "readonly",
13253
+ "reflects": true
13203
13254
  },
13204
13255
  {
13205
13256
  "kind": "field",
@@ -15812,7 +15863,8 @@
15812
15863
  "privacy": "public",
15813
15864
  "default": "false",
15814
15865
  "description": "Readonly state for the inner HTMLInputElement.\nSince the input range does not allow this attribute, it will be merged with the `disabled` one.",
15815
- "attribute": "readonly"
15866
+ "attribute": "readonly",
15867
+ "reflects": true
15816
15868
  },
15817
15869
  {
15818
15870
  "kind": "field",
@@ -18669,16 +18721,6 @@
18669
18721
  "privacy": "private",
18670
18722
  "default": "new SbbLanguageController(this)"
18671
18723
  },
18672
- {
18673
- "kind": "field",
18674
- "name": "_role",
18675
- "type": {
18676
- "text": "'status' | 'alert' | undefined"
18677
- },
18678
- "privacy": "private",
18679
- "description": "Role of the live region. This is only for Firefox as there is a known issue where Firefox +\nJAWS does not read out aria-live message.",
18680
- "readonly": true
18681
- },
18682
18724
  {
18683
18725
  "kind": "method",
18684
18726
  "name": "open",
@@ -18694,16 +18736,6 @@
18694
18736
  "module": "core/base-elements/open-close-base-element.js"
18695
18737
  }
18696
18738
  },
18697
- {
18698
- "kind": "method",
18699
- "name": "_isZeroAnimationDuration",
18700
- "privacy": "private",
18701
- "return": {
18702
- "type": {
18703
- "text": "boolean"
18704
- }
18705
- }
18706
- },
18707
18739
  {
18708
18740
  "kind": "method",
18709
18741
  "name": "close",
@@ -18757,6 +18789,16 @@
18757
18789
  }
18758
18790
  ]
18759
18791
  },
18792
+ {
18793
+ "kind": "method",
18794
+ "name": "_isZeroAnimationDuration",
18795
+ "privacy": "private",
18796
+ "return": {
18797
+ "type": {
18798
+ "text": "boolean"
18799
+ }
18800
+ }
18801
+ },
18760
18802
  {
18761
18803
  "kind": "method",
18762
18804
  "name": "_onContentSlotChange",
@@ -20994,6 +21036,7 @@
20994
21036
  "parameters": [
20995
21037
  {
20996
21038
  "name": "event",
21039
+ "optional": true,
20997
21040
  "type": {
20998
21041
  "text": "KeyboardEvent"
20999
21042
  }
@@ -21170,6 +21213,21 @@
21170
21213
  "module": "autocomplete/autocomplete-base-element.js"
21171
21214
  }
21172
21215
  },
21216
+ {
21217
+ "kind": "field",
21218
+ "name": "autoActiveFirstOption",
21219
+ "type": {
21220
+ "text": "boolean"
21221
+ },
21222
+ "privacy": "public",
21223
+ "default": "false",
21224
+ "description": "Whether the first option is automatically activated when the autocomplete is opened.",
21225
+ "attribute": "auto-active-first-option",
21226
+ "inheritedFrom": {
21227
+ "name": "SbbAutocompleteBaseElement",
21228
+ "module": "autocomplete/autocomplete-base-element.js"
21229
+ }
21230
+ },
21173
21231
  {
21174
21232
  "kind": "field",
21175
21233
  "name": "originElement",
@@ -21823,6 +21881,19 @@
21823
21881
  "name": "SbbAutocompleteBaseElement",
21824
21882
  "module": "autocomplete/autocomplete-base-element.js"
21825
21883
  }
21884
+ },
21885
+ {
21886
+ "name": "auto-active-first-option",
21887
+ "type": {
21888
+ "text": "boolean"
21889
+ },
21890
+ "default": "false",
21891
+ "description": "Whether the first option is automatically activated when the autocomplete is opened.",
21892
+ "fieldName": "autoActiveFirstOption",
21893
+ "inheritedFrom": {
21894
+ "name": "SbbAutocompleteBaseElement",
21895
+ "module": "autocomplete/autocomplete-base-element.js"
21896
+ }
21826
21897
  }
21827
21898
  ]
21828
21899
  }
@@ -37529,9 +37600,9 @@
37529
37600
  {
37530
37601
  "name": "event",
37531
37602
  "type": {
37532
- "text": "KeyboardEvent"
37603
+ "text": "KeyboardEvent | undefined"
37533
37604
  },
37534
- "description": "The keyboard event to check."
37605
+ "description": "The keyboard event to check. If null, will count as a 'next' step."
37535
37606
  },
37536
37607
  {
37537
37608
  "name": "current",
@@ -88219,15 +88290,6 @@
88219
88290
  "description": "The child instances of sbb-toggle-option as an array.",
88220
88291
  "readonly": true
88221
88292
  },
88222
- {
88223
- "kind": "field",
88224
- "name": "_loaded",
88225
- "type": {
88226
- "text": "boolean"
88227
- },
88228
- "privacy": "private",
88229
- "default": "false"
88230
- },
88231
88293
  {
88232
88294
  "kind": "field",
88233
88295
  "name": "_change",
@@ -24,6 +24,8 @@ export declare abstract class SbbAutocompleteBaseElement extends SbbAutocomplete
24
24
  accessor trigger: string | HTMLInputElement | null;
25
25
  /** Whether the icon space is preserved when no icon is set. */
26
26
  accessor preserveIconSpace: boolean;
27
+ /** Whether the first option is automatically activated when the autocomplete is opened. */
28
+ accessor autoActiveFirstOption: boolean;
27
29
  /** Returns the element where autocomplete overlay is attached to. */
28
30
  get originElement(): HTMLElement | null;
29
31
  /** Returns the trigger element. */
@@ -49,7 +51,7 @@ export declare abstract class SbbAutocompleteBaseElement extends SbbAutocomplete
49
51
  protected abstract setTriggerAttributes(element: HTMLInputElement): void;
50
52
  protected abstract openedPanelKeyboardInteraction(event: KeyboardEvent): void;
51
53
  protected abstract selectByKeyboard(event: KeyboardEvent): void;
52
- protected abstract setNextActiveOption(event: KeyboardEvent): void;
54
+ protected abstract setNextActiveOption(event?: KeyboardEvent): void;
53
55
  protected abstract resetActiveElement(): void;
54
56
  /** Opens the autocomplete. */
55
57
  open(): void;
@@ -1 +1 @@
1
- {"version":3,"file":"autocomplete-base-element.d.ts","sourceRoot":"","sources":["../../../../src/elements/autocomplete/autocomplete-base-element.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"autocomplete-base-element.d.ts","sourceRoot":"","sources":["../../../../src/elements/autocomplete/autocomplete-base-element.ts"],"names":[],"mappings":"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"}
@@ -295,7 +295,7 @@ const style = css`*,
295
295
  const ariaRoleOnHost = isSafari;
296
296
  const inputAutocompleteEvent = "inputAutocomplete";
297
297
  let SbbAutocompleteBaseElement = (() => {
298
- var _origin_accessor_storage, _trigger_accessor_storage, _preserveIconSpace_accessor_storage, _a;
298
+ var _origin_accessor_storage, _trigger_accessor_storage, _preserveIconSpace_accessor_storage, _autoActiveFirstOption_accessor_storage, _a;
299
299
  let _classDecorators = [hostAttributes({
300
300
  popover: "manual"
301
301
  })];
@@ -312,16 +312,21 @@ let SbbAutocompleteBaseElement = (() => {
312
312
  let _preserveIconSpace_decorators;
313
313
  let _preserveIconSpace_initializers = [];
314
314
  let _preserveIconSpace_extraInitializers = [];
315
+ let _autoActiveFirstOption_decorators;
316
+ let _autoActiveFirstOption_initializers = [];
317
+ let _autoActiveFirstOption_extraInitializers = [];
315
318
  _a = class extends _classSuper {
316
319
  constructor() {
317
320
  super(...arguments);
318
321
  __privateAdd(this, _origin_accessor_storage);
319
322
  __privateAdd(this, _trigger_accessor_storage);
320
323
  __privateAdd(this, _preserveIconSpace_accessor_storage);
324
+ __privateAdd(this, _autoActiveFirstOption_accessor_storage);
321
325
  __privateSet(this, _origin_accessor_storage, __runInitializers(this, _origin_initializers, null));
322
326
  __privateSet(this, _trigger_accessor_storage, (__runInitializers(this, _origin_extraInitializers), __runInitializers(this, _trigger_initializers, null)));
323
327
  __privateSet(this, _preserveIconSpace_accessor_storage, (__runInitializers(this, _trigger_extraInitializers), __runInitializers(this, _preserveIconSpace_initializers, false)));
324
- this._triggerElement = __runInitializers(this, _preserveIconSpace_extraInitializers);
328
+ __privateSet(this, _autoActiveFirstOption_accessor_storage, (__runInitializers(this, _preserveIconSpace_extraInitializers), __runInitializers(this, _autoActiveFirstOption_initializers, false)));
329
+ this._triggerElement = __runInitializers(this, _autoActiveFirstOption_extraInitializers);
325
330
  this.abort = new SbbConnectedAbortController(this);
326
331
  this._originResizeObserver = new ResizeController(this, {
327
332
  target: null,
@@ -381,6 +386,13 @@ let SbbAutocompleteBaseElement = (() => {
381
386
  set preserveIconSpace(value) {
382
387
  __privateSet(this, _preserveIconSpace_accessor_storage, value);
383
388
  }
389
+ /** Whether the first option is automatically activated when the autocomplete is opened. */
390
+ get autoActiveFirstOption() {
391
+ return __privateGet(this, _autoActiveFirstOption_accessor_storage);
392
+ }
393
+ set autoActiveFirstOption(value) {
394
+ __privateSet(this, _autoActiveFirstOption_accessor_storage, value);
395
+ }
384
396
  /** Returns the element where autocomplete overlay is attached to. */
385
397
  get originElement() {
386
398
  var _a2, _b, _c, _d;
@@ -408,6 +420,9 @@ let SbbAutocompleteBaseElement = (() => {
408
420
  throw new Error('Cannot find the origin element. Please specify a valid element or check the usage of the "origin" property from the documentation');
409
421
  }
410
422
  this._setOverlayPosition(originElement);
423
+ if (this.autoActiveFirstOption) {
424
+ this.setNextActiveOption();
425
+ }
411
426
  if (this._isZeroAnimationDuration()) {
412
427
  this._handleOpening();
413
428
  }
@@ -496,6 +511,9 @@ let SbbAutocompleteBaseElement = (() => {
496
511
  _handleSlotchange() {
497
512
  var _a2;
498
513
  this._highlightOptions((_a2 = this.triggerElement) == null ? void 0 : _a2.value);
514
+ if (this.isOpen) {
515
+ this._setOverlayPosition();
516
+ }
499
517
  this._openOnNewOptions();
500
518
  }
501
519
  /**
@@ -673,11 +691,12 @@ let SbbAutocompleteBaseElement = (() => {
673
691
  </div>
674
692
  `;
675
693
  }
676
- }, _origin_accessor_storage = new WeakMap(), _trigger_accessor_storage = new WeakMap(), _preserveIconSpace_accessor_storage = new WeakMap(), _classThis = _a, (() => {
694
+ }, _origin_accessor_storage = new WeakMap(), _trigger_accessor_storage = new WeakMap(), _preserveIconSpace_accessor_storage = new WeakMap(), _autoActiveFirstOption_accessor_storage = new WeakMap(), _classThis = _a, (() => {
677
695
  const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
678
696
  _origin_decorators = [property()];
679
697
  _trigger_decorators = [property()];
680
698
  _preserveIconSpace_decorators = [forceType(), property({ attribute: "preserve-icon-space", reflect: true, type: Boolean })];
699
+ _autoActiveFirstOption_decorators = [forceType(), property({ attribute: "auto-active-first-option", type: Boolean })];
681
700
  __esDecorate(_a, null, _origin_decorators, { kind: "accessor", name: "origin", static: false, private: false, access: { has: (obj) => "origin" in obj, get: (obj) => obj.origin, set: (obj, value) => {
682
701
  obj.origin = value;
683
702
  } }, metadata: _metadata }, _origin_initializers, _origin_extraInitializers);
@@ -687,6 +706,9 @@ let SbbAutocompleteBaseElement = (() => {
687
706
  __esDecorate(_a, null, _preserveIconSpace_decorators, { kind: "accessor", name: "preserveIconSpace", static: false, private: false, access: { has: (obj) => "preserveIconSpace" in obj, get: (obj) => obj.preserveIconSpace, set: (obj, value) => {
688
707
  obj.preserveIconSpace = value;
689
708
  } }, metadata: _metadata }, _preserveIconSpace_initializers, _preserveIconSpace_extraInitializers);
709
+ __esDecorate(_a, null, _autoActiveFirstOption_decorators, { kind: "accessor", name: "autoActiveFirstOption", static: false, private: false, access: { has: (obj) => "autoActiveFirstOption" in obj, get: (obj) => obj.autoActiveFirstOption, set: (obj, value) => {
710
+ obj.autoActiveFirstOption = value;
711
+ } }, metadata: _metadata }, _autoActiveFirstOption_initializers, _autoActiveFirstOption_extraInitializers);
690
712
  __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
691
713
  _classThis = _classDescriptor.value;
692
714
  if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
@@ -697,4 +719,4 @@ export {
697
719
  SbbAutocompleteBaseElement,
698
720
  inputAutocompleteEvent
699
721
  };
700
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"autocomplete-base-element.js","sources":["../../../../src/elements/autocomplete/autocomplete-base-element.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"],"names":["_a"],"mappings":"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"}
722
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"autocomplete-base-element.js","sources":["../../../../src/elements/autocomplete/autocomplete-base-element.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  /** Whether the first option is automatically activated when the autocomplete is opened. */\n  @forceType()\n  @property({ attribute: 'auto-active-first-option', type: Boolean })\n  public accessor autoActiveFirstOption: 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    if (this.autoActiveFirstOption) {\n      this.setNextActiveOption();\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 `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    /**\n     * It's possible to filter out options with an opened panel on input change.\n     * In this case, the panel's position must be recalculated considering the new option's list.\n     */\n    if (this.isOpen) {\n      this._setOverlayPosition();\n    }\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\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"],"names":["_a"],"mappings":"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"}
@@ -21,7 +21,7 @@ export declare class SbbAutocompleteElement extends SbbAutocompleteBaseElement {
21
21
  protected syncNegative(): void;
22
22
  protected openedPanelKeyboardInteraction(event: KeyboardEvent): void;
23
23
  protected selectByKeyboard(event: KeyboardEvent): void;
24
- protected setNextActiveOption(event: KeyboardEvent): void;
24
+ protected setNextActiveOption(event?: KeyboardEvent): void;
25
25
  protected resetActiveElement(): void;
26
26
  protected setTriggerAttributes(element: HTMLInputElement): void;
27
27
  }
@@ -1 +1 @@
1
- {"version":3,"file":"autocomplete.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/autocomplete/autocomplete.component.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAsB,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAEzE,OAAO,EAAE,0BAA0B,EAAE,MAAM,gCAAgC,CAAC;AAU5E;;;;;;;;;;;GAWG;AACH,qBAKM,sBAAuB,SAAQ,0BAA0B;IAC7D,SAAS,CAAC,SAAS,SAAkC;IACrD,SAAS,CAAC,SAAS,SAAa;IAChC,OAAO,CAAC,gBAAgB,CAAM;IAE9B,SAAS,KAAK,OAAO,IAAI,gBAAgB,EAAE,CAE1C;;IASD,SAAS,CAAC,YAAY,IAAI,IAAI;IAQ9B,SAAS,CAAC,8BAA8B,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAqBpE,SAAS,CAAC,gBAAgB,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAStD,SAAS,CAAC,mBAAmB,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAqBzD,SAAS,CAAC,kBAAkB,IAAI,IAAI;IAUpC,SAAS,CAAC,oBAAoB,CAAC,OAAO,EAAE,gBAAgB,GAAG,IAAI;CAGhE;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,kBAAkB,EAAE,sBAAsB,CAAC;KAC5C;CACF"}
1
+ {"version":3,"file":"autocomplete.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/autocomplete/autocomplete.component.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAsB,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAEzE,OAAO,EAAE,0BAA0B,EAAE,MAAM,gCAAgC,CAAC;AAU5E;;;;;;;;;;;GAWG;AACH,qBAKM,sBAAuB,SAAQ,0BAA0B;IAC7D,SAAS,CAAC,SAAS,SAAkC;IACrD,SAAS,CAAC,SAAS,SAAa;IAChC,OAAO,CAAC,gBAAgB,CAAM;IAE9B,SAAS,KAAK,OAAO,IAAI,gBAAgB,EAAE,CAE1C;;IASD,SAAS,CAAC,YAAY,IAAI,IAAI;IAQ9B,SAAS,CAAC,8BAA8B,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAqBpE,SAAS,CAAC,gBAAgB,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAStD,SAAS,CAAC,mBAAmB,CAAC,KAAK,CAAC,EAAE,aAAa,GAAG,IAAI;IAqB1D,SAAS,CAAC,kBAAkB,IAAI,IAAI;IAUpC,SAAS,CAAC,oBAAoB,CAAC,OAAO,EAAE,gBAAgB,GAAG,IAAI;CAGhE;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,kBAAkB,EAAE,sBAAsB,CAAC;KAC5C;CACF"}
@@ -96,4 +96,4 @@ let SbbAutocompleteElement = (() => {
96
96
  export {
97
97
  SbbAutocompleteElement
98
98
  };
99
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"autocomplete.component.js","sources":["../../../../src/elements/autocomplete/autocomplete.component.ts"],"sourcesContent":["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":["_a"],"mappings":";;;;;;;AAUA,IAAI,SAAS;AAMb,MAAM,iBAAiB;IAmBjB,0BAAsB,MAAA;;AAJ3B,MAAA,mBAAA,CAAA,cAAc,kBAAkB,GAChC,eAAe;AAAA,IACd,MAAM,iBAAiB,YAAY;AAAA,EAAA,CACpC,CAAC;;;;oBACmC;AAAR,EAAA,mBAAQ,YAA0B;AAAA,IAK7D,IAAc,UAAO;;AACnB,aAAO,MAAM,OAAKA,MAAA,KAAK,qBAAL,gBAAAA,IAAA,WAAwB,kBAAiB,EAAE;AAAA,IAAA;AAAA,IAG/D,cAAA;;;AARU,WAAA,YAAY,oBAAoB,EAAE,MAAM;AACxC,WAAS,YAAG;AACd,WAAgB,mBAAG;AAQzB,OAAAA,MAAA,KAAK,qBAAL,gBAAAA,IAAA,WAAwB,yBAAyB,CAAC,MAChD,KAAK,iBAAiB,CAAC;AAAA,IAAC;AAAA,IAIlB,eAAY;;AACf,OAAAA,MAAA,KAAA,qBAAA,gBAAAA,IAAA,WAAmB,eAAe,QAAQ,CAAC,YAAa,QAAQ,WAAW,KAAK;AAEhF,iBAAA,qBAAA,8BACH,4BACA,QAAQ,CAAC,YAAY,QAAQ,gBAAgB,iBAAiB,KAAK,QAAQ;AAAA,IAAC;AAAA,IAGtE,+BAA+B,OAAoB;AACvD,UAAA,KAAK,UAAU,UAAU;AAC3B;AAAA,MAAA;AAGF,cAAQ,MAAM,KAAK;AAAA,QACjB,KAAK;AACH,eAAK,MAAK;AACV;AAAA,QAEF,KAAK;AACH,eAAK,iBAAiB,KAAK;AAC3B;AAAA,QAEF,KAAK;AAAA,QACL,KAAK;AACH,eAAK,oBAAoB,KAAK;AAC9B;AAAA,MAAA;AAAA,IACJ;AAAA,IAGQ,iBAAiB,OAAoB;AAC7C,YAAM,eAAc;AACpB,YAAM,eAAe,KAAK,QAAQ,KAAK,gBAAgB;AAEvD,UAAI,cAAc;AAChB,qBAAa,8BAA8B,IAAI;AAAA,MAAA;AAAA,IACjD;AAAA,IAGQ,oBAAoB,OAAoB;;AAChD,YAAM,kBAAkB,KAAK,QAAQ,OACnC,CAAC,QAAQ,CAAC,IAAI,YAAY,CAAC,IAAI,aAAa,qBAAqB,CAAC;AAIpE,YAAM,OAAO,oBAAoB,OAAO,KAAK,kBAAkB,gBAAgB,MAAM;AAC/E,YAAA,mBAAmB,gBAAgB,IAAI;AAC7C,uBAAiB,UAAU,IAAI;AAC/B,OAAAA,MAAA,KAAK,mBAAL,gBAAAA,IAAqB,aAAa,yBAAyB,iBAAiB;AAC5E,uBAAiB,eAAe,EAAE,OAAO,UAAA,CAAW;AAG9C,YAAA,mBAAmB,gBAAgB,KAAK,gBAAgB;AAC9D,UAAI,kBAAkB;AACpB,yBAAiB,UAAU,KAAK;AAAA,MAAA;AAGlC,WAAK,mBAAmB;AAAA,IAAA;AAAA,IAGhB,qBAAkB;;AAC1B,YAAM,gBAAgB,KAAK,QAAQ,KAAK,gBAAgB;AAExD,UAAI,eAAe;AACjB,sBAAc,UAAU,KAAK;AAAA,MAAA;AAE/B,WAAK,mBAAmB;AACnB,OAAAA,MAAA,KAAA,mBAAA,gBAAAA,IAAgB,gBAAgB;AAAA,IAAuB;AAAA,IAGpD,qBAAqB,SAAyB;AACtD,gCAA0B,SAAS,iBAAiB,KAAK,KAAK,KAAK,WAAW,KAAK;AAAA,IAAA;AAAA,EACrF;;AAvFF,iBAwFC,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;AAxFK,sBAAsB,YAAA,uBAAA;AAAA,EAAA,MAAC;;;"}
99
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"autocomplete.component.js","sources":["../../../../src/elements/autocomplete/autocomplete.component.ts"],"sourcesContent":["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":["_a"],"mappings":";;;;;;;AAUA,IAAI,SAAS;AAMb,MAAM,iBAAiB;IAmBjB,0BAAsB,MAAA;;AAJ3B,MAAA,mBAAA,CAAA,cAAc,kBAAkB,GAChC,eAAe;AAAA,IACd,MAAM,iBAAiB,YAAY;AAAA,EAAA,CACpC,CAAC;;;;oBACmC;AAAR,EAAA,mBAAQ,YAA0B;AAAA,IAK7D,IAAc,UAAO;;AACnB,aAAO,MAAM,OAAKA,MAAA,KAAK,qBAAL,gBAAAA,IAAA,WAAwB,kBAAiB,EAAE;AAAA,IAAA;AAAA,IAG/D,cAAA;;;AARU,WAAA,YAAY,oBAAoB,EAAE,MAAM;AACxC,WAAS,YAAG;AACd,WAAgB,mBAAG;AAQzB,OAAAA,MAAA,KAAK,qBAAL,gBAAAA,IAAA,WAAwB,yBAAyB,CAAC,MAChD,KAAK,iBAAiB,CAAC;AAAA,IAAC;AAAA,IAIlB,eAAY;;AACf,OAAAA,MAAA,KAAA,qBAAA,gBAAAA,IAAA,WAAmB,eAAe,QAAQ,CAAC,YAAa,QAAQ,WAAW,KAAK;AAEhF,iBAAA,qBAAA,8BACH,4BACA,QAAQ,CAAC,YAAY,QAAQ,gBAAgB,iBAAiB,KAAK,QAAQ;AAAA,IAAC;AAAA,IAGtE,+BAA+B,OAAoB;AACvD,UAAA,KAAK,UAAU,UAAU;AAC3B;AAAA,MAAA;AAGF,cAAQ,MAAM,KAAK;AAAA,QACjB,KAAK;AACH,eAAK,MAAK;AACV;AAAA,QAEF,KAAK;AACH,eAAK,iBAAiB,KAAK;AAC3B;AAAA,QAEF,KAAK;AAAA,QACL,KAAK;AACH,eAAK,oBAAoB,KAAK;AAC9B;AAAA,MAAA;AAAA,IACJ;AAAA,IAGQ,iBAAiB,OAAoB;AAC7C,YAAM,eAAc;AACpB,YAAM,eAAe,KAAK,QAAQ,KAAK,gBAAgB;AAEvD,UAAI,cAAc;AAChB,qBAAa,8BAA8B,IAAI;AAAA,MAAA;AAAA,IACjD;AAAA,IAGQ,oBAAoB,OAAqB;;AACjD,YAAM,kBAAkB,KAAK,QAAQ,OACnC,CAAC,QAAQ,CAAC,IAAI,YAAY,CAAC,IAAI,aAAa,qBAAqB,CAAC;AAIpE,YAAM,OAAO,oBAAoB,OAAO,KAAK,kBAAkB,gBAAgB,MAAM;AAC/E,YAAA,mBAAmB,gBAAgB,IAAI;AAC7C,uBAAiB,UAAU,IAAI;AAC/B,OAAAA,MAAA,KAAK,mBAAL,gBAAAA,IAAqB,aAAa,yBAAyB,iBAAiB;AAC5E,uBAAiB,eAAe,EAAE,OAAO,UAAA,CAAW;AAG9C,YAAA,mBAAmB,gBAAgB,KAAK,gBAAgB;AAC9D,UAAI,kBAAkB;AACpB,yBAAiB,UAAU,KAAK;AAAA,MAAA;AAGlC,WAAK,mBAAmB;AAAA,IAAA;AAAA,IAGhB,qBAAkB;;AAC1B,YAAM,gBAAgB,KAAK,QAAQ,KAAK,gBAAgB;AAExD,UAAI,eAAe;AACjB,sBAAc,UAAU,KAAK;AAAA,MAAA;AAE/B,WAAK,mBAAmB;AACnB,OAAAA,MAAA,KAAA,mBAAA,gBAAAA,IAAgB,gBAAgB;AAAA,IAAuB;AAAA,IAGpD,qBAAqB,SAAyB;AACtD,gCAA0B,SAAS,iBAAiB,KAAK,KAAK,KAAK,WAAW,KAAK;AAAA,IAAA;AAAA,EACrF;;AAvFF,iBAwFC,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;AAxFK,sBAAsB,YAAA,uBAAA;AAAA,EAAA,MAAC;;;"}
@@ -30,7 +30,7 @@ export declare class SbbAutocompleteGridElement extends SbbAutocompleteBaseEleme
30
30
  * would always return a `SbbAutocompleteGridButtonElement`.
31
31
  */
32
32
  protected selectByKeyboard(event: KeyboardEvent): void;
33
- protected setNextActiveOption(event: KeyboardEvent): void;
33
+ protected setNextActiveOption(event?: KeyboardEvent): void;
34
34
  private _setNextHorizontalActiveElement;
35
35
  protected resetActiveElement(): void;
36
36
  protected setTriggerAttributes(element: HTMLInputElement): void;
@@ -1 +1 @@
1
- {"version":3,"file":"autocomplete-grid.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,0BAA0B,EAAE,MAAM,uBAAuB,CAAC;AAQnE,OAAO,EAAE,gCAAgC,EAAE,MAAM,gCAAgC,CAAC;AAWlF;;;;;;;;;;;GAWG;AACH,qBAKM,0BAA2B,SAAQ,0BAA0B;IACjE,SAAS,CAAC,SAAS,SAAuC;IAC1D,SAAS,CAAC,SAAS,SAAU;IAC7B,OAAO,CAAC,gBAAgB,CAAM;IAC9B,OAAO,CAAC,kBAAkB,CAAK;IAE/B,SAAS,KAAK,OAAO,IAAI,gCAAgC,EAAE,CAE1D;IAED,OAAO,KAAK,IAAI,GAMf;;IASD,SAAS,CAAC,YAAY,IAAI,IAAI;IAU9B,SAAS,CAAC,8BAA8B,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IA0BpE;;;;;;OAMG;IACH,SAAS,CAAC,gBAAgB,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IActD,SAAS,CAAC,mBAAmB,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IA8BzD,OAAO,CAAC,+BAA+B;IAmCvC,SAAS,CAAC,kBAAkB,IAAI,IAAI;IAkBpC,SAAS,CAAC,oBAAoB,CAAC,OAAO,EAAE,gBAAgB,GAAG,IAAI;CAGhE;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,uBAAuB,EAAE,0BAA0B,CAAC;KACrD;CACF"}
1
+ {"version":3,"file":"autocomplete-grid.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,0BAA0B,EAAE,MAAM,uBAAuB,CAAC;AAQnE,OAAO,EAAE,gCAAgC,EAAE,MAAM,gCAAgC,CAAC;AAWlF;;;;;;;;;;;GAWG;AACH,qBAKM,0BAA2B,SAAQ,0BAA0B;IACjE,SAAS,CAAC,SAAS,SAAuC;IAC1D,SAAS,CAAC,SAAS,SAAU;IAC7B,OAAO,CAAC,gBAAgB,CAAM;IAC9B,OAAO,CAAC,kBAAkB,CAAK;IAE/B,SAAS,KAAK,OAAO,IAAI,gCAAgC,EAAE,CAE1D;IAED,OAAO,KAAK,IAAI,GAMf;;IASD,SAAS,CAAC,YAAY,IAAI,IAAI;IAU9B,SAAS,CAAC,8BAA8B,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IA0BpE;;;;;;OAMG;IACH,SAAS,CAAC,gBAAgB,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IActD,SAAS,CAAC,mBAAmB,CAAC,KAAK,CAAC,EAAE,aAAa,GAAG,IAAI;IA8B1D,OAAO,CAAC,+BAA+B;IAmCvC,SAAS,CAAC,kBAAkB,IAAI,IAAI;IAkBpC,SAAS,CAAC,oBAAoB,CAAC,OAAO,EAAE,gBAAgB,GAAG,IAAI;CAGhE;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,uBAAuB,EAAE,0BAA0B,CAAC;KACrD;CACF"}