@sbb-esta/lyne-elements 3.2.0 → 3.3.2

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 (83) hide show
  1. package/autocomplete/autocomplete-base-element.d.ts +3 -4
  2. package/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  3. package/autocomplete/autocomplete-base-element.js +88 -83
  4. package/autocomplete/autocomplete.component.d.ts +0 -1
  5. package/autocomplete/autocomplete.component.d.ts.map +1 -1
  6. package/autocomplete/autocomplete.component.js +26 -26
  7. package/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts +0 -2
  8. package/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts.map +1 -1
  9. package/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.js +34 -44
  10. package/calendar/calendar.component.d.ts +54 -8
  11. package/calendar/calendar.component.d.ts.map +1 -1
  12. package/calendar/calendar.component.js +543 -256
  13. package/checkbox/checkbox-panel/checkbox-panel.component.d.ts +3 -2
  14. package/checkbox/checkbox-panel/checkbox-panel.component.d.ts.map +1 -1
  15. package/checkbox/checkbox-panel/checkbox-panel.component.js +36 -33
  16. package/core/i18n/i18n.d.ts +1 -0
  17. package/core/i18n/i18n.d.ts.map +1 -1
  18. package/core/i18n/i18n.js +22 -16
  19. package/core/i18n.js +79 -78
  20. package/core/mixins/element-internals-mixin.js +6 -6
  21. package/core/mixins/form-associated-mixin.d.ts.map +1 -1
  22. package/core/mixins/form-associated-mixin.js +22 -16
  23. package/core.css +7 -7
  24. package/custom-elements.json +1065 -56
  25. package/date-input/date-input.component.d.ts +5 -1
  26. package/date-input/date-input.component.d.ts.map +1 -1
  27. package/date-input/date-input.component.js +24 -15
  28. package/development/autocomplete/autocomplete-base-element.d.ts +3 -4
  29. package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  30. package/development/autocomplete/autocomplete-base-element.js +30 -15
  31. package/development/autocomplete/autocomplete.component.d.ts +0 -1
  32. package/development/autocomplete/autocomplete.component.d.ts.map +1 -1
  33. package/development/autocomplete/autocomplete.component.js +16 -21
  34. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts +0 -2
  35. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts.map +1 -1
  36. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.js +26 -35
  37. package/development/calendar/calendar.component.d.ts +54 -8
  38. package/development/calendar/calendar.component.d.ts.map +1 -1
  39. package/development/calendar/calendar.component.js +496 -81
  40. package/development/checkbox/checkbox-panel/checkbox-panel.component.d.ts +3 -2
  41. package/development/checkbox/checkbox-panel/checkbox-panel.component.d.ts.map +1 -1
  42. package/development/checkbox/checkbox-panel/checkbox-panel.component.js +10 -4
  43. package/development/core/i18n/i18n.d.ts +1 -0
  44. package/development/core/i18n/i18n.d.ts.map +1 -1
  45. package/development/core/i18n/i18n.js +8 -1
  46. package/development/core/i18n.js +2 -1
  47. package/development/core/mixins/element-internals-mixin.js +2 -2
  48. package/development/core/mixins/form-associated-mixin.d.ts.map +1 -1
  49. package/development/core/mixins/form-associated-mixin.js +14 -7
  50. package/development/date-input/date-input.component.d.ts +5 -1
  51. package/development/date-input/date-input.component.d.ts.map +1 -1
  52. package/development/date-input/date-input.component.js +11 -1
  53. package/development/form-field/form-field/form-field.component.d.ts +6 -3
  54. package/development/form-field/form-field/form-field.component.d.ts.map +1 -1
  55. package/development/form-field/form-field/form-field.component.js +1 -3
  56. package/development/header/common/header-action-common.js +4 -1
  57. package/development/icon/icon-request.js +2 -2
  58. package/development/notification/notification.component.js +1 -1
  59. package/development/option/option/option-base-element.d.ts.map +1 -1
  60. package/development/option/option/option-base-element.js +2 -1
  61. package/development/sbb-tokens-CVLcOi-S.js +1 -1
  62. package/development/time-input/time-input.component.d.ts +5 -1
  63. package/development/time-input/time-input.component.d.ts.map +1 -1
  64. package/development/time-input/time-input.component.js +11 -1
  65. package/development/toggle-check/toggle-check.component.d.ts +2 -2
  66. package/development/toggle-check/toggle-check.component.d.ts.map +1 -1
  67. package/development/toggle-check/toggle-check.component.js +4 -4
  68. package/form-field/form-field/form-field.component.d.ts +6 -3
  69. package/form-field/form-field/form-field.component.d.ts.map +1 -1
  70. package/form-field/form-field/form-field.component.js +0 -2
  71. package/header/common/header-action-common.js +1 -1
  72. package/icon/icon-request.js +3 -3
  73. package/notification/notification.component.js +1 -1
  74. package/option/option/option-base-element.d.ts.map +1 -1
  75. package/option/option/option-base-element.js +18 -18
  76. package/package.json +1 -1
  77. package/standard-theme.css +7 -7
  78. package/time-input/time-input.component.d.ts +5 -1
  79. package/time-input/time-input.component.d.ts.map +1 -1
  80. package/time-input/time-input.component.js +24 -16
  81. package/toggle-check/toggle-check.component.d.ts +2 -2
  82. package/toggle-check/toggle-check.component.d.ts.map +1 -1
  83. package/toggle-check/toggle-check.component.js +28 -28
@@ -1,5 +1,6 @@
1
1
  import { CSSResultGroup, LitElement, PropertyDeclaration } from 'lit';
2
2
  import { SbbDatepickerElement } from '../datepicker.js';
3
+ import { SbbFormFieldElementControl } from '../form-field.js';
3
4
  /**
4
5
  * Interface for elements that can be associated with a date input.
5
6
  * Implementing classes must also have a static property `sbbDateInputAssociated` set to `true`.
@@ -11,7 +12,7 @@ declare const SbbDateInputElement_base: import('../core/mixins.js').AbstractCons
11
12
  /**
12
13
  * Custom input for a date.
13
14
  */
14
- export declare class SbbDateInputElement<T = Date> extends SbbDateInputElement_base {
15
+ export declare class SbbDateInputElement<T = Date> extends SbbDateInputElement_base implements SbbFormFieldElementControl {
15
16
  static styles: CSSResultGroup;
16
17
  /**
17
18
  * The value of the date input. Reflects the current text value
@@ -24,6 +25,8 @@ export declare class SbbDateInputElement<T = Date> extends SbbDateInputElement_b
24
25
  set valueAsDate(value: T | null);
25
26
  get valueAsDate(): T | null;
26
27
  private _valueAsDate?;
28
+ /** Whether the input is empty. */
29
+ get empty(): boolean;
27
30
  /**
28
31
  * The minimum valid date. Accepts a date object or null.
29
32
  * Accepts an ISO8601 formatted string (e.g. 2024-12-24) as attribute.
@@ -74,6 +77,7 @@ export declare class SbbDateInputElement<T = Date> extends SbbDateInputElement_b
74
77
  protected shouldValidate(name: PropertyKey | undefined): boolean;
75
78
  protected validate(): void;
76
79
  private _removeValidityErrors;
80
+ private _dispatchFormFieldChange;
77
81
  }
78
82
  declare global {
79
83
  interface HTMLElementTagNameMap {
@@ -1 +1 @@
1
- {"version":3,"file":"date-input.component.d.ts","sourceRoot":"","sources":["../../../src/elements/date-input/date-input.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAY,UAAU,EAAE,KAAK,mBAAmB,EAAE,MAAM,KAAK,CAAC;AAa1F,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAY7D;;;GAGG;AACH,MAAM,WAAW,sBAAsB,CAAC,CAAC;IACvC,KAAK,EAAE,mBAAmB,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;CACtC;;AAED;;GAEG;AACH,qBAEM,mBAAmB,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,wBAAuC;IACjF,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;;;;OAKG;IACH,IAAoB,KAAK,CAAC,KAAK,EAAE,MAAM,EAQtC;IACD,IAAoB,KAAK,IAAI,MAAM,CAElC;IAED,IACW,WAAW,CAAC,KAAK,EAAE,CAAC,GAAG,IAAI,EAsBrC;IACD,IAAW,WAAW,IAAI,CAAC,GAAG,IAAI,CAIjC;IACD,OAAO,CAAC,YAAY,CAAC,CAAW;IAEhC;;;OAGG;IACH,SAEgB,GAAG,EAAE,CAAC,GAAG,IAAI,CAAQ;IAErC;;;OAGG;IACH,SAEgB,GAAG,EAAE,CAAC,GAAG,IAAI,CAAQ;IAErC;;;;OAIG;IACH,IACW,UAAU,CAAC,KAAK,EAAE,CAAC,IAAI,EAAE,CAAC,GAAG,IAAI,KAAK,OAAO,EAEvD;IACD,IAAW,UAAU,IAAI,CAAC,IAAI,EAAE,CAAC,GAAG,IAAI,KAAK,OAAO,CAEnD;IAED;;;;OAIG;IACH,SACgB,YAAY,EAAE,OAAO,GAAG,MAAM,CAAW;IAEzD;;;OAGG;IACH,OAAO,CAAC,WAAW,CAAC,CAAqB;IACzC,OAAO,CAAC,YAAY,CAA4E;IAChG,OAAO,CAAC,mBAAmB,CAAS;IAEpC;;;OAGG;IACH,IAAW,UAAU,IAAI,oBAAoB,CAAC,CAAC,CAAC,GAAG,IAAI,CAEtD;;IAOD;;OAEG;WACW,kBAAkB,CAAC,CAAC,EAAE,IAAI,EAAE,WAAW,GAAG,sBAAsB,CAAC,CAAC,CAAC,GAAG,IAAI;IAaxF,OAAO,CAAC,WAAW,CAA2C;IAE9C,iBAAiB,IAAI,IAAI;IAmBzB,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI;cAiBY,eAAe,IAAI,IAAI;IAO1C,OAAO,CAAC,cAAc;IAOtB,OAAO,CAAC,sBAAsB;IAS9B,OAAO,CAAC,WAAW;cAIA,cAAc,CAAC,IAAI,EAAE,WAAW,GAAG,SAAS,GAAG,OAAO;cAOtD,QAAQ,IAAI,IAAI;IAiCnC,OAAO,CAAC,qBAAqB;CAK9B;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,mBAAmB,CAAC;KACvC;IAED,UAAU,mBAAmB;QAC3B,aAAa,EAAE,OAAO,CAAC;KACxB;CACF"}
1
+ {"version":3,"file":"date-input.component.d.ts","sourceRoot":"","sources":["../../../src/elements/date-input/date-input.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAY,UAAU,EAAE,KAAK,mBAAmB,EAAE,MAAM,KAAK,CAAC;AAa1F,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAC7D,OAAO,EAA4B,KAAK,0BAA0B,EAAE,MAAM,kBAAkB,CAAC;AAY7F;;;GAGG;AACH,MAAM,WAAW,sBAAsB,CAAC,CAAC;IACvC,KAAK,EAAE,mBAAmB,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;CACtC;;AAED;;GAEG;AACH,qBAEM,mBAAmB,CAAC,CAAC,GAAG,IAAI,CAChC,SAAQ,wBACR,YAAW,0BAA0B;IAErC,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;;;;OAKG;IACH,IAAoB,KAAK,CAAC,KAAK,EAAE,MAAM,EAStC;IACD,IAAoB,KAAK,IAAI,MAAM,CAElC;IAED,IACW,WAAW,CAAC,KAAK,EAAE,CAAC,GAAG,IAAI,EAsBrC;IACD,IAAW,WAAW,IAAI,CAAC,GAAG,IAAI,CAIjC;IACD,OAAO,CAAC,YAAY,CAAC,CAAW;IAEhC,kCAAkC;IAClC,IAAW,KAAK,IAAI,OAAO,CAE1B;IAED;;;OAGG;IACH,SAEgB,GAAG,EAAE,CAAC,GAAG,IAAI,CAAQ;IAErC;;;OAGG;IACH,SAEgB,GAAG,EAAE,CAAC,GAAG,IAAI,CAAQ;IAErC;;;;OAIG;IACH,IACW,UAAU,CAAC,KAAK,EAAE,CAAC,IAAI,EAAE,CAAC,GAAG,IAAI,KAAK,OAAO,EAEvD;IACD,IAAW,UAAU,IAAI,CAAC,IAAI,EAAE,CAAC,GAAG,IAAI,KAAK,OAAO,CAEnD;IAED;;;;OAIG;IACH,SACgB,YAAY,EAAE,OAAO,GAAG,MAAM,CAAW;IAEzD;;;OAGG;IACH,OAAO,CAAC,WAAW,CAAC,CAAqB;IACzC,OAAO,CAAC,YAAY,CAA4E;IAChG,OAAO,CAAC,mBAAmB,CAAS;IAEpC;;;OAGG;IACH,IAAW,UAAU,IAAI,oBAAoB,CAAC,CAAC,CAAC,GAAG,IAAI,CAEtD;;IAOD;;OAEG;WACW,kBAAkB,CAAC,CAAC,EAAE,IAAI,EAAE,WAAW,GAAG,sBAAsB,CAAC,CAAC,CAAC,GAAG,IAAI;IAaxF,OAAO,CAAC,WAAW,CAA2C;IAE9C,iBAAiB,IAAI,IAAI;IAoBzB,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI;cAiBY,eAAe,IAAI,IAAI;IAO1C,OAAO,CAAC,cAAc;IAOtB,OAAO,CAAC,sBAAsB;IAS9B,OAAO,CAAC,WAAW;cAIA,cAAc,CAAC,IAAI,EAAE,WAAW,GAAG,SAAS,GAAG,OAAO;cAOtD,QAAQ,IAAI,IAAI;IAiCnC,OAAO,CAAC,qBAAqB;IAM7B,OAAO,CAAC,wBAAwB;CAIjC;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,mBAAmB,CAAC;KACvC;IAED,UAAU,mBAAmB;QAC3B,aAAa,EAAE,OAAO,CAAC;KACxB;CACF"}
@@ -1,32 +1,33 @@
1
- var I = (a) => {
1
+ var C = (a) => {
2
2
  throw TypeError(a);
3
3
  };
4
- var z = (a, s, i) => s.has(a) || I("Cannot " + i);
5
- var _ = (a, s, i) => (z(a, s, "read from private field"), i ? i.call(a) : s.get(a)), f = (a, s, i) => s.has(a) ? I("Cannot add the same private member more than once") : s instanceof WeakSet ? s.add(a) : s.set(a, i), o = (a, s, i, n) => (z(a, s, "write to private field"), n ? n.call(a, i) : s.set(a, i), i);
4
+ var I = (a, s, i) => s.has(a) || C("Cannot " + i);
5
+ var _ = (a, s, i) => (I(a, s, "read from private field"), i ? i.call(a) : s.get(a)), f = (a, s, i) => s.has(a) ? C("Cannot add the same private member more than once") : s instanceof WeakSet ? s.add(a) : s.set(a, i), o = (a, s, i, n) => (I(a, s, "write to private field"), n ? n.call(a, i) : s.set(a, i), i);
6
6
  import { __esDecorate as m, __runInitializers as d } from "tslib";
7
7
  import { css as U, LitElement as q, isServer as j } from "lit";
8
8
  import { customElement as T, property as p } from "lit/decorators.js";
9
9
  import { readConfig as L } from "../core/config.js";
10
10
  import { defaultDateAdapter as G } from "../core/datetime.js";
11
- import { plainDate as C, plainDateConverter as M } from "../core/decorators.js";
11
+ import { plainDate as z, plainDateConverter as M } from "../core/decorators.js";
12
12
  import { i18nDatePickerPlaceholder as O, i18nDateInvalid as P, i18nDateMin as N, i18nDateMax as Y } from "../core/i18n.js";
13
13
  import { SbbFormAssociatedInputMixin as B } from "../core/mixins.js";
14
- const H = U`:host{display:inline-flex;min-width:9.375rem;max-width:100%;cursor:text;align-items:center}@media (forced-colors: active){:host{color:FieldText}}:host(:disabled){cursor:default}:host(:focus){text-overflow:initial!important}:host(:empty):after{content:attr(placeholder);color:var(--sbb-color-metal);-webkit-text-fill-color:var(--sbb-color-metal);opacity:1}@media (forced-colors: active){:host(:empty):after{color:GrayText}}`;
14
+ import { SbbFormFieldControlEvent as H } from "../form-field.js";
15
+ const J = U`:host{display:inline-flex;min-width:9.375rem;max-width:100%;cursor:text;align-items:center}@media (forced-colors: active){:host{color:FieldText}}:host(:disabled){cursor:default}:host(:focus){text-overflow:initial!important}:host(:empty):after{content:attr(placeholder);color:var(--sbb-color-metal);-webkit-text-fill-color:var(--sbb-color-metal);opacity:1}@media (forced-colors: active){:host(:empty):after{color:GrayText}}`;
15
16
  Object.assign(ValidityState.prototype, {
16
17
  get sbbDateFilter() {
17
18
  return !1;
18
19
  }
19
20
  });
20
- let at = (() => {
21
+ let it = (() => {
21
22
  var h, u, c, r;
22
- let a = [T("sbb-date-input")], s, i = [], n, y = B(q), v = [], D, A, b = [], g = [], x, k = [], F = [], w, S, V = [], E = [];
23
+ let a = [T("sbb-date-input")], s, i = [], n, y = B(q), v = [], D, b, A = [], g = [], F, x = [], k = [], w, S, V = [], E = [];
23
24
  return r = class extends y {
24
25
  constructor() {
25
26
  super();
26
27
  f(this, h);
27
28
  f(this, u);
28
29
  f(this, c);
29
- this._valueAsDate = d(this, v), o(this, h, d(this, b, null)), o(this, u, (d(this, g), d(this, k, null))), o(this, c, (d(this, F), d(this, V, "short"))), this._valueCache = d(this, E), this._dateAdapter = L().datetime?.dateAdapter ?? G, this._placeholderMutable = !1, this._dateFilter = () => !0, this.addEventListener?.("change", () => this._updateValueDateFormat(), { capture: !0 });
30
+ this._valueAsDate = d(this, v), o(this, h, d(this, A, null)), o(this, u, (d(this, g), d(this, x, null))), o(this, c, (d(this, k), d(this, V, "short"))), this._valueCache = d(this, E), this._dateAdapter = L().datetime?.dateAdapter ?? G, this._placeholderMutable = !1, this._dateFilter = () => !0, this.addEventListener?.("change", () => this._updateValueDateFormat(), { capture: !0 });
30
31
  }
31
32
  /**
32
33
  * The value of the date input. Reflects the current text value
@@ -35,7 +36,7 @@ let at = (() => {
35
36
  * formatted according to the current locale.
36
37
  */
37
38
  set value(t) {
38
- this._tryParseValue(t), !j && !this.matches(":focus") && this.valueAsDate !== null && (t = this._formatDate()), super.value = t;
39
+ this._tryParseValue(t), !j && !this.matches(":focus") && this.valueAsDate !== null && (t = this._formatDate()), super.value = t, this._dispatchFormFieldChange();
39
40
  }
40
41
  get value() {
41
42
  return super.value ?? "";
@@ -52,6 +53,10 @@ let at = (() => {
52
53
  get valueAsDate() {
53
54
  return this._valueAsDate ? this._dateAdapter.clone(this._valueAsDate) : null;
54
55
  }
56
+ /** Whether the input is empty. */
57
+ get empty() {
58
+ return !this.value || this.value.trim() === "";
59
+ }
55
60
  /**
56
61
  * The minimum valid date. Accepts a date object or null.
57
62
  * Accepts an ISO8601 formatted string (e.g. 2024-12-24) as attribute.
@@ -114,6 +119,7 @@ let at = (() => {
114
119
  super.connectedCallback(), this.placeholder || (this._placeholderMutable = !0, this.placeholder = O[this.language.current]);
115
120
  for (const t of Array.from(this.closest("sbb-form-field")?.children ?? []))
116
121
  customElements.upgrade?.(t), t.constructor.sbbDateInputAssociated && !t.hasAttribute("input") && !t.input && (t.input = this);
122
+ this._dispatchFormFieldChange();
117
123
  }
118
124
  requestUpdate(t, e, l) {
119
125
  super.requestUpdate(t, e, l), this.hasUpdated && !t ? (this._updateValueDateFormat(), this._placeholderMutable && (this.placeholder = O[this.language.current])) : t === "weekdayStyle" && this._updateValueDateFormat(), this.isConnected && this.dispatchEvent(new Event("ɵchange"));
@@ -144,21 +150,24 @@ let at = (() => {
144
150
  _removeValidityErrors() {
145
151
  ["badInput", "rangeUnderflow", "rangeOverflow", "sbbDateFilter"].forEach((t) => this.removeValidityFlag(t));
146
152
  }
153
+ _dispatchFormFieldChange() {
154
+ this.closest?.("sbb-form-field")?.dispatchEvent(new H(this));
155
+ }
147
156
  }, h = new WeakMap(), u = new WeakMap(), c = new WeakMap(), n = r, (() => {
148
157
  const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(y[Symbol.metadata] ?? null) : void 0;
149
- D = [p({ attribute: !1 })], A = [C(), p({ converter: M, reflect: !0 })], x = [C(), p({ converter: M, reflect: !0 })], w = [p({ attribute: !1 })], S = [p({ attribute: "weekday-style" })], m(r, null, D, { kind: "setter", name: "valueAsDate", static: !1, private: !1, access: { has: (e) => "valueAsDate" in e, set: (e, l) => {
158
+ D = [p({ attribute: !1 })], b = [z(), p({ converter: M, reflect: !0 })], F = [z(), p({ converter: M, reflect: !0 })], w = [p({ attribute: !1 })], S = [p({ attribute: "weekday-style" })], m(r, null, D, { kind: "setter", name: "valueAsDate", static: !1, private: !1, access: { has: (e) => "valueAsDate" in e, set: (e, l) => {
150
159
  e.valueAsDate = l;
151
- } }, metadata: t }, null, v), m(r, null, A, { kind: "accessor", name: "min", static: !1, private: !1, access: { has: (e) => "min" in e, get: (e) => e.min, set: (e, l) => {
160
+ } }, metadata: t }, null, v), m(r, null, b, { kind: "accessor", name: "min", static: !1, private: !1, access: { has: (e) => "min" in e, get: (e) => e.min, set: (e, l) => {
152
161
  e.min = l;
153
- } }, metadata: t }, b, g), m(r, null, x, { kind: "accessor", name: "max", static: !1, private: !1, access: { has: (e) => "max" in e, get: (e) => e.max, set: (e, l) => {
162
+ } }, metadata: t }, A, g), m(r, null, F, { kind: "accessor", name: "max", static: !1, private: !1, access: { has: (e) => "max" in e, get: (e) => e.max, set: (e, l) => {
154
163
  e.max = l;
155
- } }, metadata: t }, k, F), m(r, null, w, { kind: "setter", name: "dateFilter", static: !1, private: !1, access: { has: (e) => "dateFilter" in e, set: (e, l) => {
164
+ } }, metadata: t }, x, k), m(r, null, w, { kind: "setter", name: "dateFilter", static: !1, private: !1, access: { has: (e) => "dateFilter" in e, set: (e, l) => {
156
165
  e.dateFilter = l;
157
166
  } }, metadata: t }, null, v), m(r, null, S, { kind: "accessor", name: "weekdayStyle", static: !1, private: !1, access: { has: (e) => "weekdayStyle" in e, get: (e) => e.weekdayStyle, set: (e, l) => {
158
167
  e.weekdayStyle = l;
159
168
  } }, metadata: t }, V, E), m(null, s = { value: n }, a, { kind: "class", name: n.name, metadata: t }, null, i), n = s.value, t && Object.defineProperty(n, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
160
- })(), r.styles = H, d(n, i), n;
169
+ })(), r.styles = J, d(n, i), n;
161
170
  })();
162
171
  export {
163
- at as SbbDateInputElement
172
+ it as SbbDateInputElement
164
173
  };
@@ -39,6 +39,7 @@ export declare abstract class SbbAutocompleteBaseElement<T = string> extends Sbb
39
39
  private _triggerElement?;
40
40
  protected abstract overlayId: string;
41
41
  protected abstract panelRole: string;
42
+ protected activeOption: SbbOptionBaseElement<T> | null;
42
43
  private _originResizeObserver;
43
44
  /** Listens to the changes on the `disabled` or `readonly` attribute of the trigger. */
44
45
  private _triggerAttributeObserver;
@@ -48,6 +49,7 @@ export declare abstract class SbbAutocompleteBaseElement<T = string> extends Sbb
48
49
  private _openPanelEventsController;
49
50
  private _isPointerDownEventOnMenu;
50
51
  private _escapableOverlayController;
52
+ private _optionsCount;
51
53
  protected abstract get options(): SbbOptionBaseElement<T>[];
52
54
  protected abstract syncNegative(): void;
53
55
  protected abstract setTriggerAttributes(element: HTMLInputElement): void;
@@ -68,10 +70,7 @@ export declare abstract class SbbAutocompleteBaseElement<T = string> extends Sbb
68
70
  /** When an option is selected, update the input value and close the autocomplete. */
69
71
  protected onOptionSelected(event: Event): void;
70
72
  private _handleSlotchange;
71
- /**
72
- * If the 'input' is focused and there's a change in the number of options, open the autocomplete
73
- */
74
- private _openOnNewOptions;
73
+ private _setNextActiveOptionIfAutoActiveFirstOption;
75
74
  /** The autocomplete should inherit 'readonly' state from the trigger. */
76
75
  private _readonly;
77
76
  private _componentSetup;
@@ -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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"}
@@ -336,6 +336,7 @@ let SbbAutocompleteBaseElement = (() => {
336
336
  __privateSet(this, _displayWith_accessor_storage, (__runInitializers(this, _autoActiveFirstOption_extraInitializers), __runInitializers(this, _displayWith_initializers, null)));
337
337
  __privateSet(this, _size_accessor_storage, (__runInitializers(this, _displayWith_extraInitializers), __runInitializers(this, _size_initializers, isLean() ? "s" : "m")));
338
338
  this._triggerElement = __runInitializers(this, _size_extraInitializers);
339
+ this.activeOption = null;
339
340
  this._originResizeObserver = new ResizeController(this, {
340
341
  target: null,
341
342
  skipInitial: true,
@@ -353,6 +354,7 @@ let SbbAutocompleteBaseElement = (() => {
353
354
  }) : null;
354
355
  this._isPointerDownEventOnMenu = false;
355
356
  this._escapableOverlayController = new SbbEscapableOverlayController(this);
357
+ this._optionsCount = 0;
356
358
  this._pointerDownListener = (event) => {
357
359
  this._isPointerDownEventOnMenu = isEventOnElement(this._overlay, event);
358
360
  };
@@ -444,9 +446,7 @@ let SbbAutocompleteBaseElement = (() => {
444
446
  throw new Error('Cannot find the origin element. Please specify a valid element or check the usage of the "origin" property from the documentation');
445
447
  }
446
448
  this._setOverlayPosition(originElement);
447
- if (this.autoActiveFirstOption) {
448
- this.setNextActiveOption();
449
- }
449
+ this._setNextActiveOptionIfAutoActiveFirstOption();
450
450
  if (this._isZeroAnimationDuration()) {
451
451
  this._handleOpening();
452
452
  }
@@ -489,6 +489,9 @@ let SbbAutocompleteBaseElement = (() => {
489
489
  if (changedProperties.has("negative")) {
490
490
  this.syncNegative();
491
491
  }
492
+ if (changedProperties.has("autoActiveFirstOption") && this.isOpen) {
493
+ this._setNextActiveOptionIfAutoActiveFirstOption();
494
+ }
492
495
  }
493
496
  firstUpdated(changedProperties) {
494
497
  super.firstUpdated(changedProperties);
@@ -532,19 +535,23 @@ let SbbAutocompleteBaseElement = (() => {
532
535
  this._highlightOptions(this.triggerElement?.value);
533
536
  if (this.isOpen) {
534
537
  this._setOverlayPosition();
535
- }
536
- this._openOnNewOptions();
537
- }
538
- /**
539
- * If the 'input' is focused and there's a change in the number of options, open the autocomplete
540
- */
541
- _openOnNewOptions() {
542
- if (document?.activeElement === this.triggerElement) {
543
- if (this.options.length > 0) {
544
- this.open();
545
- } else {
538
+ this._setNextActiveOptionIfAutoActiveFirstOption();
539
+ if (this._optionsCount > 0 && this.options.length === 0) {
546
540
  this.close();
547
541
  }
542
+ } else if (
543
+ // If the 'input' is focused and the count of options changes from 0 to > 0,
544
+ // the autocomplete should open automatically.
545
+ document?.activeElement === this.triggerElement && this._optionsCount === 0 && this.options.length > 0
546
+ ) {
547
+ this.open();
548
+ }
549
+ this._optionsCount = this.options.length;
550
+ }
551
+ _setNextActiveOptionIfAutoActiveFirstOption() {
552
+ if (this.autoActiveFirstOption) {
553
+ this.resetActiveElement();
554
+ this.setNextActiveOption();
548
555
  }
549
556
  }
550
557
  /** The autocomplete should inherit 'readonly' state from the trigger. */
@@ -653,6 +660,14 @@ let SbbAutocompleteBaseElement = (() => {
653
660
  window.addEventListener("pointerup", (ev) => this._closeOnBackdropClick(ev), {
654
661
  signal: this._openPanelEventsController.signal
655
662
  });
663
+ this.addEventListener("ɵdisabledchange", () => {
664
+ if (this.activeOption?.disabled) {
665
+ this.resetActiveElement();
666
+ }
667
+ this._setNextActiveOptionIfAutoActiveFirstOption();
668
+ }, {
669
+ signal: this._openPanelEventsController.signal
670
+ });
656
671
  this.triggerElement?.addEventListener("keydown", (event) => this.openedPanelKeyboardInteraction(event), {
657
672
  signal: this._openPanelEventsController.signal,
658
673
  // We need key event to run before any other subscription to guarantee a correct
@@ -736,4 +751,4 @@ let SbbAutocompleteBaseElement = (() => {
736
751
  export {
737
752
  SbbAutocompleteBaseElement
738
753
  };
739
- //# 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 { SbbEscapableOverlayController } from '../core/controllers.js';\nimport { forceType, idReference } from '../core/decorators.js';\nimport { isLean, 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 abstract class SbbAutocompleteBaseElement<T = string> extends SbbNegativeMixin(\n  SbbHydrationMixin(SbbOpenCloseBaseElement),\n) {\n  public static override styles: CSSResultGroup = style;\n\n  /**\n   * The element where the autocomplete will attach.\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   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor origin: HTMLElement | null = null;\n\n  /**\n   * The input element that will trigger the autocomplete opening.\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   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor trigger: 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  /** Function that maps an option's control value to its display value in the trigger. */\n  @property({ attribute: false })\n  public accessor displayWith: ((value: T) => string) | null = null;\n\n  /**\n   * Size variant, either m or s.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 'm' | 's' = isLean() ? 's' : 'm';\n\n  /** Returns the element where autocomplete overlay is attached to. */\n  public get originElement(): HTMLElement | null {\n    return (\n      this.origin ??\n      this.closest?.('sbb-form-field')?.shadowRoot?.querySelector?.('#overlay-anchor') ??\n      this.trigger ??\n      null\n    );\n  }\n\n  /** Returns the trigger element. */\n  public get triggerElement(): HTMLInputElement | null {\n    return this._triggerElement ?? null;\n  }\n  private _triggerElement?: HTMLInputElement | null;\n\n  protected abstract overlayId: string;\n  protected abstract panelRole: string;\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 _openPanelEventsController!: AbortController;\n  private _isPointerDownEventOnMenu: boolean = false;\n  private _escapableOverlayController = new SbbEscapableOverlayController(this);\n\n  protected abstract get options(): SbbOptionBaseElement<T>[];\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.dispatchBeforeOpenEvent()) {\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' || !this.dispatchBeforeCloseEvent()) {\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    this.popover = 'manual';\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    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: Event): void {\n    const target = event.target as SbbOptionBaseElement<T>;\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      // Given a value, returns the string that should be shown within the input.\n      const toDisplay = this.displayWith?.(target.value as T) ?? target.value;\n\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, toDisplay);\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(\n        new CustomEvent<{ option: SbbOptionBaseElement<T> }>('inputAutocomplete', {\n          detail: { option: target },\n        }),\n      );\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 = (this.trigger ??\n      this.closest?.('sbb-form-field')?.querySelector('input')) as HTMLInputElement | null;\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.dispatchOpenEvent();\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.dispatchCloseEvent();\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\ndeclare global {\n  interface HTMLElementEventMap {\n    inputAutocomplete: CustomEvent<{ option: SbbOptionBaseElement<any> }>;\n  }\n}\n"],"names":[],"mappings":"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"}
754
+ //# 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 { SbbEscapableOverlayController } from '../core/controllers.js';\nimport { forceType, idReference } from '../core/decorators.js';\nimport { isLean, 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 abstract class SbbAutocompleteBaseElement<T = string> extends SbbNegativeMixin(\n  SbbHydrationMixin(SbbOpenCloseBaseElement),\n) {\n  public static override styles: CSSResultGroup = style;\n\n  /**\n   * The element where the autocomplete will attach.\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   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor origin: HTMLElement | null = null;\n\n  /**\n   * The input element that will trigger the autocomplete opening.\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   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor trigger: 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  /** Function that maps an option's control value to its display value in the trigger. */\n  @property({ attribute: false })\n  public accessor displayWith: ((value: T) => string) | null = null;\n\n  /**\n   * Size variant, either m or s.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 'm' | 's' = isLean() ? 's' : 'm';\n\n  /** Returns the element where autocomplete overlay is attached to. */\n  public get originElement(): HTMLElement | null {\n    return (\n      this.origin ??\n      this.closest?.('sbb-form-field')?.shadowRoot?.querySelector?.('#overlay-anchor') ??\n      this.trigger ??\n      null\n    );\n  }\n\n  /** Returns the trigger element. */\n  public get triggerElement(): HTMLInputElement | null {\n    return this._triggerElement ?? null;\n  }\n  private _triggerElement?: HTMLInputElement | null;\n\n  protected abstract overlayId: string;\n  protected abstract panelRole: string;\n  protected activeOption: SbbOptionBaseElement<T> | null = null;\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 _openPanelEventsController!: AbortController;\n  private _isPointerDownEventOnMenu: boolean = false;\n  private _escapableOverlayController = new SbbEscapableOverlayController(this);\n  private _optionsCount = 0;\n\n  protected abstract get options(): SbbOptionBaseElement<T>[];\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.dispatchBeforeOpenEvent()) {\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    this._setNextActiveOptionIfAutoActiveFirstOption();\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' || !this.dispatchBeforeCloseEvent()) {\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    this.popover = 'manual';\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    if (changedProperties.has('autoActiveFirstOption') && this.isOpen) {\n      this._setNextActiveOptionIfAutoActiveFirstOption();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\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: Event): void {\n    const target = event.target as SbbOptionBaseElement<T>;\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      // Given a value, returns the string that should be shown within the input.\n      const toDisplay = this.displayWith?.(target.value as T) ?? target.value;\n\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, toDisplay);\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(\n        new CustomEvent<{ option: SbbOptionBaseElement<T> }>('inputAutocomplete', {\n          detail: { option: target },\n        }),\n      );\n      this.triggerElement.focus();\n    }\n\n    this.close();\n  }\n\n  private _handleSlotchange(): void {\n    this._highlightOptions(this.triggerElement?.value);\n\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      this._setNextActiveOptionIfAutoActiveFirstOption();\n\n      // If the autocomplete is open and the option count gets to zero, we close the autocomplete.\n      if (this._optionsCount > 0 && this.options.length === 0) {\n        this.close();\n      }\n    } else if (\n      // If the 'input' is focused and the count of options changes from 0 to > 0,\n      // the autocomplete should open automatically.\n      document?.activeElement === this.triggerElement &&\n      this._optionsCount === 0 &&\n      this.options.length > 0\n    ) {\n      this.open();\n    }\n\n    this._optionsCount = this.options.length;\n  }\n  private _setNextActiveOptionIfAutoActiveFirstOption(): void {\n    if (this.autoActiveFirstOption) {\n      this.resetActiveElement();\n      this.setNextActiveOption();\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 = (this.trigger ??\n      this.closest?.('sbb-form-field')?.querySelector('input')) as HTMLInputElement | null;\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.dispatchOpenEvent();\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.dispatchCloseEvent();\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    this.addEventListener(\n      'ɵdisabledchange',\n      () => {\n        if (this.activeOption?.disabled) {\n          this.resetActiveElement();\n        }\n        this._setNextActiveOptionIfAutoActiveFirstOption();\n      },\n      {\n        signal: this._openPanelEventsController.signal,\n      },\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\ndeclare global {\n  interface HTMLElementEventMap {\n    inputAutocomplete: CustomEvent<{ option: SbbOptionBaseElement<any> }>;\n  }\n}\n"],"names":[],"mappings":"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"}
@@ -12,7 +12,6 @@ export declare class SbbAutocompleteElement<T = string> extends SbbAutocompleteB
12
12
  static readonly role: string | null;
13
13
  protected overlayId: string;
14
14
  protected panelRole: string;
15
- private _activeItemIndex;
16
15
  protected get options(): SbbOptionElement<T>[];
17
16
  constructor();
18
17
  protected syncNegative(): void;
@@ -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,EAAwB,MAAM,cAAc,CAAC;AAE/F,OAAO,EAAE,0BAA0B,EAAE,MAAM,gCAAgC,CAAC;AAU5E;;;;;;;GAOG;AACH,qBAEM,sBAAsB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,0BAA0B,CAAC,CAAC,CAAC;IAC5E,gBAAgC,IAAI,gBAAqC;IACzE,SAAS,CAAC,SAAS,SAAkC;IACrD,SAAS,CAAC,SAAS,SAAa;IAChC,OAAO,CAAC,gBAAgB,CAAM;IAE9B,SAAS,KAAK,OAAO,IAAI,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAE7C;;IAOD,SAAS,CAAC,YAAY,IAAI,IAAI;IAU9B,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"}
1
+ {"version":3,"file":"autocomplete.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/autocomplete/autocomplete.component.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAsB,gBAAgB,EAAwB,MAAM,cAAc,CAAC;AAE/F,OAAO,EAAE,0BAA0B,EAAE,MAAM,gCAAgC,CAAC;AAU5E;;;;;;;GAOG;AACH,qBAEM,sBAAsB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,0BAA0B,CAAC,CAAC,CAAC;IAC5E,gBAAgC,IAAI,gBAAqC;IACzE,SAAS,CAAC,SAAS,SAAkC;IACrD,SAAS,CAAC,SAAS,SAAa;IAEhC,SAAS,KAAK,OAAO,IAAI,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAE7C;;IAOD,SAAS,CAAC,YAAY,IAAI,IAAI;IAU9B,SAAS,CAAC,8BAA8B,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAqBpE,SAAS,CAAC,gBAAgB,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAMtD,SAAS,CAAC,mBAAmB,CAAC,KAAK,CAAC,EAAE,aAAa,GAAG,IAAI;IA0B1D,SAAS,CAAC,kBAAkB,IAAI,IAAI;IAMpC,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"}
@@ -21,7 +21,6 @@ let SbbAutocompleteElement = (() => {
21
21
  super();
22
22
  this.overlayId = `sbb-autocomplete-${++nextId}`;
23
23
  this.panelRole = "listbox";
24
- this._activeItemIndex = -1;
25
24
  this.addEventListener?.("optionselected", (e) => this.onOptionSelected(e));
26
25
  }
27
26
  syncNegative() {
@@ -47,31 +46,27 @@ let SbbAutocompleteElement = (() => {
47
46
  }
48
47
  selectByKeyboard(event) {
49
48
  event.preventDefault();
50
- const activeOption = this.options[this._activeItemIndex];
51
- if (activeOption) {
52
- activeOption["selectViaUserInteraction"](true);
53
- }
49
+ this.activeOption?.["selectViaUserInteraction"](true);
54
50
  }
55
51
  setNextActiveOption(event) {
56
- const filteredOptions = this.options.filter((opt) => !opt.disabled && !opt.hasAttribute("data-group-disabled"));
57
- const next = getNextElementIndex(event, this._activeItemIndex, filteredOptions.length);
58
- const nextActiveOption = filteredOptions[next];
59
- nextActiveOption.setActive(true);
60
- this.triggerElement?.setAttribute("aria-activedescendant", nextActiveOption.id);
61
- nextActiveOption.scrollIntoView({ block: "nearest" });
62
- const lastActiveOption = filteredOptions[this._activeItemIndex];
63
- if (lastActiveOption) {
64
- lastActiveOption.setActive(false);
52
+ const enabledOptions = this.options.filter((opt) => !opt.disabled && !opt.hasAttribute("data-group-disabled"));
53
+ this.activeOption?.setActive(false);
54
+ this.triggerElement?.removeAttribute("aria-activedescendant");
55
+ if (!enabledOptions.length) {
56
+ this.activeOption = null;
57
+ return;
65
58
  }
66
- this._activeItemIndex = next;
59
+ const activeItemIndex = this.activeOption ? enabledOptions.indexOf(this.activeOption) : -1;
60
+ const next = getNextElementIndex(event, activeItemIndex, enabledOptions.length);
61
+ this.activeOption = enabledOptions[next];
62
+ this.activeOption.setActive(true);
63
+ this.triggerElement?.setAttribute("aria-activedescendant", this.activeOption.id);
64
+ this.activeOption.scrollIntoView({ block: "nearest" });
67
65
  }
68
66
  resetActiveElement() {
69
- const activeElement = this.options[this._activeItemIndex];
70
- if (activeElement) {
71
- activeElement.setActive(false);
72
- }
73
- this._activeItemIndex = -1;
67
+ this.activeOption?.setActive(false);
74
68
  this.triggerElement?.removeAttribute("aria-activedescendant");
69
+ this.activeOption = null;
75
70
  }
76
71
  setTriggerAttributes(element) {
77
72
  setAriaComboBoxAttributes(element, ariaRoleOnHost ? this.id : this.overlayId, false);
@@ -87,4 +82,4 @@ let SbbAutocompleteElement = (() => {
87
82
  export {
88
83
  SbbAutocompleteElement
89
84
  };
90
- //# 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 { isSafari } from '../core/dom.js';\nimport { setAriaComboBoxAttributes } from '../core/overlay.js';\nimport type { SbbDividerElement } from '../divider/divider.component.js';\nimport type { SbbOptGroupElement, SbbOptionElement, SbbOptionHintElement } 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 * @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')\nclass SbbAutocompleteElement<T = string> extends SbbAutocompleteBaseElement<T> {\n  public static override readonly role = ariaRoleOnHost ? 'listbox' : null;\n  protected overlayId = `sbb-autocomplete-${++nextId}`;\n  protected panelRole = 'listbox';\n  private _activeItemIndex = -1;\n\n  protected get options(): SbbOptionElement<T>[] {\n    return Array.from(this.querySelectorAll?.<SbbOptionElement<T>>('sbb-option') ?? []);\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('optionselected', (e: Event) => this.onOptionSelected(e));\n  }\n\n  protected syncNegative(): void {\n    this.querySelectorAll?.<SbbDividerElement | SbbOptionHintElement>(\n      'sbb-divider, sbb-option-hint',\n    ).forEach((el) => (el.negative = this.negative));\n\n    this.querySelectorAll?.<SbbOptionElement<T> | 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['selectViaUserInteraction'](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":[],"mappings":";;;;;;AAUA,IAAI,SAAS;AAMb,MAAM,iBAAiB;IAYjB,0BAAsB,MAAA;;0BAD3B,cAAc,kBAAkB,CAAC;;;;oBACe;AAAR,EAAA,mBAAQ,YAA6B;AAAA,IAM5E,IAAc,UAAO;AACnB,aAAO,MAAM,KAAK,KAAK,mBAAwC,YAAY,KAAK,EAAE;AAAA,IACpF;AAAA,IAEA,cAAA;AACE,YAAA;AATQ,WAAA,YAAY,oBAAoB,EAAE,MAAM;AACxC,WAAA,YAAY;AACd,WAAA,mBAAmB;AAQzB,WAAK,mBAAmB,kBAAkB,CAAC,MAAa,KAAK,iBAAiB,CAAC,CAAC;AAAA,IAClF;AAAA,IAEU,eAAY;AACpB,WAAK,mBACH,8BAA8B,EAC9B,QAAQ,CAAC,OAAQ,GAAG,WAAW,KAAK,QAAS;AAE/C,WAAK,mBACH,0BAA0B,EAC1B,QAAQ,CAAC,YAAY,QAAQ,gBAAgB,iBAAiB,KAAK,QAAQ,CAAC;AAAA,IAChF;AAAA,IAEU,+BAA+B,OAAoB;AAC3D,UAAI,KAAK,UAAU,UAAU;AAC3B;AAAA,MACF;AAEA,cAAQ,MAAM,KAAA;AAAA,QACZ,KAAK;AACH,eAAK,MAAA;AACL;AAAA,QAEF,KAAK;AACH,eAAK,iBAAiB,KAAK;AAC3B;AAAA,QAEF,KAAK;AAAA,QACL,KAAK;AACH,eAAK,oBAAoB,KAAK;AAC9B;AAAA,MAAA;AAAA,IAEN;AAAA,IAEU,iBAAiB,OAAoB;AAC7C,YAAM,eAAA;AACN,YAAM,eAAe,KAAK,QAAQ,KAAK,gBAAgB;AAEvD,UAAI,cAAc;AAChB,qBAAa,0BAA0B,EAAE,IAAI;AAAA,MAC/C;AAAA,IACF;AAAA,IAEU,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;AACrF,YAAM,mBAAmB,gBAAgB,IAAI;AAC7C,uBAAiB,UAAU,IAAI;AAC/B,WAAK,gBAAgB,aAAa,yBAAyB,iBAAiB,EAAE;AAC9E,uBAAiB,eAAe,EAAE,OAAO,UAAA,CAAW;AAGpD,YAAM,mBAAmB,gBAAgB,KAAK,gBAAgB;AAC9D,UAAI,kBAAkB;AACpB,yBAAiB,UAAU,KAAK;AAAA,MAClC;AAEA,WAAK,mBAAmB;AAAA,IAC1B;AAAA,IAEU,qBAAkB;AAC1B,YAAM,gBAAgB,KAAK,QAAQ,KAAK,gBAAgB;AAExD,UAAI,eAAe;AACjB,sBAAc,UAAU,KAAK;AAAA,MAC/B;AACA,WAAK,mBAAmB;AACxB,WAAK,gBAAgB,gBAAgB,uBAAuB;AAAA,IAC9D;AAAA,IAEU,qBAAqB,SAAyB;AACtD,gCAA0B,SAAS,iBAAiB,KAAK,KAAK,KAAK,WAAW,KAAK;AAAA,IACrF;AAAA;;AAxFF,iBAAA,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QACkC,GAAA,OAAO,iBAAiB,YAAY,MADhE,kBAAA,YAAA,uBAAA,GAAmC;;;"}
85
+ //# 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 { isSafari } from '../core/dom.js';\nimport { setAriaComboBoxAttributes } from '../core/overlay.js';\nimport type { SbbDividerElement } from '../divider/divider.component.js';\nimport type { SbbOptGroupElement, SbbOptionElement, SbbOptionHintElement } 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 * @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')\nclass SbbAutocompleteElement<T = string> extends SbbAutocompleteBaseElement<T> {\n  public static override readonly role = ariaRoleOnHost ? 'listbox' : null;\n  protected overlayId = `sbb-autocomplete-${++nextId}`;\n  protected panelRole = 'listbox';\n\n  protected get options(): SbbOptionElement<T>[] {\n    return Array.from(this.querySelectorAll?.<SbbOptionElement<T>>('sbb-option') ?? []);\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('optionselected', (e: Event) => this.onOptionSelected(e));\n  }\n\n  protected syncNegative(): void {\n    this.querySelectorAll?.<SbbDividerElement | SbbOptionHintElement>(\n      'sbb-divider, sbb-option-hint',\n    ).forEach((el) => (el.negative = this.negative));\n\n    this.querySelectorAll?.<SbbOptionElement<T> | 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\n    this.activeOption?.['selectViaUserInteraction'](true);\n  }\n\n  protected setNextActiveOption(event?: KeyboardEvent): void {\n    const enabledOptions = this.options.filter(\n      (opt) => !opt.disabled && !opt.hasAttribute('data-group-disabled'),\n    );\n\n    // Reset potentially active option\n    this.activeOption?.setActive(false);\n    this.triggerElement?.removeAttribute('aria-activedescendant');\n\n    if (!enabledOptions.length) {\n      this.activeOption = null;\n      return;\n    }\n\n    const activeItemIndex = this.activeOption\n      ? enabledOptions.indexOf(this.activeOption as SbbOptionElement<T>)\n      : -1;\n\n    // Get and activate the next active option\n    const next = getNextElementIndex(event, activeItemIndex, enabledOptions.length);\n    this.activeOption = enabledOptions[next];\n    this.activeOption.setActive(true);\n    this.triggerElement?.setAttribute('aria-activedescendant', this.activeOption.id);\n    this.activeOption.scrollIntoView({ block: 'nearest' });\n  }\n\n  protected resetActiveElement(): void {\n    this.activeOption?.setActive(false);\n    this.triggerElement?.removeAttribute('aria-activedescendant');\n    this.activeOption = null;\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":[],"mappings":";;;;;;AAUA,IAAI,SAAS;AAMb,MAAM,iBAAiB;IAYjB,0BAAsB,MAAA;;0BAD3B,cAAc,kBAAkB,CAAC;;;;oBACe;AAAR,EAAA,mBAAQ,YAA6B;AAAA,IAK5E,IAAc,UAAO;AACnB,aAAO,MAAM,KAAK,KAAK,mBAAwC,YAAY,KAAK,EAAE;AAAA,IACpF;AAAA,IAEA,cAAA;AACE,YAAA;AARQ,WAAA,YAAY,oBAAoB,EAAE,MAAM;AACxC,WAAA,YAAY;AAQpB,WAAK,mBAAmB,kBAAkB,CAAC,MAAa,KAAK,iBAAiB,CAAC,CAAC;AAAA,IAClF;AAAA,IAEU,eAAY;AACpB,WAAK,mBACH,8BAA8B,EAC9B,QAAQ,CAAC,OAAQ,GAAG,WAAW,KAAK,QAAS;AAE/C,WAAK,mBACH,0BAA0B,EAC1B,QAAQ,CAAC,YAAY,QAAQ,gBAAgB,iBAAiB,KAAK,QAAQ,CAAC;AAAA,IAChF;AAAA,IAEU,+BAA+B,OAAoB;AAC3D,UAAI,KAAK,UAAU,UAAU;AAC3B;AAAA,MACF;AAEA,cAAQ,MAAM,KAAA;AAAA,QACZ,KAAK;AACH,eAAK,MAAA;AACL;AAAA,QAEF,KAAK;AACH,eAAK,iBAAiB,KAAK;AAC3B;AAAA,QAEF,KAAK;AAAA,QACL,KAAK;AACH,eAAK,oBAAoB,KAAK;AAC9B;AAAA,MAAA;AAAA,IAEN;AAAA,IAEU,iBAAiB,OAAoB;AAC7C,YAAM,eAAA;AAEN,WAAK,eAAe,0BAA0B,EAAE,IAAI;AAAA,IACtD;AAAA,IAEU,oBAAoB,OAAqB;AACjD,YAAM,iBAAiB,KAAK,QAAQ,OAClC,CAAC,QAAQ,CAAC,IAAI,YAAY,CAAC,IAAI,aAAa,qBAAqB,CAAC;AAIpE,WAAK,cAAc,UAAU,KAAK;AAClC,WAAK,gBAAgB,gBAAgB,uBAAuB;AAE5D,UAAI,CAAC,eAAe,QAAQ;AAC1B,aAAK,eAAe;AACpB;AAAA,MACF;AAEA,YAAM,kBAAkB,KAAK,eACzB,eAAe,QAAQ,KAAK,YAAmC,IAC/D;AAGJ,YAAM,OAAO,oBAAoB,OAAO,iBAAiB,eAAe,MAAM;AAC9E,WAAK,eAAe,eAAe,IAAI;AACvC,WAAK,aAAa,UAAU,IAAI;AAChC,WAAK,gBAAgB,aAAa,yBAAyB,KAAK,aAAa,EAAE;AAC/E,WAAK,aAAa,eAAe,EAAE,OAAO,WAAW;AAAA,IACvD;AAAA,IAEU,qBAAkB;AAC1B,WAAK,cAAc,UAAU,KAAK;AAClC,WAAK,gBAAgB,gBAAgB,uBAAuB;AAC5D,WAAK,eAAe;AAAA,IACtB;AAAA,IAEU,qBAAqB,SAAyB;AACtD,gCAA0B,SAAS,iBAAiB,KAAK,KAAK,KAAK,WAAW,KAAK;AAAA,IACrF;AAAA;;AArFF,iBAAA,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QACkC,GAAA,OAAO,iBAAiB,YAAY,MADhE,kBAAA,YAAA,uBAAA,GAAmC;;;"}
@@ -12,10 +12,8 @@ export declare class SbbAutocompleteGridElement<T = string> extends SbbAutocompl
12
12
  static readonly role: string | null;
13
13
  protected overlayId: string;
14
14
  protected panelRole: string;
15
- private _activeItemIndex;
16
15
  private _activeColumnIndex;
17
16
  protected get options(): SbbAutocompleteGridOptionElement<T>[];
18
- private get _row();
19
17
  constructor();
20
18
  protected syncNegative(): void;
21
19
  protected openedPanelKeyboardInteraction(event: KeyboardEvent): 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;AAOnE,OAAO,EAAE,gCAAgC,EAAE,MAAM,gCAAgC,CAAC;AAWlF;;;;;;;GAOG;AACH,qBAEM,0BAA0B,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,0BAA0B,CAAC,CAAC,CAAC;IAChF,gBAAgC,IAAI,gBAAkC;IACtE,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,CAAC,CAAC,CAAC,EAAE,CAM7D;IAED,OAAO,KAAK,IAAI,GAMf;;IAOD,SAAS,CAAC,YAAY,IAAI,IAAI;IAY9B,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;IAsCvC,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;AAOnE,OAAO,EAAE,gCAAgC,EAAE,MAAM,gCAAgC,CAAC;AAUlF;;;;;;;GAOG;AACH,qBAEM,0BAA0B,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,0BAA0B,CAAC,CAAC,CAAC;IAChF,gBAAgC,IAAI,gBAAkC;IACtE,SAAS,CAAC,SAAS,SAAuC;IAC1D,SAAS,CAAC,SAAS,SAAU;IAC7B,OAAO,CAAC,kBAAkB,CAAK;IAE/B,SAAS,KAAK,OAAO,IAAI,gCAAgC,CAAC,CAAC,CAAC,EAAE,CAM7D;;IAOD,SAAS,CAAC,YAAY,IAAI,IAAI;IAY9B,SAAS,CAAC,8BAA8B,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IA0BpE;;;;;;OAMG;IACH,SAAS,CAAC,gBAAgB,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAgBtD,SAAS,CAAC,mBAAmB,CAAC,KAAK,CAAC,EAAE,aAAa,GAAG,IAAI;IA8B1D,OAAO,CAAC,+BAA+B;IAqCvC,SAAS,CAAC,kBAAkB,IAAI,IAAI;IAapC,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"}