@sbb-esta/lyne-elements-experimental 4.0.0-next.3 → 4.0.0-next.4

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 (58) hide show
  1. package/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts.map +1 -1
  2. package/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.js +27 -26
  3. package/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.component.d.ts.map +1 -1
  4. package/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.component.js +7 -8
  5. package/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.component.d.ts +1 -1
  6. package/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.component.d.ts.map +1 -1
  7. package/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.component.js +17 -12
  8. package/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.component.d.ts +0 -1
  9. package/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.component.d.ts.map +1 -1
  10. package/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.component.js +19 -20
  11. package/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.component.js +12 -12
  12. package/core/timetable/access-leg-helper.d.ts +5 -5
  13. package/custom-elements.json +379 -422
  14. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts.map +1 -1
  15. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.js +9 -8
  16. package/development/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.component.d.ts.map +1 -1
  17. package/development/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.component.js +5 -5
  18. package/development/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.component.d.ts +1 -1
  19. package/development/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.component.d.ts.map +1 -1
  20. package/development/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.component.js +11 -5
  21. package/development/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.component.d.ts +0 -1
  22. package/development/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.component.d.ts.map +1 -1
  23. package/development/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.component.js +13 -18
  24. package/development/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.component.js +7 -7
  25. package/development/core/timetable/access-leg-helper.d.ts +5 -5
  26. package/development/core/timetable/access-leg-helper.js +1 -1
  27. package/development/seat-reservation/common/mapper/mapper.d.ts +3 -1
  28. package/development/seat-reservation/common/mapper/mapper.d.ts.map +1 -1
  29. package/development/seat-reservation/common/mapper/mapper.js +1 -1
  30. package/development/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts +0 -88
  31. package/development/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts.map +1 -1
  32. package/development/seat-reservation/common/mapper/seat-reservation-sample-data.js +1 -815
  33. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts +4 -4
  34. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -1
  35. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.js +8 -9
  36. package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts +1 -1
  37. package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -1
  38. package/development/seat-reservation/seat-reservation/seat-reservation.component.js +7 -7
  39. package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts +1 -1
  40. package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +6 -6
  41. package/development/timetable-row/timetable-row.component.d.ts.map +1 -1
  42. package/development/timetable-row/timetable-row.component.js +7 -7
  43. package/package.json +2 -2
  44. package/seat-reservation/common/mapper/mapper.d.ts +3 -1
  45. package/seat-reservation/common/mapper/mapper.d.ts.map +1 -1
  46. package/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts +0 -88
  47. package/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts.map +1 -1
  48. package/seat-reservation/common/mapper/seat-reservation-sample-data.js +2 -815
  49. package/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts +4 -4
  50. package/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -1
  51. package/seat-reservation/seat-reservation/seat-reservation-base-element.js +8 -8
  52. package/seat-reservation/seat-reservation/seat-reservation.component.d.ts +1 -1
  53. package/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -1
  54. package/seat-reservation/seat-reservation/seat-reservation.component.js +27 -27
  55. package/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts +1 -1
  56. package/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +1 -1
  57. package/timetable-row/timetable-row.component.d.ts.map +1 -1
  58. package/timetable-row/timetable-row.component.js +18 -18
@@ -1 +1 @@
1
- {"version":3,"file":"autocomplete-grid.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,0BAA0B,EAAE,MAAM,yCAAyC,CAAC;AASrF,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;IA+B1D,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"}
1
+ {"version":3,"file":"autocomplete-grid.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,0BAA0B,EAAE,MAAM,yCAAyC,CAAC;AAUrF,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;IA+B1D,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"}
@@ -2,6 +2,7 @@ import { __esDecorate, __runInitializers } from "tslib";
2
2
  import { SbbAutocompleteBaseElement } from "@sbb-esta/lyne-elements/autocomplete.js";
3
3
  import { getNextElementIndex } from "@sbb-esta/lyne-elements/core/a11y.js";
4
4
  import { isSafari } from "@sbb-esta/lyne-elements/core/dom.js";
5
+ import { ɵstateController as _stateController } from "@sbb-esta/lyne-elements/core/mixins.js";
5
6
  import { setAriaComboBoxAttributes } from "@sbb-esta/lyne-elements/core/overlay.js";
6
7
  import { customElement } from "lit/decorators.js";
7
8
  import { SbbAutocompleteGridOptionElement } from "../autocomplete-grid-option.js";
@@ -27,7 +28,7 @@ let SbbAutocompleteGridElement = (() => {
27
28
  }
28
29
  syncNegative() {
29
30
  this.querySelectorAll?.("sbb-divider, sbb-autocomplete-grid-button, sbb-option-hint").forEach((e) => e.negative = this.negative);
30
- this.querySelectorAll?.("sbb-autocomplete-grid-row, sbb-autocomplete-grid-option, sbb-autocomplete-grid-optgroup").forEach((element) => element.toggleAttribute("data-negative", this.negative));
31
+ this.querySelectorAll?.("sbb-autocomplete-grid-row, sbb-autocomplete-grid-option, sbb-autocomplete-grid-optgroup").forEach((element) => _stateController(element).toggle("negative", this.negative));
31
32
  }
32
33
  openedPanelKeyboardInteraction(event) {
33
34
  if (this.state !== "opened") {
@@ -69,10 +70,10 @@ let SbbAutocompleteGridElement = (() => {
69
70
  }
70
71
  }
71
72
  setNextActiveOption(event) {
72
- const enabledOptions = this.options.filter((opt) => !opt.matches(":state(disabled)"));
73
+ const enabledOptions = this.options.filter((opt) => !opt.matches(":is(:state(disabled),[state--disabled])"));
73
74
  this.activeOption?.setActive(false);
74
75
  this.triggerElement?.removeAttribute("aria-activedescendant");
75
- Array.from(this.querySelectorAll?.("sbb-autocomplete-grid-row [data-focus-visible]") ?? []).forEach((row) => row.removeAttribute("data-focus-visible"));
76
+ Array.from(this.querySelectorAll?.("sbb-autocomplete-grid-row :is(:state(focus-visible),[state--focus-visible])") ?? []).forEach((row) => _stateController(row).delete("focus-visible"));
76
77
  this._activeColumnIndex = 0;
77
78
  if (!enabledOptions.length) {
78
79
  this.activeOption = null;
@@ -92,7 +93,7 @@ let SbbAutocompleteGridElement = (() => {
92
93
  if (!this.activeOption) {
93
94
  return;
94
95
  }
95
- const elementsInRow = Array.from(this.activeOption?.closest("sbb-autocomplete-grid-row")?.querySelectorAll("sbb-autocomplete-grid-option, sbb-autocomplete-grid-button") ?? [])?.filter((el) => !el.matches(":state(disabled)"));
96
+ const elementsInRow = Array.from(this.activeOption?.closest("sbb-autocomplete-grid-row")?.querySelectorAll("sbb-autocomplete-grid-option, sbb-autocomplete-grid-button") ?? [])?.filter((el) => !el.matches(":is(:state(disabled),[state--disabled])"));
96
97
  if (!elementsInRow.length) {
97
98
  return;
98
99
  }
@@ -101,13 +102,13 @@ let SbbAutocompleteGridElement = (() => {
101
102
  if (nextElement instanceof SbbAutocompleteGridOptionElement) {
102
103
  nextElement.setActive(true);
103
104
  } else {
104
- nextElement.toggleAttribute("data-focus-visible", true);
105
+ _stateController(nextElement).add("focus-visible");
105
106
  }
106
107
  const lastActiveElement = elementsInRow[this._activeColumnIndex];
107
108
  if (lastActiveElement instanceof SbbAutocompleteGridOptionElement) {
108
109
  lastActiveElement.setActive(false);
109
110
  } else {
110
- lastActiveElement.toggleAttribute("data-focus-visible", false);
111
+ _stateController(lastActiveElement).delete("focus-visible");
111
112
  }
112
113
  this.triggerElement?.setAttribute("aria-activedescendant", nextElement.id);
113
114
  nextElement.scrollIntoView({ block: "nearest" });
@@ -115,7 +116,7 @@ let SbbAutocompleteGridElement = (() => {
115
116
  }
116
117
  resetActiveElement() {
117
118
  if (this._activeColumnIndex !== 0) {
118
- this.activeOption?.closest("sbb-autocomplete-grid-row")?.querySelectorAll("sbb-autocomplete-grid-button").forEach((e) => e.toggleAttribute("data-focus-visible", false));
119
+ this.activeOption?.closest("sbb-autocomplete-grid-row")?.querySelectorAll("sbb-autocomplete-grid-button").forEach((e) => _stateController(e).delete("focus-visible"));
119
120
  }
120
121
  this.activeOption?.setActive(false);
121
122
  this.activeOption = null;
@@ -136,4 +137,4 @@ let SbbAutocompleteGridElement = (() => {
136
137
  export {
137
138
  SbbAutocompleteGridElement
138
139
  };
139
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"autocomplete-grid.component.js","sources":["../../../../../src/elements-experimental/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.ts"],"sourcesContent":["import { SbbAutocompleteBaseElement } from '@sbb-esta/lyne-elements/autocomplete.js';\nimport { getNextElementIndex } from '@sbb-esta/lyne-elements/core/a11y.js';\nimport { isSafari } from '@sbb-esta/lyne-elements/core/dom.js';\nimport { setAriaComboBoxAttributes } from '@sbb-esta/lyne-elements/core/overlay.js';\nimport type { SbbDividerElement } from '@sbb-esta/lyne-elements/divider.js';\nimport type { SbbOptGroupElement, SbbOptionHintElement } from '@sbb-esta/lyne-elements/option.js';\nimport { customElement } from 'lit/decorators.js';\n\nimport type { SbbAutocompleteGridButtonElement } from '../autocomplete-grid-button.ts';\nimport { SbbAutocompleteGridOptionElement } from '../autocomplete-grid-option.ts';\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 with connected buttons.\n *\n * @slot - Use the unnamed slot to add `sbb-autocomplete-grid-row` or `sbb-autocomplete-grid-optgroup` elements to the `sbb-autocomplete-grid`.\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-grid')\nclass SbbAutocompleteGridElement<T = string> extends SbbAutocompleteBaseElement<T> {\n  public static override readonly role = ariaRoleOnHost ? 'grid' : null;\n  protected overlayId = `sbb-autocomplete-grid-${++nextId}`;\n  protected panelRole = 'grid';\n  private _activeColumnIndex = 0;\n\n  protected get options(): SbbAutocompleteGridOptionElement<T>[] {\n    return Array.from(\n      this.querySelectorAll?.<SbbAutocompleteGridOptionElement<T>>(\n        'sbb-autocomplete-grid-option',\n      ) ?? [],\n    );\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?.<\n      SbbDividerElement | SbbAutocompleteGridButtonElement | SbbOptionHintElement\n    >('sbb-divider, sbb-autocomplete-grid-button, sbb-option-hint').forEach(\n      (e) => (e.negative = this.negative),\n    );\n\n    this.querySelectorAll?.<SbbAutocompleteGridOptionElement<T> | SbbOptGroupElement>(\n      'sbb-autocomplete-grid-row, sbb-autocomplete-grid-option, sbb-autocomplete-grid-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      case 'ArrowRight':\n      case 'ArrowLeft':\n        this._setNextHorizontalActiveElement(event);\n        break;\n    }\n  }\n\n  /**\n   * Select an element on 'Enter' keypress.\n   *\n   * Due to keyboard navigation code, the `_activeColumnIndex` is zero when an option is 'focused'\n   * and greater than zero when a button is 'focused', so asking for `querySelectorAll(...)[this._activeColumnIndex]`\n   * would always return a `SbbAutocompleteGridButtonElement`.\n   */\n  protected selectByKeyboard(event: KeyboardEvent): void {\n    event.preventDefault();\n\n    if (this._activeColumnIndex !== 0) {\n      this.activeOption\n        ?.closest('sbb-autocomplete-grid-row')\n        ?.querySelectorAll('sbb-autocomplete-grid-button')\n        [\n          // We ignore the option in the selector. Therefore, we have to shift the activeColumnIndex by one.\n          this._activeColumnIndex - 1\n        ]?.click();\n    } else {\n      this.activeOption?.['selectViaUserInteraction'](true);\n    }\n  }\n\n  protected setNextActiveOption(event?: KeyboardEvent): void {\n    const enabledOptions = this.options.filter((opt) => !opt.matches(':state(disabled)'));\n\n    // Reset potentially active option\n    this.activeOption?.setActive(false);\n    this.triggerElement?.removeAttribute('aria-activedescendant');\n    Array.from(\n      this.querySelectorAll?.('sbb-autocomplete-grid-row [data-focus-visible]') ?? [],\n    ).forEach((row) => row.removeAttribute('data-focus-visible'));\n    this._activeColumnIndex = 0;\n\n    if (!enabledOptions.length) {\n      this.activeOption = null;\n      return;\n    }\n\n    const activeItemIndex = this.activeOption\n      ? enabledOptions.indexOf(this.activeOption as SbbAutocompleteGridOptionElement<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    if (this.autoSelectActiveOption) {\n      this.onOptionArrowsSelected(this.activeOption);\n    }\n  }\n\n  private _setNextHorizontalActiveElement(event: KeyboardEvent): void {\n    if (!this.activeOption) {\n      return;\n    }\n\n    const elementsInRow = Array.from(\n      this.activeOption\n        ?.closest('sbb-autocomplete-grid-row')\n        ?.querySelectorAll<\n          SbbAutocompleteGridOptionElement<T> | SbbAutocompleteGridButtonElement\n        >('sbb-autocomplete-grid-option, sbb-autocomplete-grid-button') ?? [],\n    )?.filter((el) => !el.matches(':state(disabled)'));\n\n    if (!elementsInRow.length) {\n      return;\n    }\n\n    const next: number = getNextElementIndex(event, this._activeColumnIndex, elementsInRow.length);\n    const nextElement: SbbAutocompleteGridOptionElement<T> | SbbAutocompleteGridButtonElement =\n      elementsInRow[next];\n    if (nextElement instanceof SbbAutocompleteGridOptionElement) {\n      nextElement.setActive(true);\n    } else {\n      nextElement.toggleAttribute('data-focus-visible', true);\n    }\n\n    const lastActiveElement = elementsInRow[this._activeColumnIndex];\n    if (lastActiveElement instanceof SbbAutocompleteGridOptionElement) {\n      lastActiveElement.setActive(false);\n    } else {\n      lastActiveElement.toggleAttribute('data-focus-visible', false);\n    }\n    this.triggerElement?.setAttribute('aria-activedescendant', nextElement.id);\n    nextElement.scrollIntoView({ block: 'nearest' });\n    this._activeColumnIndex = next;\n  }\n\n  protected resetActiveElement(): void {\n    if (this._activeColumnIndex !== 0) {\n      this.activeOption\n        ?.closest('sbb-autocomplete-grid-row')\n        ?.querySelectorAll('sbb-autocomplete-grid-button')\n        .forEach((e) => e.toggleAttribute('data-focus-visible', false));\n    }\n    this.activeOption?.setActive(false);\n    this.activeOption = null;\n    this._activeColumnIndex = 0;\n    this.triggerElement?.removeAttribute('aria-activedescendant');\n  }\n\n  protected setTriggerAttributes(element: HTMLInputElement): void {\n    setAriaComboBoxAttributes(element, ariaRoleOnHost ? this.id : this.overlayId, false, 'grid');\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-autocomplete-grid': SbbAutocompleteGridElement;\n  }\n}\n"],"names":[],"mappings":"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"}
140
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"autocomplete-grid.component.js","sources":["../../../../../src/elements-experimental/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.ts"],"sourcesContent":["import { SbbAutocompleteBaseElement } from '@sbb-esta/lyne-elements/autocomplete.js';\nimport { getNextElementIndex } from '@sbb-esta/lyne-elements/core/a11y.js';\nimport { isSafari } from '@sbb-esta/lyne-elements/core/dom.js';\nimport { ɵstateController } from '@sbb-esta/lyne-elements/core/mixins.js';\nimport { setAriaComboBoxAttributes } from '@sbb-esta/lyne-elements/core/overlay.js';\nimport type { SbbDividerElement } from '@sbb-esta/lyne-elements/divider.js';\nimport type { SbbOptGroupElement, SbbOptionHintElement } from '@sbb-esta/lyne-elements/option.js';\nimport { customElement } from 'lit/decorators.js';\n\nimport type { SbbAutocompleteGridButtonElement } from '../autocomplete-grid-button.ts';\nimport { SbbAutocompleteGridOptionElement } from '../autocomplete-grid-option.ts';\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 with connected buttons.\n *\n * @slot - Use the unnamed slot to add `sbb-autocomplete-grid-row` or `sbb-autocomplete-grid-optgroup` elements to the `sbb-autocomplete-grid`.\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-grid')\nclass SbbAutocompleteGridElement<T = string> extends SbbAutocompleteBaseElement<T> {\n  public static override readonly role = ariaRoleOnHost ? 'grid' : null;\n  protected overlayId = `sbb-autocomplete-grid-${++nextId}`;\n  protected panelRole = 'grid';\n  private _activeColumnIndex = 0;\n\n  protected get options(): SbbAutocompleteGridOptionElement<T>[] {\n    return Array.from(\n      this.querySelectorAll?.<SbbAutocompleteGridOptionElement<T>>(\n        'sbb-autocomplete-grid-option',\n      ) ?? [],\n    );\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?.<\n      SbbDividerElement | SbbAutocompleteGridButtonElement | SbbOptionHintElement\n    >('sbb-divider, sbb-autocomplete-grid-button, sbb-option-hint').forEach(\n      (e) => (e.negative = this.negative),\n    );\n\n    this.querySelectorAll?.<SbbAutocompleteGridOptionElement<T> | SbbOptGroupElement>(\n      'sbb-autocomplete-grid-row, sbb-autocomplete-grid-option, sbb-autocomplete-grid-optgroup',\n    ).forEach((element) => ɵstateController(element).toggle('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      case 'ArrowRight':\n      case 'ArrowLeft':\n        this._setNextHorizontalActiveElement(event);\n        break;\n    }\n  }\n\n  /**\n   * Select an element on 'Enter' keypress.\n   *\n   * Due to keyboard navigation code, the `_activeColumnIndex` is zero when an option is 'focused'\n   * and greater than zero when a button is 'focused', so asking for `querySelectorAll(...)[this._activeColumnIndex]`\n   * would always return a `SbbAutocompleteGridButtonElement`.\n   */\n  protected selectByKeyboard(event: KeyboardEvent): void {\n    event.preventDefault();\n\n    if (this._activeColumnIndex !== 0) {\n      this.activeOption\n        ?.closest('sbb-autocomplete-grid-row')\n        ?.querySelectorAll('sbb-autocomplete-grid-button')\n        [\n          // We ignore the option in the selector. Therefore, we have to shift the activeColumnIndex by one.\n          this._activeColumnIndex - 1\n        ]?.click();\n    } else {\n      this.activeOption?.['selectViaUserInteraction'](true);\n    }\n  }\n\n  protected setNextActiveOption(event?: KeyboardEvent): void {\n    const enabledOptions = this.options.filter((opt) => !opt.matches(':state(disabled)'));\n\n    // Reset potentially active option\n    this.activeOption?.setActive(false);\n    this.triggerElement?.removeAttribute('aria-activedescendant');\n    Array.from(\n      this.querySelectorAll?.('sbb-autocomplete-grid-row :state(focus-visible)') ?? [],\n    ).forEach((row) => ɵstateController(row).delete('focus-visible'));\n    this._activeColumnIndex = 0;\n\n    if (!enabledOptions.length) {\n      this.activeOption = null;\n      return;\n    }\n\n    const activeItemIndex = this.activeOption\n      ? enabledOptions.indexOf(this.activeOption as SbbAutocompleteGridOptionElement<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    if (this.autoSelectActiveOption) {\n      this.onOptionArrowsSelected(this.activeOption);\n    }\n  }\n\n  private _setNextHorizontalActiveElement(event: KeyboardEvent): void {\n    if (!this.activeOption) {\n      return;\n    }\n\n    const elementsInRow = Array.from(\n      this.activeOption\n        ?.closest('sbb-autocomplete-grid-row')\n        ?.querySelectorAll<\n          SbbAutocompleteGridOptionElement<T> | SbbAutocompleteGridButtonElement\n        >('sbb-autocomplete-grid-option, sbb-autocomplete-grid-button') ?? [],\n    )?.filter((el) => !el.matches(':state(disabled)'));\n\n    if (!elementsInRow.length) {\n      return;\n    }\n\n    const next: number = getNextElementIndex(event, this._activeColumnIndex, elementsInRow.length);\n    const nextElement: SbbAutocompleteGridOptionElement<T> | SbbAutocompleteGridButtonElement =\n      elementsInRow[next];\n    if (nextElement instanceof SbbAutocompleteGridOptionElement) {\n      nextElement.setActive(true);\n    } else {\n      ɵstateController(nextElement).add('focus-visible');\n    }\n\n    const lastActiveElement = elementsInRow[this._activeColumnIndex];\n    if (lastActiveElement instanceof SbbAutocompleteGridOptionElement) {\n      lastActiveElement.setActive(false);\n    } else {\n      ɵstateController(lastActiveElement).delete('focus-visible');\n    }\n    this.triggerElement?.setAttribute('aria-activedescendant', nextElement.id);\n    nextElement.scrollIntoView({ block: 'nearest' });\n    this._activeColumnIndex = next;\n  }\n\n  protected resetActiveElement(): void {\n    if (this._activeColumnIndex !== 0) {\n      this.activeOption\n        ?.closest('sbb-autocomplete-grid-row')\n        ?.querySelectorAll('sbb-autocomplete-grid-button')\n        .forEach((e) => ɵstateController(e).delete('focus-visible'));\n    }\n    this.activeOption?.setActive(false);\n    this.activeOption = null;\n    this._activeColumnIndex = 0;\n    this.triggerElement?.removeAttribute('aria-activedescendant');\n  }\n\n  protected setTriggerAttributes(element: HTMLInputElement): void {\n    setAriaComboBoxAttributes(element, ariaRoleOnHost ? this.id : this.overlayId, false, 'grid');\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-autocomplete-grid': SbbAutocompleteGridElement;\n  }\n}\n"],"names":["ɵstateController"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"autocomplete-grid-button.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.component.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,+CAA+C,CAAC;AAOrF,OAAO,EAAE,KAAK,cAAc,EAAY,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAG9F,OAAO,KAAK,EAAE,kCAAkC,EAAE,MAAM,kCAAkC,CAAC;AAC3F,OAAO,KAAK,EAAE,gCAAgC,EAAE,MAAM,gCAAgC,CAAC;;AAIvF;;;;GAIG;AACH,qBAMM,gCAAiC,SAAQ,qCAE9C;IACC,gBAAgC,IAAI,YAAY;IAChD,OAAuB,MAAM,EAAE,cAAc,CAAsC;IAEnF,+EAA+E;IAC/E,IAAW,MAAM,IAAI,gCAAgC,GAAG,IAAI,CAK3D;IAED,IAAW,QAAQ,IAAI,kCAAkC,GAAG,IAAI,CAE/D;;cAmBkB,oBAAoB,IAAI,OAAO;cAI/B,cAAc,IAAI,cAAc;IAInC,iBAAiB,IAAI,IAAI;cAKtB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO5E,OAAO,CAAC,gBAAgB;IAUxB,OAAO,CAAC,kBAAkB,CAIxB;CACH;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,8BAA8B,EAAE,gCAAgC,CAAC;KAClE;CACF"}
1
+ {"version":3,"file":"autocomplete-grid-button.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.component.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,+CAA+C,CAAC;AAOrF,OAAO,EAAE,KAAK,cAAc,EAAY,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAG9F,OAAO,KAAK,EAAE,kCAAkC,EAAE,MAAM,kCAAkC,CAAC;AAC3F,OAAO,KAAK,EAAE,gCAAgC,EAAE,MAAM,gCAAgC,CAAC;;AAIvF;;;;GAIG;AACH,qBAKM,gCAAiC,SAAQ,qCAE9C;IACC,gBAAgC,IAAI,YAAY;IAChD,OAAuB,MAAM,EAAE,cAAc,CAAsC;IAEnF,+EAA+E;IAC/E,IAAW,MAAM,IAAI,gCAAgC,GAAG,IAAI,CAK3D;IAED,IAAW,QAAQ,IAAI,kCAAkC,GAAG,IAAI,CAE/D;;cAoBkB,oBAAoB,IAAI,OAAO;cAI/B,cAAc,IAAI,cAAc;IAInC,iBAAiB,IAAI,IAAI;cAKtB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO5E,OAAO,CAAC,gBAAgB;IAUxB,OAAO,CAAC,kBAAkB,CAIxB;CACH;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,8BAA8B,EAAE,gCAAgC,CAAC;KAClE;CACF"}
@@ -1,7 +1,7 @@
1
1
  import { __esDecorate, __runInitializers } from "tslib";
2
2
  import { miniButtonStyle } from "@sbb-esta/lyne-elements/button/common.js";
3
3
  import { SbbActionBaseElement } from "@sbb-esta/lyne-elements/core/base-elements.js";
4
- import { SbbAncestorWatcherController } from "@sbb-esta/lyne-elements/core/controllers.js";
4
+ import { SbbPropertyWatcherController } from "@sbb-esta/lyne-elements/core/controllers.js";
5
5
  import { hostAttributes } from "@sbb-esta/lyne-elements/core/decorators.js";
6
6
  import { isEventPrevented } from "@sbb-esta/lyne-elements/core/eventing.js";
7
7
  import { SbbDisabledMixin, SbbNegativeMixin } from "@sbb-esta/lyne-elements/core/mixins.js";
@@ -13,8 +13,7 @@ let autocompleteButtonNextId = 0;
13
13
  let SbbAutocompleteGridButtonElement = (() => {
14
14
  var _a;
15
15
  let _classDecorators = [customElement("sbb-autocomplete-grid-button"), hostAttributes({
16
- tabindex: null,
17
- "data-button": ""
16
+ tabindex: null
18
17
  })];
19
18
  let _classDescriptor;
20
19
  let _classExtraInitializers = [];
@@ -35,10 +34,11 @@ let SbbAutocompleteGridButtonElement = (() => {
35
34
  return;
36
35
  }
37
36
  };
37
+ this.internals.states.add("button");
38
38
  if (!isServer) {
39
39
  this.setupBaseEventHandlers();
40
40
  this.addEventListener("click", this._handleButtonClick);
41
- this.addController(new SbbAncestorWatcherController(this, () => this.closest("sbb-autocomplete-grid-optgroup"), {
41
+ this.addController(new SbbPropertyWatcherController(this, () => this.closest("sbb-autocomplete-grid-optgroup"), {
42
42
  disabled: () => this._updateInternals()
43
43
  }));
44
44
  }
@@ -79,4 +79,4 @@ let SbbAutocompleteGridButtonElement = (() => {
79
79
  export {
80
80
  SbbAutocompleteGridButtonElement
81
81
  };
82
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLWdyaWQtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzLWV4cGVyaW1lbnRhbC9hdXRvY29tcGxldGUtZ3JpZC9hdXRvY29tcGxldGUtZ3JpZC1idXR0b24vYXV0b2NvbXBsZXRlLWdyaWQtYnV0dG9uLmNvbXBvbmVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBtaW5pQnV0dG9uU3R5bGUgfSBmcm9tICdAc2JiLWVzdGEvbHluZS1lbGVtZW50cy9idXR0b24vY29tbW9uLmpzJztcbmltcG9ydCB7IFNiYkFjdGlvbkJhc2VFbGVtZW50IH0gZnJvbSAnQHNiYi1lc3RhL2x5bmUtZWxlbWVudHMvY29yZS9iYXNlLWVsZW1lbnRzLmpzJztcbmltcG9ydCB7IFNiYkFuY2VzdG9yV2F0Y2hlckNvbnRyb2xsZXIgfSBmcm9tICdAc2JiLWVzdGEvbHluZS1lbGVtZW50cy9jb3JlL2NvbnRyb2xsZXJzLmpzJztcbmltcG9ydCB7IGhvc3RBdHRyaWJ1dGVzIH0gZnJvbSAnQHNiYi1lc3RhL2x5bmUtZWxlbWVudHMvY29yZS9kZWNvcmF0b3JzLmpzJztcbmltcG9ydCB7IGlzRXZlbnRQcmV2ZW50ZWQgfSBmcm9tICdAc2JiLWVzdGEvbHluZS1lbGVtZW50cy9jb3JlL2V2ZW50aW5nLmpzJztcbmltcG9ydCB7IFNiYkRpc2FibGVkTWl4aW4sIFNiYk5lZ2F0aXZlTWl4aW4gfSBmcm9tICdAc2JiLWVzdGEvbHluZS1lbGVtZW50cy9jb3JlL21peGlucy5qcyc7XG5pbXBvcnQgeyBib3hTaXppbmdTdHlsZXMgfSBmcm9tICdAc2JiLWVzdGEvbHluZS1lbGVtZW50cy9jb3JlL3N0eWxlcy5qcyc7XG5pbXBvcnQgeyBTYmJJY29uTmFtZU1peGluIH0gZnJvbSAnQHNiYi1lc3RhL2x5bmUtZWxlbWVudHMvaWNvbi5qcyc7XG5pbXBvcnQgeyB0eXBlIENTU1Jlc3VsdEdyb3VwLCBpc1NlcnZlciwgdHlwZSBQcm9wZXJ0eVZhbHVlcywgdHlwZSBUZW1wbGF0ZVJlc3VsdCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgdHlwZSB7IFNiYkF1dG9jb21wbGV0ZUdyaWRPcHRncm91cEVsZW1lbnQgfSBmcm9tICcuLi9hdXRvY29tcGxldGUtZ3JpZC1vcHRncm91cC50cyc7XG5pbXBvcnQgdHlwZSB7IFNiYkF1dG9jb21wbGV0ZUdyaWRPcHRpb25FbGVtZW50IH0gZnJvbSAnLi4vYXV0b2NvbXBsZXRlLWdyaWQtb3B0aW9uLnRzJztcblxubGV0IGF1dG9jb21wbGV0ZUJ1dHRvbk5leHRJZCA9IDA7XG5cbi8qKlxuICogSXQgZGlzcGxheXMgYW4gaWNvbi1vbmx5IGJ1dHRvbiB0aGF0IGNhbiBiZSB1c2VkIGluIGBzYmItYXV0b2NvbXBsZXRlLWdyaWRgLlxuICpcbiAqIEBzbG90IGljb24gLSBTbG90IHVzZWQgdG8gZGlzcGxheSB0aGUgaWNvbiwgaWYgb25lIGlzIHNldFxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItYXV0b2NvbXBsZXRlLWdyaWQtYnV0dG9uJylcbkBob3N0QXR0cmlidXRlcyh7XG4gIHRhYmluZGV4OiBudWxsLFxuICAnZGF0YS1idXR0b24nOiAnJyxcbn0pXG5jbGFzcyBTYmJBdXRvY29tcGxldGVHcmlkQnV0dG9uRWxlbWVudCBleHRlbmRzIFNiYkRpc2FibGVkTWl4aW4oXG4gIFNiYk5lZ2F0aXZlTWl4aW4oU2JiSWNvbk5hbWVNaXhpbihTYmJBY3Rpb25CYXNlRWxlbWVudCkpLFxuKSB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgcmVhZG9ubHkgcm9sZSA9ICdidXR0b24nO1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHN0eWxlczogQ1NTUmVzdWx0R3JvdXAgPSBbYm94U2l6aW5nU3R5bGVzLCBtaW5pQnV0dG9uU3R5bGVdO1xuXG4gIC8qKiBHZXRzIHRoZSBTYmJBdXRvY29tcGxldGVHcmlkT3B0aW9uRWxlbWVudCBvbiB0aGUgc2FtZSByb3cgb2YgdGhlIGJ1dHRvbi4gKi9cbiAgcHVibGljIGdldCBvcHRpb24oKTogU2JiQXV0b2NvbXBsZXRlR3JpZE9wdGlvbkVsZW1lbnQgfCBudWxsIHtcbiAgICByZXR1cm4gKFxuICAgICAgdGhpcy5jbG9zZXN0KCdzYmItYXV0b2NvbXBsZXRlLWdyaWQtcm93Jyk/LnF1ZXJ5U2VsZWN0b3IoJ3NiYi1hdXRvY29tcGxldGUtZ3JpZC1vcHRpb24nKSB8fFxuICAgICAgbnVsbFxuICAgICk7XG4gIH1cblxuICBwdWJsaWMgZ2V0IG9wdGdyb3VwKCk6IFNiYkF1dG9jb21wbGV0ZUdyaWRPcHRncm91cEVsZW1lbnQgfCBudWxsIHtcbiAgICByZXR1cm4gdGhpcy5jbG9zZXN0KCdzYmItYXV0b2NvbXBsZXRlLWdyaWQtb3B0Z3JvdXAnKTtcbiAgfVxuXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuICAgIGlmICghaXNTZXJ2ZXIpIHtcbiAgICAgIHRoaXMuc2V0dXBCYXNlRXZlbnRIYW5kbGVycygpO1xuICAgICAgdGhpcy5hZGRFdmVudExpc3RlbmVyKCdjbGljaycsIHRoaXMuX2hhbmRsZUJ1dHRvbkNsaWNrKTtcbiAgICAgIHRoaXMuYWRkQ29udHJvbGxlcihcbiAgICAgICAgbmV3IFNiYkFuY2VzdG9yV2F0Y2hlckNvbnRyb2xsZXIoXG4gICAgICAgICAgdGhpcyxcbiAgICAgICAgICAoKSA9PiB0aGlzLmNsb3Nlc3QoJ3NiYi1hdXRvY29tcGxldGUtZ3JpZC1vcHRncm91cCcpLFxuICAgICAgICAgIHtcbiAgICAgICAgICAgIGRpc2FibGVkOiAoKSA9PiB0aGlzLl91cGRhdGVJbnRlcm5hbHMoKSxcbiAgICAgICAgICB9LFxuICAgICAgICApLFxuICAgICAgKTtcbiAgICB9XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgaXNEaXNhYmxlZEV4dGVybmFsbHkoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMub3B0Z3JvdXA/LmRpc2FibGVkID8/IGZhbHNlO1xuICB9XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlclRlbXBsYXRlKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gc3VwZXIucmVuZGVySWNvblNsb3QoKTtcbiAgfVxuXG4gIHB1YmxpYyBvdmVycmlkZSBjb25uZWN0ZWRDYWxsYmFjaygpOiB2b2lkIHtcbiAgICBzdXBlci5jb25uZWN0ZWRDYWxsYmFjaygpO1xuICAgIHRoaXMuaWQgfHw9IGBzYmItYXV0b2NvbXBsZXRlLWdyaWQtYnV0dG9uLSR7KythdXRvY29tcGxldGVCdXR0b25OZXh0SWR9YDtcbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSB3aWxsVXBkYXRlKGNoYW5nZWRQcm9wZXJ0aWVzOiBQcm9wZXJ0eVZhbHVlczx0aGlzPik6IHZvaWQge1xuICAgIHN1cGVyLndpbGxVcGRhdGUoY2hhbmdlZFByb3BlcnRpZXMpO1xuICAgIGlmIChjaGFuZ2VkUHJvcGVydGllcy5oYXMoJ2Rpc2FibGVkJykpIHtcbiAgICAgIHRoaXMuX3VwZGF0ZUludGVybmFscygpO1xuICAgIH1cbiAgfVxuXG4gIHByaXZhdGUgX3VwZGF0ZUludGVybmFscygpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5kaXNhYmxlZCB8fCB0aGlzLm9wdGdyb3VwPy5kaXNhYmxlZCkge1xuICAgICAgdGhpcy5pbnRlcm5hbHMuc3RhdGVzLmFkZCgnZGlzYWJsZWQnKTtcbiAgICAgIHRoaXMuaW50ZXJuYWxzLmFyaWFEaXNhYmxlZCA9ICd0cnVlJztcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5pbnRlcm5hbHMuc3RhdGVzLmRlbGV0ZSgnZGlzYWJsZWQnKTtcbiAgICAgIHRoaXMuaW50ZXJuYWxzLmFyaWFEaXNhYmxlZCA9IG51bGw7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBfaGFuZGxlQnV0dG9uQ2xpY2sgPSBhc3luYyAoZXZlbnQ6IE1vdXNlRXZlbnQpOiBQcm9taXNlPHZvaWQ+ID0+IHtcbiAgICBpZiAoKGF3YWl0IGlzRXZlbnRQcmV2ZW50ZWQoZXZlbnQpKSB8fCAhdGhpcy5jbG9zZXN0KCdmb3JtJykpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gIH07XG59XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgaW50ZXJmYWNlIEhUTUxFbGVtZW50VGFnTmFtZU1hcCB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuICAgICdzYmItYXV0b2NvbXBsZXRlLWdyaWQtYnV0dG9uJzogU2JiQXV0b2NvbXBsZXRlR3JpZEJ1dHRvbkVsZW1lbnQ7XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQWNBLElBQUksMkJBQTJCO0lBYXpCLG9DQUFnQyxNQUFBOztBQUxyQyxNQUFBLG1CQUFBLENBQUEsY0FBYyw4QkFBOEIsR0FDNUMsZUFBZTtBQUFBLElBQ2QsVUFBVTtBQUFBLElBQ1YsZUFBZTtBQUFBLEVBQUEsQ0FDaEIsQ0FBQzs7OztvQkFDNkMsaUJBQzdDLGlCQUFpQixpQkFBaUIsb0JBQW9CLENBQUMsQ0FBQztBQURuQixFQUFBLG1CQUFRLFlBRTlDO0FBQUE7QUFBQSxJQUtDLElBQVcsU0FBTTtBQUNmLGFBQ0UsS0FBSyxRQUFRLDJCQUEyQixHQUFHLGNBQWMsOEJBQThCLEtBQ3ZGO0FBQUEsSUFFSjtBQUFBLElBRUEsSUFBVyxXQUFRO0FBQ2pCLGFBQU8sS0FBSyxRQUFRLGdDQUFnQztBQUFBLElBQ3REO0FBQUEsSUFFQSxjQUFBO0FBQ0UsWUFBQTtBQThDTSxXQUFBLHFCQUFxQixPQUFPLFVBQW9DO0FBQ3RFLFlBQUssTUFBTSxpQkFBaUIsS0FBSyxLQUFNLENBQUMsS0FBSyxRQUFRLE1BQU0sR0FBRztBQUM1RDtBQUFBLFFBQ0Y7QUFBQSxNQUNGO0FBakRFLFVBQUksQ0FBQyxVQUFVO0FBQ2IsYUFBSyx1QkFBQTtBQUNMLGFBQUssaUJBQWlCLFNBQVMsS0FBSyxrQkFBa0I7QUFDdEQsYUFBSyxjQUNILElBQUksNkJBQ0YsTUFDQSxNQUFNLEtBQUssUUFBUSxnQ0FBZ0MsR0FDbkQ7QUFBQSxVQUNFLFVBQVUsTUFBTSxLQUFLLGlCQUFBO0FBQUEsUUFBZ0IsQ0FDdEMsQ0FDRjtBQUFBLE1BRUw7QUFBQSxJQUNGO0FBQUEsSUFFbUIsdUJBQW9CO0FBQ3JDLGFBQU8sS0FBSyxVQUFVLFlBQVk7QUFBQSxJQUNwQztBQUFBLElBRW1CLGlCQUFjO0FBQy9CLGFBQU8sTUFBTSxlQUFBO0FBQUEsSUFDZjtBQUFBLElBRWdCLG9CQUFpQjtBQUMvQixZQUFNLGtCQUFBO0FBQ04sV0FBSyxPQUFPLGdDQUFnQyxFQUFFLHdCQUF3QjtBQUFBLElBQ3hFO0FBQUEsSUFFbUIsV0FBVyxtQkFBdUM7QUFDbkUsWUFBTSxXQUFXLGlCQUFpQjtBQUNsQyxVQUFJLGtCQUFrQixJQUFJLFVBQVUsR0FBRztBQUNyQyxhQUFLLGlCQUFBO0FBQUEsTUFDUDtBQUFBLElBQ0Y7QUFBQSxJQUVRLG1CQUFnQjtBQUN0QixVQUFJLEtBQUssWUFBWSxLQUFLLFVBQVUsVUFBVTtBQUM1QyxhQUFLLFVBQVUsT0FBTyxJQUFJLFVBQVU7QUFDcEMsYUFBSyxVQUFVLGVBQWU7QUFBQSxNQUNoQyxPQUFPO0FBQ0wsYUFBSyxVQUFVLE9BQU8sT0FBTyxVQUFVO0FBQ3ZDLGFBQUssVUFBVSxlQUFlO0FBQUEsTUFDaEM7QUFBQSxJQUNGO0FBQUE7O0FBL0RGLGlCQUFBLE1BQUEsbUJBQUEsRUFBQSxPQUFBLFdBQUEsR0FBQSxrQkFBQSxFQUFBLE1BQUEsU0FBQSxNQUFBLFdBQUEsTUFBQSxVQUFBLFVBQUEsR0FBQSxNQUFBLHVCQUFBOzs7UUFHa0MsR0FBQSxPQUFPLFVBQ2hCLEdBQUEsU0FBeUIsQ0FBQyxpQkFBaUIsZUFBZSxHQUo3RSxrQkFBQSxZQUFBLHVCQUFBLEdBQWlDOzs7In0=
82
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLWdyaWQtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzLWV4cGVyaW1lbnRhbC9hdXRvY29tcGxldGUtZ3JpZC9hdXRvY29tcGxldGUtZ3JpZC1idXR0b24vYXV0b2NvbXBsZXRlLWdyaWQtYnV0dG9uLmNvbXBvbmVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBtaW5pQnV0dG9uU3R5bGUgfSBmcm9tICdAc2JiLWVzdGEvbHluZS1lbGVtZW50cy9idXR0b24vY29tbW9uLmpzJztcbmltcG9ydCB7IFNiYkFjdGlvbkJhc2VFbGVtZW50IH0gZnJvbSAnQHNiYi1lc3RhL2x5bmUtZWxlbWVudHMvY29yZS9iYXNlLWVsZW1lbnRzLmpzJztcbmltcG9ydCB7IFNiYlByb3BlcnR5V2F0Y2hlckNvbnRyb2xsZXIgfSBmcm9tICdAc2JiLWVzdGEvbHluZS1lbGVtZW50cy9jb3JlL2NvbnRyb2xsZXJzLmpzJztcbmltcG9ydCB7IGhvc3RBdHRyaWJ1dGVzIH0gZnJvbSAnQHNiYi1lc3RhL2x5bmUtZWxlbWVudHMvY29yZS9kZWNvcmF0b3JzLmpzJztcbmltcG9ydCB7IGlzRXZlbnRQcmV2ZW50ZWQgfSBmcm9tICdAc2JiLWVzdGEvbHluZS1lbGVtZW50cy9jb3JlL2V2ZW50aW5nLmpzJztcbmltcG9ydCB7IFNiYkRpc2FibGVkTWl4aW4sIFNiYk5lZ2F0aXZlTWl4aW4gfSBmcm9tICdAc2JiLWVzdGEvbHluZS1lbGVtZW50cy9jb3JlL21peGlucy5qcyc7XG5pbXBvcnQgeyBib3hTaXppbmdTdHlsZXMgfSBmcm9tICdAc2JiLWVzdGEvbHluZS1lbGVtZW50cy9jb3JlL3N0eWxlcy5qcyc7XG5pbXBvcnQgeyBTYmJJY29uTmFtZU1peGluIH0gZnJvbSAnQHNiYi1lc3RhL2x5bmUtZWxlbWVudHMvaWNvbi5qcyc7XG5pbXBvcnQgeyB0eXBlIENTU1Jlc3VsdEdyb3VwLCBpc1NlcnZlciwgdHlwZSBQcm9wZXJ0eVZhbHVlcywgdHlwZSBUZW1wbGF0ZVJlc3VsdCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgdHlwZSB7IFNiYkF1dG9jb21wbGV0ZUdyaWRPcHRncm91cEVsZW1lbnQgfSBmcm9tICcuLi9hdXRvY29tcGxldGUtZ3JpZC1vcHRncm91cC50cyc7XG5pbXBvcnQgdHlwZSB7IFNiYkF1dG9jb21wbGV0ZUdyaWRPcHRpb25FbGVtZW50IH0gZnJvbSAnLi4vYXV0b2NvbXBsZXRlLWdyaWQtb3B0aW9uLnRzJztcblxubGV0IGF1dG9jb21wbGV0ZUJ1dHRvbk5leHRJZCA9IDA7XG5cbi8qKlxuICogSXQgZGlzcGxheXMgYW4gaWNvbi1vbmx5IGJ1dHRvbiB0aGF0IGNhbiBiZSB1c2VkIGluIGBzYmItYXV0b2NvbXBsZXRlLWdyaWRgLlxuICpcbiAqIEBzbG90IGljb24gLSBTbG90IHVzZWQgdG8gZGlzcGxheSB0aGUgaWNvbiwgaWYgb25lIGlzIHNldFxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItYXV0b2NvbXBsZXRlLWdyaWQtYnV0dG9uJylcbkBob3N0QXR0cmlidXRlcyh7XG4gIHRhYmluZGV4OiBudWxsLFxufSlcbmNsYXNzIFNiYkF1dG9jb21wbGV0ZUdyaWRCdXR0b25FbGVtZW50IGV4dGVuZHMgU2JiRGlzYWJsZWRNaXhpbihcbiAgU2JiTmVnYXRpdmVNaXhpbihTYmJJY29uTmFtZU1peGluKFNiYkFjdGlvbkJhc2VFbGVtZW50KSksXG4pIHtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSByZWFkb25seSByb2xlID0gJ2J1dHRvbic7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IFtib3hTaXppbmdTdHlsZXMsIG1pbmlCdXR0b25TdHlsZV07XG5cbiAgLyoqIEdldHMgdGhlIFNiYkF1dG9jb21wbGV0ZUdyaWRPcHRpb25FbGVtZW50IG9uIHRoZSBzYW1lIHJvdyBvZiB0aGUgYnV0dG9uLiAqL1xuICBwdWJsaWMgZ2V0IG9wdGlvbigpOiBTYmJBdXRvY29tcGxldGVHcmlkT3B0aW9uRWxlbWVudCB8IG51bGwge1xuICAgIHJldHVybiAoXG4gICAgICB0aGlzLmNsb3Nlc3QoJ3NiYi1hdXRvY29tcGxldGUtZ3JpZC1yb3cnKT8ucXVlcnlTZWxlY3Rvcignc2JiLWF1dG9jb21wbGV0ZS1ncmlkLW9wdGlvbicpIHx8XG4gICAgICBudWxsXG4gICAgKTtcbiAgfVxuXG4gIHB1YmxpYyBnZXQgb3B0Z3JvdXAoKTogU2JiQXV0b2NvbXBsZXRlR3JpZE9wdGdyb3VwRWxlbWVudCB8IG51bGwge1xuICAgIHJldHVybiB0aGlzLmNsb3Nlc3QoJ3NiYi1hdXRvY29tcGxldGUtZ3JpZC1vcHRncm91cCcpO1xuICB9XG5cbiAgcHVibGljIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKCk7XG4gICAgdGhpcy5pbnRlcm5hbHMuc3RhdGVzLmFkZCgnYnV0dG9uJyk7XG4gICAgaWYgKCFpc1NlcnZlcikge1xuICAgICAgdGhpcy5zZXR1cEJhc2VFdmVudEhhbmRsZXJzKCk7XG4gICAgICB0aGlzLmFkZEV2ZW50TGlzdGVuZXIoJ2NsaWNrJywgdGhpcy5faGFuZGxlQnV0dG9uQ2xpY2spO1xuICAgICAgdGhpcy5hZGRDb250cm9sbGVyKFxuICAgICAgICBuZXcgU2JiUHJvcGVydHlXYXRjaGVyQ29udHJvbGxlcihcbiAgICAgICAgICB0aGlzLFxuICAgICAgICAgICgpID0+IHRoaXMuY2xvc2VzdCgnc2JiLWF1dG9jb21wbGV0ZS1ncmlkLW9wdGdyb3VwJyksXG4gICAgICAgICAge1xuICAgICAgICAgICAgZGlzYWJsZWQ6ICgpID0+IHRoaXMuX3VwZGF0ZUludGVybmFscygpLFxuICAgICAgICAgIH0sXG4gICAgICAgICksXG4gICAgICApO1xuICAgIH1cbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSBpc0Rpc2FibGVkRXh0ZXJuYWxseSgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5vcHRncm91cD8uZGlzYWJsZWQgPz8gZmFsc2U7XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyVGVtcGxhdGUoKTogVGVtcGxhdGVSZXN1bHQge1xuICAgIHJldHVybiBzdXBlci5yZW5kZXJJY29uU2xvdCgpO1xuICB9XG5cbiAgcHVibGljIG92ZXJyaWRlIGNvbm5lY3RlZENhbGxiYWNrKCk6IHZvaWQge1xuICAgIHN1cGVyLmNvbm5lY3RlZENhbGxiYWNrKCk7XG4gICAgdGhpcy5pZCB8fD0gYHNiYi1hdXRvY29tcGxldGUtZ3JpZC1idXR0b24tJHsrK2F1dG9jb21wbGV0ZUJ1dHRvbk5leHRJZH1gO1xuICB9XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHdpbGxVcGRhdGUoY2hhbmdlZFByb3BlcnRpZXM6IFByb3BlcnR5VmFsdWVzPHRoaXM+KTogdm9pZCB7XG4gICAgc3VwZXIud2lsbFVwZGF0ZShjaGFuZ2VkUHJvcGVydGllcyk7XG4gICAgaWYgKGNoYW5nZWRQcm9wZXJ0aWVzLmhhcygnZGlzYWJsZWQnKSkge1xuICAgICAgdGhpcy5fdXBkYXRlSW50ZXJuYWxzKCk7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBfdXBkYXRlSW50ZXJuYWxzKCk6IHZvaWQge1xuICAgIGlmICh0aGlzLmRpc2FibGVkIHx8IHRoaXMub3B0Z3JvdXA/LmRpc2FibGVkKSB7XG4gICAgICB0aGlzLmludGVybmFscy5zdGF0ZXMuYWRkKCdkaXNhYmxlZCcpO1xuICAgICAgdGhpcy5pbnRlcm5hbHMuYXJpYURpc2FibGVkID0gJ3RydWUnO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLmludGVybmFscy5zdGF0ZXMuZGVsZXRlKCdkaXNhYmxlZCcpO1xuICAgICAgdGhpcy5pbnRlcm5hbHMuYXJpYURpc2FibGVkID0gbnVsbDtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIF9oYW5kbGVCdXR0b25DbGljayA9IGFzeW5jIChldmVudDogTW91c2VFdmVudCk6IFByb21pc2U8dm9pZD4gPT4ge1xuICAgIGlmICgoYXdhaXQgaXNFdmVudFByZXZlbnRlZChldmVudCkpIHx8ICF0aGlzLmNsb3Nlc3QoJ2Zvcm0nKSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgfTtcbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi1hdXRvY29tcGxldGUtZ3JpZC1idXR0b24nOiBTYmJBdXRvY29tcGxldGVHcmlkQnV0dG9uRWxlbWVudDtcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBY0EsSUFBSSwyQkFBMkI7SUFZekIsb0NBQWdDLE1BQUE7O0FBSnJDLE1BQUEsbUJBQUEsQ0FBQSxjQUFjLDhCQUE4QixHQUM1QyxlQUFlO0FBQUEsSUFDZCxVQUFVO0FBQUEsRUFBQSxDQUNYLENBQUM7Ozs7b0JBQzZDLGlCQUM3QyxpQkFBaUIsaUJBQWlCLG9CQUFvQixDQUFDLENBQUM7QUFEbkIsRUFBQSxtQkFBUSxZQUU5QztBQUFBO0FBQUEsSUFLQyxJQUFXLFNBQU07QUFDZixhQUNFLEtBQUssUUFBUSwyQkFBMkIsR0FBRyxjQUFjLDhCQUE4QixLQUN2RjtBQUFBLElBRUo7QUFBQSxJQUVBLElBQVcsV0FBUTtBQUNqQixhQUFPLEtBQUssUUFBUSxnQ0FBZ0M7QUFBQSxJQUN0RDtBQUFBLElBRUEsY0FBQTtBQUNFLFlBQUE7QUErQ00sV0FBQSxxQkFBcUIsT0FBTyxVQUFvQztBQUN0RSxZQUFLLE1BQU0saUJBQWlCLEtBQUssS0FBTSxDQUFDLEtBQUssUUFBUSxNQUFNLEdBQUc7QUFDNUQ7QUFBQSxRQUNGO0FBQUEsTUFDRjtBQWxERSxXQUFLLFVBQVUsT0FBTyxJQUFJLFFBQVE7QUFDbEMsVUFBSSxDQUFDLFVBQVU7QUFDYixhQUFLLHVCQUFBO0FBQ0wsYUFBSyxpQkFBaUIsU0FBUyxLQUFLLGtCQUFrQjtBQUN0RCxhQUFLLGNBQ0gsSUFBSSw2QkFDRixNQUNBLE1BQU0sS0FBSyxRQUFRLGdDQUFnQyxHQUNuRDtBQUFBLFVBQ0UsVUFBVSxNQUFNLEtBQUssaUJBQUE7QUFBQSxRQUFnQixDQUN0QyxDQUNGO0FBQUEsTUFFTDtBQUFBLElBQ0Y7QUFBQSxJQUVtQix1QkFBb0I7QUFDckMsYUFBTyxLQUFLLFVBQVUsWUFBWTtBQUFBLElBQ3BDO0FBQUEsSUFFbUIsaUJBQWM7QUFDL0IsYUFBTyxNQUFNLGVBQUE7QUFBQSxJQUNmO0FBQUEsSUFFZ0Isb0JBQWlCO0FBQy9CLFlBQU0sa0JBQUE7QUFDTixXQUFLLE9BQU8sZ0NBQWdDLEVBQUUsd0JBQXdCO0FBQUEsSUFDeEU7QUFBQSxJQUVtQixXQUFXLG1CQUF1QztBQUNuRSxZQUFNLFdBQVcsaUJBQWlCO0FBQ2xDLFVBQUksa0JBQWtCLElBQUksVUFBVSxHQUFHO0FBQ3JDLGFBQUssaUJBQUE7QUFBQSxNQUNQO0FBQUEsSUFDRjtBQUFBLElBRVEsbUJBQWdCO0FBQ3RCLFVBQUksS0FBSyxZQUFZLEtBQUssVUFBVSxVQUFVO0FBQzVDLGFBQUssVUFBVSxPQUFPLElBQUksVUFBVTtBQUNwQyxhQUFLLFVBQVUsZUFBZTtBQUFBLE1BQ2hDLE9BQU87QUFDTCxhQUFLLFVBQVUsT0FBTyxPQUFPLFVBQVU7QUFDdkMsYUFBSyxVQUFVLGVBQWU7QUFBQSxNQUNoQztBQUFBLElBQ0Y7QUFBQTs7QUFoRUYsaUJBQUEsTUFBQSxtQkFBQSxFQUFBLE9BQUEsV0FBQSxHQUFBLGtCQUFBLEVBQUEsTUFBQSxTQUFBLE1BQUEsV0FBQSxNQUFBLFVBQUEsVUFBQSxHQUFBLE1BQUEsdUJBQUE7OztRQUdrQyxHQUFBLE9BQU8sVUFDaEIsR0FBQSxTQUF5QixDQUFDLGlCQUFpQixlQUFlLEdBSjdFLGtCQUFBLFlBQUEsdUJBQUEsR0FBaUM7OzsifQ==
@@ -8,8 +8,8 @@ import { SbbAutocompleteGridOptionElement } from '../autocomplete-grid-option.ts
8
8
  */
9
9
  export declare class SbbAutocompleteGridOptgroupElement extends SbbOptgroupBaseElement {
10
10
  protected get options(): SbbAutocompleteGridOptionElement[];
11
+ constructor();
11
12
  protected getAutocompleteParent(): SbbAutocompleteBaseElement | null;
12
- protected setAttributeFromParent(): void;
13
13
  }
14
14
  declare global {
15
15
  interface HTMLElementTagNameMap {
@@ -1 +1 @@
1
- {"version":3,"file":"autocomplete-grid-optgroup.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,yCAAyC,CAAC;AAC1F,OAAO,EAAE,sBAAsB,EAAE,MAAM,4CAA4C,CAAC;AAGpF,OAAO,KAAK,EAAE,gCAAgC,EAAE,MAAM,gCAAgC,CAAC;AAEvF;;;;GAIG;AACH,qBAEM,kCAAmC,SAAQ,sBAAsB;IACrE,SAAS,KAAK,OAAO,IAAI,gCAAgC,EAAE,CAI1D;IAED,SAAS,CAAC,qBAAqB,IAAI,0BAA0B,GAAG,IAAI;IAIpE,SAAS,CAAC,sBAAsB,IAAI,IAAI;CAIzC;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gCAAgC,EAAE,kCAAkC,CAAC;KACtE;CACF"}
1
+ {"version":3,"file":"autocomplete-grid-optgroup.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,yCAAyC,CAAC;AAE1F,OAAO,EAAE,sBAAsB,EAAE,MAAM,4CAA4C,CAAC;AAGpF,OAAO,KAAK,EAAE,gCAAgC,EAAE,MAAM,gCAAgC,CAAC;AAEvF;;;;GAIG;AACH,qBAEM,kCAAmC,SAAQ,sBAAsB;IACrE,SAAS,KAAK,OAAO,IAAI,gCAAgC,EAAE,CAI1D;;IAiBD,SAAS,CAAC,qBAAqB,IAAI,0BAA0B,GAAG,IAAI;CAGrE;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gCAAgC,EAAE,kCAAkC,CAAC;KACtE;CACF"}
@@ -1,4 +1,5 @@
1
1
  import { __esDecorate, __runInitializers } from "tslib";
2
+ import { SbbPropertyWatcherController } from "@sbb-esta/lyne-elements/core/controllers.js";
2
3
  import { SbbOptgroupBaseElement } from "@sbb-esta/lyne-elements/option/optgroup.js";
3
4
  import { customElement } from "lit/decorators.js";
4
5
  let SbbAutocompleteGridOptgroupElement = (() => {
@@ -12,13 +13,18 @@ let SbbAutocompleteGridOptgroupElement = (() => {
12
13
  get options() {
13
14
  return Array.from(this.querySelectorAll?.("sbb-autocomplete-grid-option") ?? []);
14
15
  }
16
+ constructor() {
17
+ super();
18
+ this.addController(new SbbPropertyWatcherController(this, () => this.closest("sbb-autocomplete-grid"), {
19
+ negative: (e) => {
20
+ this.toggleState("negative", e.negative);
21
+ this.requestUpdate();
22
+ }
23
+ }));
24
+ }
15
25
  getAutocompleteParent() {
16
26
  return this.closest?.("sbb-autocomplete-grid") || null;
17
27
  }
18
- setAttributeFromParent() {
19
- this.negative = !!this.closest(`:is(sbb-autocomplete-grid, sbb-form-field)[negative]`);
20
- this.toggleAttribute("data-negative", this.negative);
21
- }
22
28
  }, _classThis = _a, (() => {
23
29
  const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
24
30
  __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
@@ -31,4 +37,4 @@ let SbbAutocompleteGridOptgroupElement = (() => {
31
37
  export {
32
38
  SbbAutocompleteGridOptgroupElement
33
39
  };
34
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLWdyaWQtb3B0Z3JvdXAuY29tcG9uZW50LmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMtZXhwZXJpbWVudGFsL2F1dG9jb21wbGV0ZS1ncmlkL2F1dG9jb21wbGV0ZS1ncmlkLW9wdGdyb3VwL2F1dG9jb21wbGV0ZS1ncmlkLW9wdGdyb3VwLmNvbXBvbmVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFNiYkF1dG9jb21wbGV0ZUJhc2VFbGVtZW50IH0gZnJvbSAnQHNiYi1lc3RhL2x5bmUtZWxlbWVudHMvYXV0b2NvbXBsZXRlLmpzJztcbmltcG9ydCB7IFNiYk9wdGdyb3VwQmFzZUVsZW1lbnQgfSBmcm9tICdAc2JiLWVzdGEvbHluZS1lbGVtZW50cy9vcHRpb24vb3B0Z3JvdXAuanMnO1xuaW1wb3J0IHsgY3VzdG9tRWxlbWVudCB9IGZyb20gJ2xpdC9kZWNvcmF0b3JzLmpzJztcblxuaW1wb3J0IHR5cGUgeyBTYmJBdXRvY29tcGxldGVHcmlkT3B0aW9uRWxlbWVudCB9IGZyb20gJy4uL2F1dG9jb21wbGV0ZS1ncmlkLW9wdGlvbi50cyc7XG5cbi8qKlxuICogSXQgY2FuIGJlIHVzZWQgYXMgYSBjb250YWluZXIgZm9yIG9uZSBvciBtb3JlIGBzYmItYXV0b2NvbXBsZXRlLWdyaWQtb3B0aW9uYC5cbiAqXG4gKiBAc2xvdCAtIFVzZSB0aGUgdW5uYW1lZCBzbG90IHRvIGFkZCBgc2JiLWF1dG9jb21wbGV0ZS1ncmlkLW9wdGlvbmAgZWxlbWVudHMgdG8gdGhlIGBzYmItYXV0b2NvbXBsZXRlLWdyaWQtb3B0Z3JvdXBgLlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItYXV0b2NvbXBsZXRlLWdyaWQtb3B0Z3JvdXAnKVxuY2xhc3MgU2JiQXV0b2NvbXBsZXRlR3JpZE9wdGdyb3VwRWxlbWVudCBleHRlbmRzIFNiYk9wdGdyb3VwQmFzZUVsZW1lbnQge1xuICBwcm90ZWN0ZWQgZ2V0IG9wdGlvbnMoKTogU2JiQXV0b2NvbXBsZXRlR3JpZE9wdGlvbkVsZW1lbnRbXSB7XG4gICAgcmV0dXJuIEFycmF5LmZyb20oXG4gICAgICB0aGlzLnF1ZXJ5U2VsZWN0b3JBbGw/Lignc2JiLWF1dG9jb21wbGV0ZS1ncmlkLW9wdGlvbicpID8/IFtdLFxuICAgICkgYXMgU2JiQXV0b2NvbXBsZXRlR3JpZE9wdGlvbkVsZW1lbnRbXTtcbiAgfVxuXG4gIHByb3RlY3RlZCBnZXRBdXRvY29tcGxldGVQYXJlbnQoKTogU2JiQXV0b2NvbXBsZXRlQmFzZUVsZW1lbnQgfCBudWxsIHtcbiAgICByZXR1cm4gdGhpcy5jbG9zZXN0Py48U2JiQXV0b2NvbXBsZXRlQmFzZUVsZW1lbnQ+KCdzYmItYXV0b2NvbXBsZXRlLWdyaWQnKSB8fCBudWxsO1xuICB9XG5cbiAgcHJvdGVjdGVkIHNldEF0dHJpYnV0ZUZyb21QYXJlbnQoKTogdm9pZCB7XG4gICAgdGhpcy5uZWdhdGl2ZSA9ICEhdGhpcy5jbG9zZXN0KGA6aXMoc2JiLWF1dG9jb21wbGV0ZS1ncmlkLCBzYmItZm9ybS1maWVsZClbbmVnYXRpdmVdYCk7XG4gICAgdGhpcy50b2dnbGVBdHRyaWJ1dGUoJ2RhdGEtbmVnYXRpdmUnLCB0aGlzLm5lZ2F0aXZlKTtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLWF1dG9jb21wbGV0ZS1ncmlkLW9wdGdyb3VwJzogU2JiQXV0b2NvbXBsZXRlR3JpZE9wdGdyb3VwRWxlbWVudDtcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztJQWFNLHNDQUFrQyxNQUFBOzswQkFEdkMsY0FBYyxnQ0FBZ0MsQ0FBQzs7OztvQkFDQztBQUFSLEVBQUEsbUJBQVEsWUFBc0I7QUFBQSxJQUNyRSxJQUFjLFVBQU87QUFDbkIsYUFBTyxNQUFNLEtBQ1gsS0FBSyxtQkFBbUIsOEJBQThCLEtBQUssRUFBRTtBQUFBLElBRWpFO0FBQUEsSUFFVSx3QkFBcUI7QUFDN0IsYUFBTyxLQUFLLFVBQXNDLHVCQUF1QixLQUFLO0FBQUEsSUFDaEY7QUFBQSxJQUVVLHlCQUFzQjtBQUM5QixXQUFLLFdBQVcsQ0FBQyxDQUFDLEtBQUssUUFBUSxzREFBc0Q7QUFDckYsV0FBSyxnQkFBZ0IsaUJBQWlCLEtBQUssUUFBUTtBQUFBLElBQ3JEO0FBQUEsRUFBQTs7QUFkRixpQkFBQSxNQUFBLG1CQUFBLEVBQUEsT0FBQSxXQUFBLEdBQUEsa0JBQUEsRUFBQSxNQUFBLFNBQUEsTUFBQSxXQUFBLE1BQUEsVUFBQSxVQUFBLEdBQUEsTUFBQSx1QkFBQTs7O0FBQU0sc0JBQUEsWUFBQSx1QkFBQTtBQUFBLEVBQUEsTUFBbUM7OzsifQ==
40
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLWdyaWQtb3B0Z3JvdXAuY29tcG9uZW50LmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMtZXhwZXJpbWVudGFsL2F1dG9jb21wbGV0ZS1ncmlkL2F1dG9jb21wbGV0ZS1ncmlkLW9wdGdyb3VwL2F1dG9jb21wbGV0ZS1ncmlkLW9wdGdyb3VwLmNvbXBvbmVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFNiYkF1dG9jb21wbGV0ZUJhc2VFbGVtZW50IH0gZnJvbSAnQHNiYi1lc3RhL2x5bmUtZWxlbWVudHMvYXV0b2NvbXBsZXRlLmpzJztcbmltcG9ydCB7IFNiYlByb3BlcnR5V2F0Y2hlckNvbnRyb2xsZXIgfSBmcm9tICdAc2JiLWVzdGEvbHluZS1lbGVtZW50cy9jb3JlL2NvbnRyb2xsZXJzLmpzJztcbmltcG9ydCB7IFNiYk9wdGdyb3VwQmFzZUVsZW1lbnQgfSBmcm9tICdAc2JiLWVzdGEvbHluZS1lbGVtZW50cy9vcHRpb24vb3B0Z3JvdXAuanMnO1xuaW1wb3J0IHsgY3VzdG9tRWxlbWVudCB9IGZyb20gJ2xpdC9kZWNvcmF0b3JzLmpzJztcblxuaW1wb3J0IHR5cGUgeyBTYmJBdXRvY29tcGxldGVHcmlkT3B0aW9uRWxlbWVudCB9IGZyb20gJy4uL2F1dG9jb21wbGV0ZS1ncmlkLW9wdGlvbi50cyc7XG5cbi8qKlxuICogSXQgY2FuIGJlIHVzZWQgYXMgYSBjb250YWluZXIgZm9yIG9uZSBvciBtb3JlIGBzYmItYXV0b2NvbXBsZXRlLWdyaWQtb3B0aW9uYC5cbiAqXG4gKiBAc2xvdCAtIFVzZSB0aGUgdW5uYW1lZCBzbG90IHRvIGFkZCBgc2JiLWF1dG9jb21wbGV0ZS1ncmlkLW9wdGlvbmAgZWxlbWVudHMgdG8gdGhlIGBzYmItYXV0b2NvbXBsZXRlLWdyaWQtb3B0Z3JvdXBgLlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItYXV0b2NvbXBsZXRlLWdyaWQtb3B0Z3JvdXAnKVxuY2xhc3MgU2JiQXV0b2NvbXBsZXRlR3JpZE9wdGdyb3VwRWxlbWVudCBleHRlbmRzIFNiYk9wdGdyb3VwQmFzZUVsZW1lbnQge1xuICBwcm90ZWN0ZWQgZ2V0IG9wdGlvbnMoKTogU2JiQXV0b2NvbXBsZXRlR3JpZE9wdGlvbkVsZW1lbnRbXSB7XG4gICAgcmV0dXJuIEFycmF5LmZyb20oXG4gICAgICB0aGlzLnF1ZXJ5U2VsZWN0b3JBbGw/Lignc2JiLWF1dG9jb21wbGV0ZS1ncmlkLW9wdGlvbicpID8/IFtdLFxuICAgICkgYXMgU2JiQXV0b2NvbXBsZXRlR3JpZE9wdGlvbkVsZW1lbnRbXTtcbiAgfVxuXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuXG4gICAgdGhpcy5hZGRDb250cm9sbGVyKFxuICAgICAgbmV3IFNiYlByb3BlcnR5V2F0Y2hlckNvbnRyb2xsZXIodGhpcywgKCkgPT4gdGhpcy5jbG9zZXN0KCdzYmItYXV0b2NvbXBsZXRlLWdyaWQnKSwge1xuICAgICAgICBuZWdhdGl2ZTogKGUpID0+IHtcbiAgICAgICAgICB0aGlzLnRvZ2dsZVN0YXRlKCduZWdhdGl2ZScsIGUubmVnYXRpdmUpO1xuXG4gICAgICAgICAgLy8gVG8gdXBkYXRlIHRoZSBzYmItZGl2aWRlciB3ZSBuZWVkIGEgcmVxdWVzdFVwZGF0ZSgpIGhlcmVcbiAgICAgICAgICB0aGlzLnJlcXVlc3RVcGRhdGUoKTtcbiAgICAgICAgfSxcbiAgICAgIH0pLFxuICAgICk7XG4gIH1cblxuICBwcm90ZWN0ZWQgZ2V0QXV0b2NvbXBsZXRlUGFyZW50KCk6IFNiYkF1dG9jb21wbGV0ZUJhc2VFbGVtZW50IHwgbnVsbCB7XG4gICAgcmV0dXJuIHRoaXMuY2xvc2VzdD8uPFNiYkF1dG9jb21wbGV0ZUJhc2VFbGVtZW50Pignc2JiLWF1dG9jb21wbGV0ZS1ncmlkJykgfHwgbnVsbDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLWF1dG9jb21wbGV0ZS1ncmlkLW9wdGdyb3VwJzogU2JiQXV0b2NvbXBsZXRlR3JpZE9wdGdyb3VwRWxlbWVudDtcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7SUFjTSxzQ0FBa0MsTUFBQTs7MEJBRHZDLGNBQWMsZ0NBQWdDLENBQUM7Ozs7b0JBQ0M7QUFBUixFQUFBLG1CQUFRLFlBQXNCO0FBQUEsSUFDckUsSUFBYyxVQUFPO0FBQ25CLGFBQU8sTUFBTSxLQUNYLEtBQUssbUJBQW1CLDhCQUE4QixLQUFLLEVBQUU7QUFBQSxJQUVqRTtBQUFBLElBRUEsY0FBQTtBQUNFLFlBQUE7QUFFQSxXQUFLLGNBQ0gsSUFBSSw2QkFBNkIsTUFBTSxNQUFNLEtBQUssUUFBUSx1QkFBdUIsR0FBRztBQUFBLFFBQ2xGLFVBQVUsQ0FBQyxNQUFLO0FBQ2QsZUFBSyxZQUFZLFlBQVksRUFBRSxRQUFRO0FBR3ZDLGVBQUssY0FBQTtBQUFBLFFBQ1A7QUFBQSxNQUFBLENBQ0QsQ0FBQztBQUFBLElBRU47QUFBQSxJQUVVLHdCQUFxQjtBQUM3QixhQUFPLEtBQUssVUFBc0MsdUJBQXVCLEtBQUs7QUFBQSxJQUNoRjtBQUFBLEVBQUE7O0FBeEJGLGlCQUFBLE1BQUEsbUJBQUEsRUFBQSxPQUFBLFdBQUEsR0FBQSxrQkFBQSxFQUFBLE1BQUEsU0FBQSxNQUFBLFdBQUEsTUFBQSxVQUFBLFVBQUEsR0FBQSxNQUFBLHVCQUFBOzs7QUFBTSxzQkFBQSxZQUFBLHVCQUFBO0FBQUEsRUFBQSxNQUFtQzs7OyJ9
@@ -16,7 +16,6 @@ export declare class SbbAutocompleteGridOptionElement<T = string> extends SbbOpt
16
16
  protected optionId: string;
17
17
  constructor();
18
18
  protected willUpdate(changedProperties: PropertyValues<this>): void;
19
- protected setAttributeFromParent(): void;
20
19
  protected selectByClick(event: MouseEvent): void;
21
20
  }
22
21
  declare global {
@@ -1 +1 @@
1
- {"version":3,"file":"autocomplete-grid-option.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.component.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,oBAAoB,EAAE,MAAM,mCAAmC,CAAC;AACzE,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAK1D,eAAO,MAAM,wBAAwB,EAAE,MAAuC,CAAC;AAE/E;;;;;;;;GAQG;AACH,qBAEM,gCAAgC,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,oBAAoB,CAAC,CAAC,CAAC;IAChF,gBAAgC,IAAI,cAAc;IAClD,OAAuB,MAAM,EAAE,cAAc,CAA4B;IAEzE,SAAS,CAAC,QAAQ,SAA4B;;cAkB3B,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAW5E,SAAS,CAAC,sBAAsB,IAAI,IAAI;IAexC,SAAS,CAAC,aAAa,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;CAQjD;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,8BAA8B,EAAE,gCAAgC,CAAC;KAClE;CACF"}
1
+ {"version":3,"file":"autocomplete-grid-option.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.component.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,oBAAoB,EAAE,MAAM,mCAAmC,CAAC;AACzE,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAK1D,eAAO,MAAM,wBAAwB,EAAE,MAAuC,CAAC;AAE/E;;;;;;;;GAQG;AACH,qBAEM,gCAAgC,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,oBAAoB,CAAC,CAAC,CAAC;IAChF,gBAAgC,IAAI,cAAc;IAClD,OAAuB,MAAM,EAAE,cAAc,CAA4B;IAEzE,SAAS,CAAC,QAAQ,SAA4B;;cAyB3B,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAW5E,SAAS,CAAC,aAAa,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;CAQjD;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,8BAA8B,EAAE,gCAAgC,CAAC;KAClE;CACF"}
@@ -1,5 +1,6 @@
1
1
  import { __esDecorate, __runInitializers } from "tslib";
2
- import { SbbAncestorWatcherController } from "@sbb-esta/lyne-elements/core/controllers.js";
2
+ import { SbbPropertyWatcherController } from "@sbb-esta/lyne-elements/core/controllers.js";
3
+ import { ɵstateController as _stateController } from "@sbb-esta/lyne-elements/core/mixins.js";
3
4
  import { boxSizingStyles } from "@sbb-esta/lyne-elements/core/styles.js";
4
5
  import { SbbOptionBaseElement } from "@sbb-esta/lyne-elements/option.js";
5
6
  import { customElement } from "lit/decorators.js";
@@ -17,16 +18,16 @@ const style = css`:host {
17
18
  display: block;
18
19
  }
19
20
 
20
- :host([data-negative]) {
21
+ :host(:is(:state(negative),[state--negative])) {
21
22
  --sbb-option-color: var(--sbb-color-3-negative);
22
23
  --sbb-option-icon-color: var(--sbb-color-5);
23
24
  }
24
25
 
25
- :host(:not([data-disable-highlight])) .sbb-option__label slot {
26
+ :host(:not(:is(:state(disable-highlight),[state--disable-highlight]))) .sbb-option__label slot {
26
27
  display: none;
27
28
  }
28
29
 
29
- :host([data-active]) {
30
+ :host(:is(:state(active),[state--active])) {
30
31
  --sbb-option-focus-outline-color: var(--sbb-focus-outline-color);
31
32
  }
32
33
 
@@ -92,30 +93,24 @@ let SbbAutocompleteGridOptionElement = (() => {
92
93
  constructor() {
93
94
  super();
94
95
  this.optionId = autocompleteGridOptionId;
95
- this.addController(new SbbAncestorWatcherController(this, () => this.closest("sbb-autocomplete-grid-optgroup"), {
96
+ this.addController(new SbbPropertyWatcherController(this, () => this.closest("sbb-autocomplete-grid-optgroup"), {
96
97
  disabled: (p) => {
97
98
  this.disabledFromGroup = p.disabled;
98
- this.closest?.("sbb-autocomplete-grid-row")?.toggleAttribute("data-disabled", this.disabled || this.disabledFromGroup);
99
+ _stateController(this.closest?.("sbb-autocomplete-grid-row"))?.toggle("disabled", this.disabled || this.disabledFromGroup);
100
+ this.updateAriaDisabled();
99
101
  },
100
102
  label: (p) => this.groupLabel = p.label
101
103
  }));
104
+ this.addController(new SbbPropertyWatcherController(this, () => this.closest("sbb-autocomplete-grid"), {
105
+ negative: (e) => this.toggleState("negative", e.negative)
106
+ }));
102
107
  }
103
108
  willUpdate(changedProperties) {
104
109
  super.willUpdate(changedProperties);
105
110
  if (changedProperties.has("disabled")) {
106
- this.closest?.("sbb-autocomplete-grid-row")?.toggleAttribute("data-disabled", this.disabled || this.disabledFromGroup);
107
- this.updateAriaDisabled();
108
- }
109
- }
110
- setAttributeFromParent() {
111
- const parentGroup = this.closest("sbb-autocomplete-grid-optgroup");
112
- if (parentGroup) {
113
- this.disabledFromGroup = parentGroup.disabled;
111
+ _stateController(this.closest?.("sbb-autocomplete-grid-row"))?.toggle("disabled", this.disabled || this.disabledFromGroup);
114
112
  this.updateAriaDisabled();
115
113
  }
116
- this.closest("sbb-autocomplete-grid-row")?.toggleAttribute("data-disabled", this.disabled || this.disabledFromGroup);
117
- this.negative = !!this.closest(`:is(sbb-autocomplete-grid[negative],sbb-form-field[negative])`);
118
- this.toggleAttribute("data-negative", this.negative);
119
114
  }
120
115
  selectByClick(event) {
121
116
  if (this.disabled || this.disabledFromGroup) {
@@ -136,4 +131,4 @@ export {
136
131
  SbbAutocompleteGridOptionElement,
137
132
  autocompleteGridOptionId
138
133
  };
139
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLWdyaWQtb3B0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzLWV4cGVyaW1lbnRhbC9hdXRvY29tcGxldGUtZ3JpZC9hdXRvY29tcGxldGUtZ3JpZC1vcHRpb24vYXV0b2NvbXBsZXRlLWdyaWQtb3B0aW9uLmNvbXBvbmVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTYmJBbmNlc3RvcldhdGNoZXJDb250cm9sbGVyIH0gZnJvbSAnQHNiYi1lc3RhL2x5bmUtZWxlbWVudHMvY29yZS9jb250cm9sbGVycy5qcyc7XG5pbXBvcnQgeyBib3hTaXppbmdTdHlsZXMgfSBmcm9tICdAc2JiLWVzdGEvbHluZS1lbGVtZW50cy9jb3JlL3N0eWxlcy5qcyc7XG5pbXBvcnQgeyBTYmJPcHRpb25CYXNlRWxlbWVudCB9IGZyb20gJ0BzYmItZXN0YS9seW5lLWVsZW1lbnRzL29wdGlvbi5qcyc7XG5pbXBvcnQgdHlwZSB7IENTU1Jlc3VsdEdyb3VwLCBQcm9wZXJ0eVZhbHVlcyB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9hdXRvY29tcGxldGUtZ3JpZC1vcHRpb24uc2Nzcz9saXQmaW5saW5lJztcblxuZXhwb3J0IGNvbnN0IGF1dG9jb21wbGV0ZUdyaWRPcHRpb25JZDogc3RyaW5nID0gYHNiYi1hdXRvY29tcGxldGUtZ3JpZC1vcHRpb25gO1xuXG4vKipcbiAqIEl0IGRpc3BsYXlzIGFuIG9wdGlvbiBpdGVtIHdoaWNoIGNhbiBiZSB1c2VkIGluIGBzYmItYXV0b2NvbXBsZXRlLWdyaWRgLlxuICpcbiAqIEBzbG90IC0gVXNlIHRoZSB1bm5hbWVkIHNsb3QgdG8gYWRkIGNvbnRlbnQgdG8gdGhlIG9wdGlvbiBsYWJlbC5cbiAqIEBzbG90IGljb24gLSBVc2UgdGhpcyBzbG90IHRvIHByb3ZpZGUgYW4gaWNvbi4gSWYgYGljb24tbmFtZWAgaXMgc2V0LCBhIHNiYi1pY29uIHdpbGwgYmUgdXNlZC5cbiAqIEBjc3Nwcm9wIFstLXNiYi1vcHRpb24taWNvbi1jb250YWluZXItZGlzcGxheT1ub25lXSAtIENhbiBiZSB1c2VkIHRvIHJlc2VydmUgc3BhY2UgZXZlblxuICogd2hlbiBwcmVzZXJ2ZS1pY29uLXNwYWNlIG9uIGF1dG9jb21wbGV0ZSBpcyBub3Qgc2V0IG9yIGljb25OYW1lIGlzIG5vdCBzZXQuXG4gKiBAb3ZlcnJpZGVUeXBlIHZhbHVlIC0gVCA9IHN0cmluZ1xuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItYXV0b2NvbXBsZXRlLWdyaWQtb3B0aW9uJylcbmNsYXNzIFNiYkF1dG9jb21wbGV0ZUdyaWRPcHRpb25FbGVtZW50PFQgPSBzdHJpbmc+IGV4dGVuZHMgU2JiT3B0aW9uQmFzZUVsZW1lbnQ8VD4ge1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHJlYWRvbmx5IHJvbGUgPSAnZ3JpZGNlbGwnO1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHN0eWxlczogQ1NTUmVzdWx0R3JvdXAgPSBbYm94U2l6aW5nU3R5bGVzLCBzdHlsZV07XG5cbiAgcHJvdGVjdGVkIG9wdGlvbklkID0gYXV0b2NvbXBsZXRlR3JpZE9wdGlvbklkO1xuXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuICAgIHRoaXMuYWRkQ29udHJvbGxlcihcbiAgICAgIG5ldyBTYmJBbmNlc3RvcldhdGNoZXJDb250cm9sbGVyKHRoaXMsICgpID0+IHRoaXMuY2xvc2VzdCgnc2JiLWF1dG9jb21wbGV0ZS1ncmlkLW9wdGdyb3VwJyksIHtcbiAgICAgICAgZGlzYWJsZWQ6IChwKSA9PiB7XG4gICAgICAgICAgdGhpcy5kaXNhYmxlZEZyb21Hcm91cCA9IHAuZGlzYWJsZWQ7XG4gICAgICAgICAgdGhpcy5jbG9zZXN0Py4oJ3NiYi1hdXRvY29tcGxldGUtZ3JpZC1yb3cnKT8udG9nZ2xlQXR0cmlidXRlKFxuICAgICAgICAgICAgJ2RhdGEtZGlzYWJsZWQnLFxuICAgICAgICAgICAgdGhpcy5kaXNhYmxlZCB8fCB0aGlzLmRpc2FibGVkRnJvbUdyb3VwLFxuICAgICAgICAgICk7XG4gICAgICAgIH0sXG4gICAgICAgIGxhYmVsOiAocCkgPT4gKHRoaXMuZ3JvdXBMYWJlbCA9IHAubGFiZWwpLFxuICAgICAgfSksXG4gICAgKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSB3aWxsVXBkYXRlKGNoYW5nZWRQcm9wZXJ0aWVzOiBQcm9wZXJ0eVZhbHVlczx0aGlzPik6IHZvaWQge1xuICAgIHN1cGVyLndpbGxVcGRhdGUoY2hhbmdlZFByb3BlcnRpZXMpO1xuICAgIGlmIChjaGFuZ2VkUHJvcGVydGllcy5oYXMoJ2Rpc2FibGVkJykpIHtcbiAgICAgIHRoaXMuY2xvc2VzdD8uKCdzYmItYXV0b2NvbXBsZXRlLWdyaWQtcm93Jyk/LnRvZ2dsZUF0dHJpYnV0ZShcbiAgICAgICAgJ2RhdGEtZGlzYWJsZWQnLFxuICAgICAgICB0aGlzLmRpc2FibGVkIHx8IHRoaXMuZGlzYWJsZWRGcm9tR3JvdXAsXG4gICAgICApO1xuICAgICAgdGhpcy51cGRhdGVBcmlhRGlzYWJsZWQoKTtcbiAgICB9XG4gIH1cblxuICBwcm90ZWN0ZWQgc2V0QXR0cmlidXRlRnJvbVBhcmVudCgpOiB2b2lkIHtcbiAgICBjb25zdCBwYXJlbnRHcm91cCA9IHRoaXMuY2xvc2VzdCgnc2JiLWF1dG9jb21wbGV0ZS1ncmlkLW9wdGdyb3VwJyk7XG4gICAgaWYgKHBhcmVudEdyb3VwKSB7XG4gICAgICB0aGlzLmRpc2FibGVkRnJvbUdyb3VwID0gcGFyZW50R3JvdXAuZGlzYWJsZWQ7XG4gICAgICB0aGlzLnVwZGF0ZUFyaWFEaXNhYmxlZCgpO1xuICAgIH1cbiAgICB0aGlzLmNsb3Nlc3QoJ3NiYi1hdXRvY29tcGxldGUtZ3JpZC1yb3cnKT8udG9nZ2xlQXR0cmlidXRlKFxuICAgICAgJ2RhdGEtZGlzYWJsZWQnLFxuICAgICAgdGhpcy5kaXNhYmxlZCB8fCB0aGlzLmRpc2FibGVkRnJvbUdyb3VwLFxuICAgICk7XG5cbiAgICB0aGlzLm5lZ2F0aXZlID0gISF0aGlzLmNsb3Nlc3QoYDppcyhzYmItYXV0b2NvbXBsZXRlLWdyaWRbbmVnYXRpdmVdLHNiYi1mb3JtLWZpZWxkW25lZ2F0aXZlXSlgKTtcbiAgICB0aGlzLnRvZ2dsZUF0dHJpYnV0ZSgnZGF0YS1uZWdhdGl2ZScsIHRoaXMubmVnYXRpdmUpO1xuICB9XG5cbiAgcHJvdGVjdGVkIHNlbGVjdEJ5Q2xpY2soZXZlbnQ6IE1vdXNlRXZlbnQpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5kaXNhYmxlZCB8fCB0aGlzLmRpc2FibGVkRnJvbUdyb3VwKSB7XG4gICAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICB0aGlzLnNlbGVjdFZpYVVzZXJJbnRlcmFjdGlvbih0cnVlKTtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLWF1dG9jb21wbGV0ZS1ncmlkLW9wdGlvbic6IFNiYkF1dG9jb21wbGV0ZUdyaWRPcHRpb25FbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQVFPLE1BQU0sMkJBQW1DO0lBYTFDLG9DQUFnQyxNQUFBOzswQkFEckMsY0FBYyw4QkFBOEIsQ0FBQzs7OztvQkFDYTtBQUFSLEVBQUEsbUJBQVEsWUFBdUI7QUFBQSxJQU1oRixjQUFBO0FBQ0UsWUFBQTtBQUhRLFdBQUEsV0FBVztBQUluQixXQUFLLGNBQ0gsSUFBSSw2QkFBNkIsTUFBTSxNQUFNLEtBQUssUUFBUSxnQ0FBZ0MsR0FBRztBQUFBLFFBQzNGLFVBQVUsQ0FBQyxNQUFLO0FBQ2QsZUFBSyxvQkFBb0IsRUFBRTtBQUMzQixlQUFLLFVBQVUsMkJBQTJCLEdBQUcsZ0JBQzNDLGlCQUNBLEtBQUssWUFBWSxLQUFLLGlCQUFpQjtBQUFBLFFBRTNDO0FBQUEsUUFDQSxPQUFPLENBQUMsTUFBTyxLQUFLLGFBQWEsRUFBRTtBQUFBLE1BQUEsQ0FDcEMsQ0FBQztBQUFBLElBRU47QUFBQSxJQUVtQixXQUFXLG1CQUF1QztBQUNuRSxZQUFNLFdBQVcsaUJBQWlCO0FBQ2xDLFVBQUksa0JBQWtCLElBQUksVUFBVSxHQUFHO0FBQ3JDLGFBQUssVUFBVSwyQkFBMkIsR0FBRyxnQkFDM0MsaUJBQ0EsS0FBSyxZQUFZLEtBQUssaUJBQWlCO0FBRXpDLGFBQUssbUJBQUE7QUFBQSxNQUNQO0FBQUEsSUFDRjtBQUFBLElBRVUseUJBQXNCO0FBQzlCLFlBQU0sY0FBYyxLQUFLLFFBQVEsZ0NBQWdDO0FBQ2pFLFVBQUksYUFBYTtBQUNmLGFBQUssb0JBQW9CLFlBQVk7QUFDckMsYUFBSyxtQkFBQTtBQUFBLE1BQ1A7QUFDQSxXQUFLLFFBQVEsMkJBQTJCLEdBQUcsZ0JBQ3pDLGlCQUNBLEtBQUssWUFBWSxLQUFLLGlCQUFpQjtBQUd6QyxXQUFLLFdBQVcsQ0FBQyxDQUFDLEtBQUssUUFBUSwrREFBK0Q7QUFDOUYsV0FBSyxnQkFBZ0IsaUJBQWlCLEtBQUssUUFBUTtBQUFBLElBQ3JEO0FBQUEsSUFFVSxjQUFjLE9BQWlCO0FBQ3ZDLFVBQUksS0FBSyxZQUFZLEtBQUssbUJBQW1CO0FBQzNDLGNBQU0sZ0JBQUE7QUFDTjtBQUFBLE1BQ0Y7QUFFQSxXQUFLLHlCQUF5QixJQUFJO0FBQUEsSUFDcEM7QUFBQTs7QUF2REYsaUJBQUEsTUFBQSxtQkFBQSxFQUFBLE9BQUEsV0FBQSxHQUFBLGtCQUFBLEVBQUEsTUFBQSxTQUFBLE1BQUEsV0FBQSxNQUFBLFVBQUEsVUFBQSxHQUFBLE1BQUEsdUJBQUE7OztRQUNrQyxHQUFBLE9BQU8sWUFDaEIsR0FBQSxTQUF5QixDQUFDLGlCQUFpQixLQUFLLEdBRm5FLGtCQUFBLFlBQUEsdUJBQUEsR0FBNkM7OzsifQ==
134
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLWdyaWQtb3B0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzLWV4cGVyaW1lbnRhbC9hdXRvY29tcGxldGUtZ3JpZC9hdXRvY29tcGxldGUtZ3JpZC1vcHRpb24vYXV0b2NvbXBsZXRlLWdyaWQtb3B0aW9uLmNvbXBvbmVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTYmJQcm9wZXJ0eVdhdGNoZXJDb250cm9sbGVyIH0gZnJvbSAnQHNiYi1lc3RhL2x5bmUtZWxlbWVudHMvY29yZS9jb250cm9sbGVycy5qcyc7XG5pbXBvcnQgeyDJtXN0YXRlQ29udHJvbGxlciB9IGZyb20gJ0BzYmItZXN0YS9seW5lLWVsZW1lbnRzL2NvcmUvbWl4aW5zLmpzJztcbmltcG9ydCB7IGJveFNpemluZ1N0eWxlcyB9IGZyb20gJ0BzYmItZXN0YS9seW5lLWVsZW1lbnRzL2NvcmUvc3R5bGVzLmpzJztcbmltcG9ydCB7IFNiYk9wdGlvbkJhc2VFbGVtZW50IH0gZnJvbSAnQHNiYi1lc3RhL2x5bmUtZWxlbWVudHMvb3B0aW9uLmpzJztcbmltcG9ydCB0eXBlIHsgQ1NTUmVzdWx0R3JvdXAsIFByb3BlcnR5VmFsdWVzIH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQgfSBmcm9tICdsaXQvZGVjb3JhdG9ycy5qcyc7XG5cbmltcG9ydCBzdHlsZSBmcm9tICcuL2F1dG9jb21wbGV0ZS1ncmlkLW9wdGlvbi5zY3NzP2xpdCZpbmxpbmUnO1xuXG5leHBvcnQgY29uc3QgYXV0b2NvbXBsZXRlR3JpZE9wdGlvbklkOiBzdHJpbmcgPSBgc2JiLWF1dG9jb21wbGV0ZS1ncmlkLW9wdGlvbmA7XG5cbi8qKlxuICogSXQgZGlzcGxheXMgYW4gb3B0aW9uIGl0ZW0gd2hpY2ggY2FuIGJlIHVzZWQgaW4gYHNiYi1hdXRvY29tcGxldGUtZ3JpZGAuXG4gKlxuICogQHNsb3QgLSBVc2UgdGhlIHVubmFtZWQgc2xvdCB0byBhZGQgY29udGVudCB0byB0aGUgb3B0aW9uIGxhYmVsLlxuICogQHNsb3QgaWNvbiAtIFVzZSB0aGlzIHNsb3QgdG8gcHJvdmlkZSBhbiBpY29uLiBJZiBgaWNvbi1uYW1lYCBpcyBzZXQsIGEgc2JiLWljb24gd2lsbCBiZSB1c2VkLlxuICogQGNzc3Byb3AgWy0tc2JiLW9wdGlvbi1pY29uLWNvbnRhaW5lci1kaXNwbGF5PW5vbmVdIC0gQ2FuIGJlIHVzZWQgdG8gcmVzZXJ2ZSBzcGFjZSBldmVuXG4gKiB3aGVuIHByZXNlcnZlLWljb24tc3BhY2Ugb24gYXV0b2NvbXBsZXRlIGlzIG5vdCBzZXQgb3IgaWNvbk5hbWUgaXMgbm90IHNldC5cbiAqIEBvdmVycmlkZVR5cGUgdmFsdWUgLSBUID0gc3RyaW5nXG4gKi9cbmV4cG9ydFxuQGN1c3RvbUVsZW1lbnQoJ3NiYi1hdXRvY29tcGxldGUtZ3JpZC1vcHRpb24nKVxuY2xhc3MgU2JiQXV0b2NvbXBsZXRlR3JpZE9wdGlvbkVsZW1lbnQ8VCA9IHN0cmluZz4gZXh0ZW5kcyBTYmJPcHRpb25CYXNlRWxlbWVudDxUPiB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgcmVhZG9ubHkgcm9sZSA9ICdncmlkY2VsbCc7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IFtib3hTaXppbmdTdHlsZXMsIHN0eWxlXTtcblxuICBwcm90ZWN0ZWQgb3B0aW9uSWQgPSBhdXRvY29tcGxldGVHcmlkT3B0aW9uSWQ7XG5cbiAgcHVibGljIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKCk7XG4gICAgdGhpcy5hZGRDb250cm9sbGVyKFxuICAgICAgbmV3IFNiYlByb3BlcnR5V2F0Y2hlckNvbnRyb2xsZXIodGhpcywgKCkgPT4gdGhpcy5jbG9zZXN0KCdzYmItYXV0b2NvbXBsZXRlLWdyaWQtb3B0Z3JvdXAnKSwge1xuICAgICAgICBkaXNhYmxlZDogKHApID0+IHtcbiAgICAgICAgICB0aGlzLmRpc2FibGVkRnJvbUdyb3VwID0gcC5kaXNhYmxlZDtcbiAgICAgICAgICDJtXN0YXRlQ29udHJvbGxlcih0aGlzLmNsb3Nlc3Q/Lignc2JiLWF1dG9jb21wbGV0ZS1ncmlkLXJvdycpKT8udG9nZ2xlKFxuICAgICAgICAgICAgJ2Rpc2FibGVkJyxcbiAgICAgICAgICAgIHRoaXMuZGlzYWJsZWQgfHwgdGhpcy5kaXNhYmxlZEZyb21Hcm91cCxcbiAgICAgICAgICApO1xuICAgICAgICAgIHRoaXMudXBkYXRlQXJpYURpc2FibGVkKCk7XG4gICAgICAgIH0sXG4gICAgICAgIGxhYmVsOiAocCkgPT4gKHRoaXMuZ3JvdXBMYWJlbCA9IHAubGFiZWwpLFxuICAgICAgfSksXG4gICAgKTtcblxuICAgIHRoaXMuYWRkQ29udHJvbGxlcihcbiAgICAgIG5ldyBTYmJQcm9wZXJ0eVdhdGNoZXJDb250cm9sbGVyKHRoaXMsICgpID0+IHRoaXMuY2xvc2VzdCgnc2JiLWF1dG9jb21wbGV0ZS1ncmlkJyksIHtcbiAgICAgICAgbmVnYXRpdmU6IChlKSA9PiB0aGlzLnRvZ2dsZVN0YXRlKCduZWdhdGl2ZScsIGUubmVnYXRpdmUpLFxuICAgICAgfSksXG4gICAgKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSB3aWxsVXBkYXRlKGNoYW5nZWRQcm9wZXJ0aWVzOiBQcm9wZXJ0eVZhbHVlczx0aGlzPik6IHZvaWQge1xuICAgIHN1cGVyLndpbGxVcGRhdGUoY2hhbmdlZFByb3BlcnRpZXMpO1xuICAgIGlmIChjaGFuZ2VkUHJvcGVydGllcy5oYXMoJ2Rpc2FibGVkJykpIHtcbiAgICAgIMm1c3RhdGVDb250cm9sbGVyKHRoaXMuY2xvc2VzdD8uKCdzYmItYXV0b2NvbXBsZXRlLWdyaWQtcm93JykpPy50b2dnbGUoXG4gICAgICAgICdkaXNhYmxlZCcsXG4gICAgICAgIHRoaXMuZGlzYWJsZWQgfHwgdGhpcy5kaXNhYmxlZEZyb21Hcm91cCxcbiAgICAgICk7XG4gICAgICB0aGlzLnVwZGF0ZUFyaWFEaXNhYmxlZCgpO1xuICAgIH1cbiAgfVxuXG4gIHByb3RlY3RlZCBzZWxlY3RCeUNsaWNrKGV2ZW50OiBNb3VzZUV2ZW50KTogdm9pZCB7XG4gICAgaWYgKHRoaXMuZGlzYWJsZWQgfHwgdGhpcy5kaXNhYmxlZEZyb21Hcm91cCkge1xuICAgICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgdGhpcy5zZWxlY3RWaWFVc2VySW50ZXJhY3Rpb24odHJ1ZSk7XG4gIH1cbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi1hdXRvY29tcGxldGUtZ3JpZC1vcHRpb24nOiBTYmJBdXRvY29tcGxldGVHcmlkT3B0aW9uRWxlbWVudDtcbiAgfVxufVxuIl0sIm5hbWVzIjpbIsm1c3RhdGVDb250cm9sbGVyIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQVNPLE1BQU0sMkJBQW1DO0lBYTFDLG9DQUFnQyxNQUFBOzswQkFEckMsY0FBYyw4QkFBOEIsQ0FBQzs7OztvQkFDYTtBQUFSLEVBQUEsbUJBQVEsWUFBdUI7QUFBQSxJQU1oRixjQUFBO0FBQ0UsWUFBQTtBQUhRLFdBQUEsV0FBVztBQUluQixXQUFLLGNBQ0gsSUFBSSw2QkFBNkIsTUFBTSxNQUFNLEtBQUssUUFBUSxnQ0FBZ0MsR0FBRztBQUFBLFFBQzNGLFVBQVUsQ0FBQyxNQUFLO0FBQ2QsZUFBSyxvQkFBb0IsRUFBRTtBQUMzQkEsMkJBQWlCLEtBQUssVUFBVSwyQkFBMkIsQ0FBQyxHQUFHLE9BQzdELFlBQ0EsS0FBSyxZQUFZLEtBQUssaUJBQWlCO0FBRXpDLGVBQUssbUJBQUE7QUFBQSxRQUNQO0FBQUEsUUFDQSxPQUFPLENBQUMsTUFBTyxLQUFLLGFBQWEsRUFBRTtBQUFBLE1BQUEsQ0FDcEMsQ0FBQztBQUdKLFdBQUssY0FDSCxJQUFJLDZCQUE2QixNQUFNLE1BQU0sS0FBSyxRQUFRLHVCQUF1QixHQUFHO0FBQUEsUUFDbEYsVUFBVSxDQUFDLE1BQU0sS0FBSyxZQUFZLFlBQVksRUFBRSxRQUFRO0FBQUEsTUFBQSxDQUN6RCxDQUFDO0FBQUEsSUFFTjtBQUFBLElBRW1CLFdBQVcsbUJBQXVDO0FBQ25FLFlBQU0sV0FBVyxpQkFBaUI7QUFDbEMsVUFBSSxrQkFBa0IsSUFBSSxVQUFVLEdBQUc7QUFDckNBLHlCQUFpQixLQUFLLFVBQVUsMkJBQTJCLENBQUMsR0FBRyxPQUM3RCxZQUNBLEtBQUssWUFBWSxLQUFLLGlCQUFpQjtBQUV6QyxhQUFLLG1CQUFBO0FBQUEsTUFDUDtBQUFBLElBQ0Y7QUFBQSxJQUVVLGNBQWMsT0FBaUI7QUFDdkMsVUFBSSxLQUFLLFlBQVksS0FBSyxtQkFBbUI7QUFDM0MsY0FBTSxnQkFBQTtBQUNOO0FBQUEsTUFDRjtBQUVBLFdBQUsseUJBQXlCLElBQUk7QUFBQSxJQUNwQztBQUFBOztBQS9DRixpQkFBQSxNQUFBLG1CQUFBLEVBQUEsT0FBQSxXQUFBLEdBQUEsa0JBQUEsRUFBQSxNQUFBLFNBQUEsTUFBQSxXQUFBLE1BQUEsVUFBQSxVQUFBLEdBQUEsTUFBQSx1QkFBQTs7O1FBQ2tDLEdBQUEsT0FBTyxZQUNoQixHQUFBLFNBQXlCLENBQUMsaUJBQWlCLEtBQUssR0FGbkUsa0JBQUEsWUFBQSx1QkFBQSxHQUE2Qzs7OyJ9
@@ -19,7 +19,7 @@ const style = css`:host {
19
19
  display: block;
20
20
  }
21
21
 
22
- :host([data-negative]) {
22
+ :host(:is(:state(negative),[state--negative])) {
23
23
  --sbb-autocomplete-grid-row-color: var(--sbb-color-3-negative);
24
24
  --sbb-autocomplete-grid-row-background-color-hover: var(--sbb-background-color-3-negative);
25
25
  --sbb-autocomplete-grid-row-disabled-border-color: var(--sbb-border-color-5);
@@ -28,18 +28,18 @@ const style = css`:host {
28
28
  }
29
29
 
30
30
  @media (any-hover: hover) {
31
- :host(:hover:not([data-disabled])) {
31
+ :host(:hover:not(:is(:state(disabled),[state--disabled]))) {
32
32
  --sbb-autocomplete-grid-row-background-color: var(
33
33
  --sbb-autocomplete-grid-row-background-color-hover
34
34
  );
35
35
  }
36
36
  }
37
37
 
38
- :host([data-disabled]) {
38
+ :host(:is(:state(disabled),[state--disabled])) {
39
39
  --sbb-autocomplete-grid-row-cursor: var(--sbb-cursor-default);
40
40
  }
41
41
  @media (forced-colors: active) {
42
- :host([data-disabled]) {
42
+ :host(:is(:state(disabled),[state--disabled])) {
43
43
  --sbb-autocomplete-grid-row-color: GrayText;
44
44
  }
45
45
  }
@@ -62,11 +62,11 @@ const style = css`:host {
62
62
  -webkit-tap-highlight-color: transparent;
63
63
  -webkit-text-fill-color: var(--sbb-autocomplete-grid-row-color);
64
64
  }
65
- :host([data-disabled]) .sbb-autocomplete-grid-row {
65
+ :host(:is(:state(disabled),[state--disabled])) .sbb-autocomplete-grid-row {
66
66
  position: relative;
67
67
  z-index: 0;
68
68
  }
69
- :host([data-disabled]) .sbb-autocomplete-grid-row::before {
69
+ :host(:is(:state(disabled),[state--disabled])) .sbb-autocomplete-grid-row::before {
70
70
  content: "";
71
71
  display: block;
72
72
  position: absolute;
@@ -77,7 +77,7 @@ const style = css`:host {
77
77
  z-index: -1;
78
78
  }
79
79
  @media (forced-colors: active) {
80
- :host([data-disabled]) .sbb-autocomplete-grid-row::before {
80
+ :host(:is(:state(disabled),[state--disabled])) .sbb-autocomplete-grid-row::before {
81
81
  border-color: GrayText;
82
82
  }
83
83
  }`;
@@ -6,15 +6,15 @@ interface IAccessAttribute {
6
6
  icon: string;
7
7
  }
8
8
  /**
9
- * @param legs: An array of Leg objects representing the journey legs.
10
- * @param departureWalk: The walking distance in minutes from the departure point to the first leg.
11
- * @param arrivalWalk: The walking distance in minutes from the last leg to the arrival point.
12
- * @param currentLanguage: The current language for localization.
13
- * @param a11yFootpath: Whether the a11y-icon should be shown.
14
9
  * @returns renderDepartureTimeAttribute: A function that renders the element for the departure time attribute.
15
10
  * @returns renderArrivalTimeAttribute: A function that renders the element for the arrival time attribute.
16
11
  * @returns arrivalTimeAttribute: The access attribute for the arrival time.
17
12
  * @returns departureTimeAttribute: The access attribute for the departure time.
13
+ * @param legs An array of Leg objects representing the journey legs.
14
+ * @param departureWalk The walking distance in minutes from the departure point to the first leg.
15
+ * @param arrivalWalk The walking distance in minutes from the last leg to the arrival point.
16
+ * @param currentLanguage The current language for localization.
17
+ * @param a11yFootpath Whether the a11y-icon should be shown.
18
18
  */
19
19
  export declare function getDepartureArrivalTimeAttribute(legs: Leg[], departureWalk: number, arrivalWalk: number, currentLanguage: string, a11yFootpath?: boolean): {
20
20
  renderDepartureTimeAttribute: () => TemplateResult;
@@ -122,4 +122,4 @@ function getDepartureArrivalTimeAttribute(legs, departureWalk, arrivalWalk, curr
122
122
  export {
123
123
  getDepartureArrivalTimeAttribute
124
124
  };
125
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"access-leg-helper.js","sources":["../../../../../src/elements-experimental/core/timetable/access-leg-helper.ts"],"sourcesContent":["// This helper file contains several functions related to accessing attributes for the connections.\n\nimport {\n  i18nWalkingDistanceArrival,\n  i18nWalkingDistanceDeparture,\n} from '@sbb-esta/lyne-elements/core/i18n.js';\nimport type { TemplateResult } from 'lit';\nimport { html, nothing } from 'lit';\n\nimport {\n  extractTimeAndStringFromNoticeText,\n  isConnectionLeg,\n  isRideLeg,\n} from './timetable-helper.ts';\nimport type { Leg, PtConnectionLeg, PtRideLeg } from './timetable-properties.ts';\n\nimport '@sbb-esta/lyne-elements/icon.js';\n\ninterface IAccessAttribute {\n  duration: number;\n  text: string;\n  icon: string;\n}\n\n/**\n * @returns the attribute of a ConnectionLeg\n */\nfunction getPTConnectionAttribute(\n  leg: PtRideLeg | PtConnectionLeg,\n  connectionLegNotice: string[],\n): IAccessAttribute | null {\n  const connectionFirstLeg = isConnectionLeg(leg) ? (leg as PtConnectionLeg) : null;\n\n  const connectionFirstLegNotice = connectionFirstLeg\n    ? connectionFirstLeg?.notices?.filter((notice) => connectionLegNotice.includes(notice.name))[0]\n    : null;\n\n  return connectionFirstLegNotice\n    ? {\n        duration: connectionFirstLeg?.duration || 0,\n        text: connectionFirstLegNotice?.text?.template || '',\n        icon: 'walk-small',\n      }\n    : null;\n}\n\n/**\n * @returns the extended enter attribute of the PTRideLeg\n */\nfunction getFirstExtendedLegAttribute(\n  leg: PtRideLeg | PtConnectionLeg,\n  departureWalk: number,\n  a11yFootpath: boolean | undefined,\n  currentLanguage: string,\n): IAccessAttribute | null {\n  // Extended enter\n  const extendedFirstLeg = isRideLeg(leg)\n    ? (leg as PtRideLeg)?.serviceJourney?.notices?.filter((notice) =>\n        ['CI'].includes(notice.name),\n      )[0]\n    : null;\n\n  const extractTimeAndString =\n    extendedFirstLeg && extractTimeAndStringFromNoticeText(extendedFirstLeg);\n\n  return extendedFirstLeg\n    ? {\n        duration: (extractTimeAndString?.duration || 0) + (departureWalk || 0),\n        text: a11yFootpath\n          ? i18nWalkingDistanceDeparture[currentLanguage]\n          : extractTimeAndString?.text || '',\n        icon: a11yFootpath ? 'wheelchair-small' : `sa-${extendedFirstLeg?.name?.toLowerCase()}`,\n      }\n    : null;\n}\n\n/**\n * @returns the extended exit attribute of the PTRideLeg\n */\nfunction getLastExtendedLegAttribute(\n  leg: Leg,\n  arrivalWalk: number,\n  a11yFootpath: boolean | undefined,\n  currentLanguage: string,\n): IAccessAttribute | null {\n  // Extended exit\n  const extendedLastLeg = isRideLeg(leg)\n    ? (leg as PtRideLeg)?.serviceJourney?.notices?.filter((notice) =>\n        ['CO'].includes(notice.name),\n      )[0]\n    : null;\n\n  const extractTimeAndString =\n    extendedLastLeg && extractTimeAndStringFromNoticeText(extendedLastLeg);\n\n  return extendedLastLeg\n    ? {\n        duration: (extractTimeAndString?.duration || 0) + (arrivalWalk || 0),\n        text: a11yFootpath\n          ? i18nWalkingDistanceArrival[currentLanguage]\n          : extractTimeAndString?.text || '',\n        icon: a11yFootpath ? 'wheelchair-small' : `sa-${extendedLastLeg?.name?.toLowerCase()}`,\n      }\n    : null;\n}\n\n/**\n * renders the extended exit/enter icon with the duration\n */\nfunction renderTransferTime(\n  duration: number | string,\n  icon: string,\n  currentLanguage: string,\n  label?: string,\n  type?: 'departure' | 'arrival',\n): TemplateResult {\n  return html`\n    <span class=\"sbb-pearl-chain__time-transfer sbb-pearl-chain__time-transfer--${icon}-${type}\">\n      <sbb-icon name=${icon}></sbb-icon>\n      <time datetime=${duration + 'M'}>\n        <span class=\"sbb-screen-reader-only\">\n          ${!label && type\n            ? type === 'departure'\n              ? i18nWalkingDistanceDeparture[currentLanguage]\n              : i18nWalkingDistanceArrival[currentLanguage]\n            : nothing}\n          ${label ? html`<span>${label}</span>` : nothing}&nbsp;\n        </span>\n        ${duration}\n        <span class=\"sbb-pearl-chain__time-walktime-prime-symbol\" aria-hidden=\"true\">'</span>\n        <span class=\"sbb-screen-reader-only\">min</span>\n      </time>\n    </span>\n  `;\n}\n\n/**\n * renders a walk-time icon with the walk duration\n */\nfunction renderWalkTime(\n  duration: number | string,\n  label: string,\n  variant: 'left' | 'right',\n  icon: string,\n): TemplateResult {\n  return html`\n    <span class=\"sbb-pearl-chain__time-walktime sbb-pearl-chain__time-walktime--${icon}-${variant}\">\n      <sbb-icon name=${icon}></sbb-icon>\n      <time datetime=${duration + 'M'}>\n        <span class=\"sbb-screen-reader-only\">${label}</span>\n        ${duration}\n        <span class=\"sbb-pearl-chain__time-walktime-prime-symbol\" aria-hidden=\"true\">'</span>\n      </time>\n    </span>\n  `;\n}\n\n/**\n * @param legs: An array of Leg objects representing the journey legs.\n * @param departureWalk: The walking distance in minutes from the departure point to the first leg.\n * @param arrivalWalk: The walking distance in minutes from the last leg to the arrival point.\n * @param currentLanguage: The current language for localization.\n * @param a11yFootpath: Whether the a11y-icon should be shown.\n * @returns renderDepartureTimeAttribute: A function that renders the element for the departure time attribute.\n * @returns renderArrivalTimeAttribute: A function that renders the element for the arrival time attribute.\n * @returns arrivalTimeAttribute: The access attribute for the arrival time.\n * @returns departureTimeAttribute: The access attribute for the departure time.\n */\nexport function getDepartureArrivalTimeAttribute(\n  legs: Leg[],\n  departureWalk: number,\n  arrivalWalk: number,\n  currentLanguage: string,\n  a11yFootpath?: boolean,\n): {\n  renderDepartureTimeAttribute: () => TemplateResult;\n  renderArrivalTimeAttribute: () => TemplateResult;\n  departureTimeAttribute: IAccessAttribute | null;\n  arrivalTimeAttribute: IAccessAttribute | null;\n} {\n  const connectionRideLeg =\n    legs &&\n    (legs.filter((leg) => isRideLeg(leg) || isConnectionLeg(leg))[0] as\n      | PtRideLeg\n      | PtConnectionLeg);\n\n  const connectionLegNotice = ['YM', 'YB', 'Y', 'YT'];\n\n  const connectionFirstLeg = getPTConnectionAttribute(connectionRideLeg, connectionLegNotice);\n  const extendedFirstLeg = getFirstExtendedLegAttribute(\n    connectionRideLeg,\n    departureWalk,\n    a11yFootpath,\n    currentLanguage,\n  );\n  const departureWalkAttribute = departureWalk\n    ? {\n        text: i18nWalkingDistanceDeparture[currentLanguage],\n        duration: departureWalk,\n        icon: a11yFootpath ? 'wheelchair-small' : 'walk-small',\n      }\n    : null;\n\n  const getDepartureType = (): IAccessAttribute | null => {\n    if (connectionFirstLeg) {\n      return connectionFirstLeg;\n    } else if (departureWalkAttribute && !extendedFirstLeg && !connectionFirstLeg) {\n      return departureWalkAttribute;\n    } else if (extendedFirstLeg) {\n      return extendedFirstLeg;\n    } else {\n      return null;\n    }\n  };\n\n  function renderDepartureTimeAttribute(): TemplateResult {\n    return html`\n      ${connectionFirstLeg\n        ? renderWalkTime(\n            connectionFirstLeg.duration,\n            connectionFirstLeg.text,\n            'left',\n            connectionFirstLeg.icon,\n          )\n        : nothing}\n      ${departureWalkAttribute && !extendedFirstLeg && !connectionFirstLeg\n        ? renderWalkTime(\n            departureWalkAttribute.duration,\n            departureWalkAttribute.text,\n            'left',\n            departureWalkAttribute.icon,\n          )\n        : nothing}\n      ${extendedFirstLeg\n        ? a11yFootpath\n          ? renderWalkTime(\n              extendedFirstLeg.duration,\n              extendedFirstLeg.text,\n              'left',\n              extendedFirstLeg.icon,\n            )\n          : renderTransferTime(\n              extendedFirstLeg.duration,\n              extendedFirstLeg.icon,\n              currentLanguage,\n              extendedFirstLeg.text,\n              'departure',\n            )\n        : nothing}\n    `;\n  }\n\n  const lastLeg = legs && legs[legs.length - 1];\n  const lastConnectionRideLeg =\n    (isConnectionLeg(lastLeg) || isRideLeg(lastLeg)) && (lastLeg as PtConnectionLeg | PtRideLeg);\n\n  const connectionLastLeg =\n    lastConnectionRideLeg && getPTConnectionAttribute(lastConnectionRideLeg, connectionLegNotice);\n  const extendedLastLeg =\n    lastConnectionRideLeg &&\n    getLastExtendedLegAttribute(lastConnectionRideLeg, arrivalWalk, a11yFootpath, currentLanguage);\n  const arrivalWalkAttribute = arrivalWalk\n    ? {\n        text: i18nWalkingDistanceArrival[currentLanguage],\n        duration: arrivalWalk,\n        icon: a11yFootpath ? 'wheelchair-small' : 'walk-small',\n      }\n    : null;\n\n  const getArrivalType = (): IAccessAttribute | null => {\n    if (connectionLastLeg) {\n      return connectionLastLeg;\n    } else if (arrivalWalkAttribute && !extendedLastLeg && !connectionLastLeg) {\n      return arrivalWalkAttribute;\n    } else if (extendedLastLeg) {\n      return extendedLastLeg;\n    } else {\n      return null;\n    }\n  };\n\n  function renderArrivalTimeAttribute(): TemplateResult {\n    return html`\n      ${connectionLastLeg\n        ? renderWalkTime(\n            connectionLastLeg.duration,\n            connectionLastLeg.text,\n            'right',\n            connectionLastLeg.icon,\n          )\n        : nothing}\n      ${arrivalWalkAttribute && !extendedLastLeg && !connectionLastLeg\n        ? renderWalkTime(\n            arrivalWalkAttribute.duration,\n            arrivalWalkAttribute.text,\n            'right',\n            arrivalWalkAttribute.icon,\n          )\n        : nothing}\n      ${extendedLastLeg\n        ? a11yFootpath\n          ? renderWalkTime(\n              extendedLastLeg.duration,\n              extendedLastLeg.text,\n              'right',\n              extendedLastLeg.icon,\n            )\n          : renderTransferTime(\n              extendedLastLeg.duration,\n              extendedLastLeg.icon,\n              currentLanguage,\n              extendedLastLeg.text,\n              'arrival',\n            )\n        : nothing}\n    `;\n  }\n\n  return {\n    renderDepartureTimeAttribute,\n    renderArrivalTimeAttribute,\n    departureTimeAttribute: getDepartureType(),\n    arrivalTimeAttribute: getArrivalType(),\n  };\n}\n"],"names":[],"mappings":";;;;AA2BA,SAAS,yBACP,KACA,qBAA6B;AAE7B,QAAM,qBAAqB,gBAAgB,GAAG,IAAK,MAA0B;AAE7E,QAAM,2BAA2B,qBAC7B,oBAAoB,SAAS,OAAO,CAAC,WAAW,oBAAoB,SAAS,OAAO,IAAI,CAAC,EAAE,CAAC,IAC5F;AAEJ,SAAO,2BACH;AAAA,IACE,UAAU,oBAAoB,YAAY;AAAA,IAC1C,MAAM,0BAA0B,MAAM,YAAY;AAAA,IAClD,MAAM;AAAA,EAAA,IAER;AACN;AAKA,SAAS,6BACP,KACA,eACA,cACA,iBAAuB;AAGvB,QAAM,mBAAmB,UAAU,GAAG,IACjC,KAAmB,gBAAgB,SAAS,OAAO,CAAC,WACnD,CAAC,IAAI,EAAE,SAAS,OAAO,IAAI,CAAC,EAC5B,CAAC,IACH;AAEJ,QAAM,uBACJ,oBAAoB,mCAAmC,gBAAgB;AAEzE,SAAO,mBACH;AAAA,IACE,WAAW,sBAAsB,YAAY,MAAM,iBAAiB;AAAA,IACpE,MAAM,eACF,6BAA6B,eAAe,IAC5C,sBAAsB,QAAQ;AAAA,IAClC,MAAM,eAAe,qBAAqB,MAAM,kBAAkB,MAAM,aAAa;AAAA,EAAA,IAEvF;AACN;AAKA,SAAS,4BACP,KACA,aACA,cACA,iBAAuB;AAGvB,QAAM,kBAAkB,UAAU,GAAG,IAChC,KAAmB,gBAAgB,SAAS,OAAO,CAAC,WACnD,CAAC,IAAI,EAAE,SAAS,OAAO,IAAI,CAAC,EAC5B,CAAC,IACH;AAEJ,QAAM,uBACJ,mBAAmB,mCAAmC,eAAe;AAEvE,SAAO,kBACH;AAAA,IACE,WAAW,sBAAsB,YAAY,MAAM,eAAe;AAAA,IAClE,MAAM,eACF,2BAA2B,eAAe,IAC1C,sBAAsB,QAAQ;AAAA,IAClC,MAAM,eAAe,qBAAqB,MAAM,iBAAiB,MAAM,aAAa;AAAA,EAAA,IAEtF;AACN;AAKA,SAAS,mBACP,UACA,MACA,iBACA,OACA,MAA8B;AAE9B,SAAO;AAAA,kFACyE,IAAI,IAAI,IAAI;AAAA,uBACvE,IAAI;AAAA,uBACJ,WAAW,GAAG;AAAA;AAAA,YAEzB,CAAC,SAAS,OACR,SAAS,cACP,6BAA6B,eAAe,IAC5C,2BAA2B,eAAe,IAC5C,OAAO;AAAA,YACT,QAAQ,aAAa,KAAK,YAAY,OAAO;AAAA;AAAA,UAE/C,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAMlB;AAKA,SAAS,eACP,UACA,OACA,SACA,MAAY;AAEZ,SAAO;AAAA,kFACyE,IAAI,IAAI,OAAO;AAAA,uBAC1E,IAAI;AAAA,uBACJ,WAAW,GAAG;AAAA,+CACU,KAAK;AAAA,UAC1C,QAAQ;AAAA;AAAA;AAAA;AAAA;AAKlB;AAaM,SAAU,iCACd,MACA,eACA,aACA,iBACA,cAAsB;AAOtB,QAAM,oBACJ,QACC,KAAK,OAAO,CAAC,QAAQ,UAAU,GAAG,KAAK,gBAAgB,GAAG,CAAC,EAAE,CAAC;AAIjE,QAAM,sBAAsB,CAAC,MAAM,MAAM,KAAK,IAAI;AAElD,QAAM,qBAAqB,yBAAyB,mBAAmB,mBAAmB;AAC1F,QAAM,mBAAmB,6BACvB,mBACA,eACA,cACA,eAAe;AAEjB,QAAM,yBAAyB,gBAC3B;AAAA,IACE,MAAM,6BAA6B,eAAe;AAAA,IAClD,UAAU;AAAA,IACV,MAAM,eAAe,qBAAqB;AAAA,EAAA,IAE5C;AAEJ,QAAM,mBAAmB,MAA8B;AACrD,QAAI,oBAAoB;AACtB,aAAO;AAAA,IACT,WAAW,0BAA0B,CAAC,oBAAoB,CAAC,oBAAoB;AAC7E,aAAO;AAAA,IACT,WAAW,kBAAkB;AAC3B,aAAO;AAAA,IACT,OAAO;AACL,aAAO;AAAA,IACT;AAAA,EACF;AAEA,WAAS,+BAA4B;AACnC,WAAO;AAAA,QACH,qBACE,eACE,mBAAmB,UACnB,mBAAmB,MACnB,QACA,mBAAmB,IAAI,IAEzB,OAAO;AAAA,QACT,0BAA0B,CAAC,oBAAoB,CAAC,qBAC9C,eACE,uBAAuB,UACvB,uBAAuB,MACvB,QACA,uBAAuB,IAAI,IAE7B,OAAO;AAAA,QACT,mBACE,eACE,eACE,iBAAiB,UACjB,iBAAiB,MACjB,QACA,iBAAiB,IAAI,IAEvB,mBACE,iBAAiB,UACjB,iBAAiB,MACjB,iBACA,iBAAiB,MACjB,WAAW,IAEf,OAAO;AAAA;AAAA,EAEf;AAEA,QAAM,UAAU,QAAQ,KAAK,KAAK,SAAS,CAAC;AAC5C,QAAM,yBACH,gBAAgB,OAAO,KAAK,UAAU,OAAO,MAAO;AAEvD,QAAM,oBACJ,yBAAyB,yBAAyB,uBAAuB,mBAAmB;AAC9F,QAAM,kBACJ,yBACA,4BAA4B,uBAAuB,aAAa,cAAc,eAAe;AAC/F,QAAM,uBAAuB,cACzB;AAAA,IACE,MAAM,2BAA2B,eAAe;AAAA,IAChD,UAAU;AAAA,IACV,MAAM,eAAe,qBAAqB;AAAA,EAAA,IAE5C;AAEJ,QAAM,iBAAiB,MAA8B;AACnD,QAAI,mBAAmB;AACrB,aAAO;AAAA,IACT,WAAW,wBAAwB,CAAC,mBAAmB,CAAC,mBAAmB;AACzE,aAAO;AAAA,IACT,WAAW,iBAAiB;AAC1B,aAAO;AAAA,IACT,OAAO;AACL,aAAO;AAAA,IACT;AAAA,EACF;AAEA,WAAS,6BAA0B;AACjC,WAAO;AAAA,QACH,oBACE,eACE,kBAAkB,UAClB,kBAAkB,MAClB,SACA,kBAAkB,IAAI,IAExB,OAAO;AAAA,QACT,wBAAwB,CAAC,mBAAmB,CAAC,oBAC3C,eACE,qBAAqB,UACrB,qBAAqB,MACrB,SACA,qBAAqB,IAAI,IAE3B,OAAO;AAAA,QACT,kBACE,eACE,eACE,gBAAgB,UAChB,gBAAgB,MAChB,SACA,gBAAgB,IAAI,IAEtB,mBACE,gBAAgB,UAChB,gBAAgB,MAChB,iBACA,gBAAgB,MAChB,SAAS,IAEb,OAAO;AAAA;AAAA,EAEf;AAEA,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA,wBAAwB,iBAAA;AAAA,IACxB,sBAAsB,eAAA;AAAA,EAAc;AAExC;"}
125
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"access-leg-helper.js","sources":["../../../../../src/elements-experimental/core/timetable/access-leg-helper.ts"],"sourcesContent":["// This helper file contains several functions related to accessing attributes for the connections.\n\nimport {\n  i18nWalkingDistanceArrival,\n  i18nWalkingDistanceDeparture,\n} from '@sbb-esta/lyne-elements/core/i18n.js';\nimport type { TemplateResult } from 'lit';\nimport { html, nothing } from 'lit';\n\nimport {\n  extractTimeAndStringFromNoticeText,\n  isConnectionLeg,\n  isRideLeg,\n} from './timetable-helper.ts';\nimport type { Leg, PtConnectionLeg, PtRideLeg } from './timetable-properties.ts';\n\nimport '@sbb-esta/lyne-elements/icon.js';\n\ninterface IAccessAttribute {\n  duration: number;\n  text: string;\n  icon: string;\n}\n\n/**\n * @returns the attribute of a ConnectionLeg\n */\nfunction getPTConnectionAttribute(\n  leg: PtRideLeg | PtConnectionLeg,\n  connectionLegNotice: string[],\n): IAccessAttribute | null {\n  const connectionFirstLeg = isConnectionLeg(leg) ? (leg as PtConnectionLeg) : null;\n\n  const connectionFirstLegNotice = connectionFirstLeg\n    ? connectionFirstLeg?.notices?.filter((notice) => connectionLegNotice.includes(notice.name))[0]\n    : null;\n\n  return connectionFirstLegNotice\n    ? {\n        duration: connectionFirstLeg?.duration || 0,\n        text: connectionFirstLegNotice?.text?.template || '',\n        icon: 'walk-small',\n      }\n    : null;\n}\n\n/**\n * @returns the extended enter attribute of the PTRideLeg\n */\nfunction getFirstExtendedLegAttribute(\n  leg: PtRideLeg | PtConnectionLeg,\n  departureWalk: number,\n  a11yFootpath: boolean | undefined,\n  currentLanguage: string,\n): IAccessAttribute | null {\n  // Extended enter\n  const extendedFirstLeg = isRideLeg(leg)\n    ? (leg as PtRideLeg)?.serviceJourney?.notices?.filter((notice) =>\n        ['CI'].includes(notice.name),\n      )[0]\n    : null;\n\n  const extractTimeAndString =\n    extendedFirstLeg && extractTimeAndStringFromNoticeText(extendedFirstLeg);\n\n  return extendedFirstLeg\n    ? {\n        duration: (extractTimeAndString?.duration || 0) + (departureWalk || 0),\n        text: a11yFootpath\n          ? i18nWalkingDistanceDeparture[currentLanguage]\n          : extractTimeAndString?.text || '',\n        icon: a11yFootpath ? 'wheelchair-small' : `sa-${extendedFirstLeg?.name?.toLowerCase()}`,\n      }\n    : null;\n}\n\n/**\n * @returns the extended exit attribute of the PTRideLeg\n */\nfunction getLastExtendedLegAttribute(\n  leg: Leg,\n  arrivalWalk: number,\n  a11yFootpath: boolean | undefined,\n  currentLanguage: string,\n): IAccessAttribute | null {\n  // Extended exit\n  const extendedLastLeg = isRideLeg(leg)\n    ? (leg as PtRideLeg)?.serviceJourney?.notices?.filter((notice) =>\n        ['CO'].includes(notice.name),\n      )[0]\n    : null;\n\n  const extractTimeAndString =\n    extendedLastLeg && extractTimeAndStringFromNoticeText(extendedLastLeg);\n\n  return extendedLastLeg\n    ? {\n        duration: (extractTimeAndString?.duration || 0) + (arrivalWalk || 0),\n        text: a11yFootpath\n          ? i18nWalkingDistanceArrival[currentLanguage]\n          : extractTimeAndString?.text || '',\n        icon: a11yFootpath ? 'wheelchair-small' : `sa-${extendedLastLeg?.name?.toLowerCase()}`,\n      }\n    : null;\n}\n\n/**\n * renders the extended exit/enter icon with the duration\n */\nfunction renderTransferTime(\n  duration: number | string,\n  icon: string,\n  currentLanguage: string,\n  label?: string,\n  type?: 'departure' | 'arrival',\n): TemplateResult {\n  return html`\n    <span class=\"sbb-pearl-chain__time-transfer sbb-pearl-chain__time-transfer--${icon}-${type}\">\n      <sbb-icon name=${icon}></sbb-icon>\n      <time datetime=${duration + 'M'}>\n        <span class=\"sbb-screen-reader-only\">\n          ${!label && type\n            ? type === 'departure'\n              ? i18nWalkingDistanceDeparture[currentLanguage]\n              : i18nWalkingDistanceArrival[currentLanguage]\n            : nothing}\n          ${label ? html`<span>${label}</span>` : nothing}&nbsp;\n        </span>\n        ${duration}\n        <span class=\"sbb-pearl-chain__time-walktime-prime-symbol\" aria-hidden=\"true\">'</span>\n        <span class=\"sbb-screen-reader-only\">min</span>\n      </time>\n    </span>\n  `;\n}\n\n/**\n * renders a walk-time icon with the walk duration\n */\nfunction renderWalkTime(\n  duration: number | string,\n  label: string,\n  variant: 'left' | 'right',\n  icon: string,\n): TemplateResult {\n  return html`\n    <span class=\"sbb-pearl-chain__time-walktime sbb-pearl-chain__time-walktime--${icon}-${variant}\">\n      <sbb-icon name=${icon}></sbb-icon>\n      <time datetime=${duration + 'M'}>\n        <span class=\"sbb-screen-reader-only\">${label}</span>\n        ${duration}\n        <span class=\"sbb-pearl-chain__time-walktime-prime-symbol\" aria-hidden=\"true\">'</span>\n      </time>\n    </span>\n  `;\n}\n\n/**\n * @returns renderDepartureTimeAttribute: A function that renders the element for the departure time attribute.\n * @returns renderArrivalTimeAttribute: A function that renders the element for the arrival time attribute.\n * @returns arrivalTimeAttribute: The access attribute for the arrival time.\n * @returns departureTimeAttribute: The access attribute for the departure time.\n * @param legs An array of Leg objects representing the journey legs.\n * @param departureWalk The walking distance in minutes from the departure point to the first leg.\n * @param arrivalWalk The walking distance in minutes from the last leg to the arrival point.\n * @param currentLanguage The current language for localization.\n * @param a11yFootpath Whether the a11y-icon should be shown.\n */\nexport function getDepartureArrivalTimeAttribute(\n  legs: Leg[],\n  departureWalk: number,\n  arrivalWalk: number,\n  currentLanguage: string,\n  a11yFootpath?: boolean,\n): {\n  renderDepartureTimeAttribute: () => TemplateResult;\n  renderArrivalTimeAttribute: () => TemplateResult;\n  departureTimeAttribute: IAccessAttribute | null;\n  arrivalTimeAttribute: IAccessAttribute | null;\n} {\n  const connectionRideLeg =\n    legs &&\n    (legs.filter((leg) => isRideLeg(leg) || isConnectionLeg(leg))[0] as\n      | PtRideLeg\n      | PtConnectionLeg);\n\n  const connectionLegNotice = ['YM', 'YB', 'Y', 'YT'];\n\n  const connectionFirstLeg = getPTConnectionAttribute(connectionRideLeg, connectionLegNotice);\n  const extendedFirstLeg = getFirstExtendedLegAttribute(\n    connectionRideLeg,\n    departureWalk,\n    a11yFootpath,\n    currentLanguage,\n  );\n  const departureWalkAttribute = departureWalk\n    ? {\n        text: i18nWalkingDistanceDeparture[currentLanguage],\n        duration: departureWalk,\n        icon: a11yFootpath ? 'wheelchair-small' : 'walk-small',\n      }\n    : null;\n\n  const getDepartureType = (): IAccessAttribute | null => {\n    if (connectionFirstLeg) {\n      return connectionFirstLeg;\n    } else if (departureWalkAttribute && !extendedFirstLeg && !connectionFirstLeg) {\n      return departureWalkAttribute;\n    } else if (extendedFirstLeg) {\n      return extendedFirstLeg;\n    } else {\n      return null;\n    }\n  };\n\n  function renderDepartureTimeAttribute(): TemplateResult {\n    return html`\n      ${connectionFirstLeg\n        ? renderWalkTime(\n            connectionFirstLeg.duration,\n            connectionFirstLeg.text,\n            'left',\n            connectionFirstLeg.icon,\n          )\n        : nothing}\n      ${departureWalkAttribute && !extendedFirstLeg && !connectionFirstLeg\n        ? renderWalkTime(\n            departureWalkAttribute.duration,\n            departureWalkAttribute.text,\n            'left',\n            departureWalkAttribute.icon,\n          )\n        : nothing}\n      ${extendedFirstLeg\n        ? a11yFootpath\n          ? renderWalkTime(\n              extendedFirstLeg.duration,\n              extendedFirstLeg.text,\n              'left',\n              extendedFirstLeg.icon,\n            )\n          : renderTransferTime(\n              extendedFirstLeg.duration,\n              extendedFirstLeg.icon,\n              currentLanguage,\n              extendedFirstLeg.text,\n              'departure',\n            )\n        : nothing}\n    `;\n  }\n\n  const lastLeg = legs && legs[legs.length - 1];\n  const lastConnectionRideLeg =\n    (isConnectionLeg(lastLeg) || isRideLeg(lastLeg)) && (lastLeg as PtConnectionLeg | PtRideLeg);\n\n  const connectionLastLeg =\n    lastConnectionRideLeg && getPTConnectionAttribute(lastConnectionRideLeg, connectionLegNotice);\n  const extendedLastLeg =\n    lastConnectionRideLeg &&\n    getLastExtendedLegAttribute(lastConnectionRideLeg, arrivalWalk, a11yFootpath, currentLanguage);\n  const arrivalWalkAttribute = arrivalWalk\n    ? {\n        text: i18nWalkingDistanceArrival[currentLanguage],\n        duration: arrivalWalk,\n        icon: a11yFootpath ? 'wheelchair-small' : 'walk-small',\n      }\n    : null;\n\n  const getArrivalType = (): IAccessAttribute | null => {\n    if (connectionLastLeg) {\n      return connectionLastLeg;\n    } else if (arrivalWalkAttribute && !extendedLastLeg && !connectionLastLeg) {\n      return arrivalWalkAttribute;\n    } else if (extendedLastLeg) {\n      return extendedLastLeg;\n    } else {\n      return null;\n    }\n  };\n\n  function renderArrivalTimeAttribute(): TemplateResult {\n    return html`\n      ${connectionLastLeg\n        ? renderWalkTime(\n            connectionLastLeg.duration,\n            connectionLastLeg.text,\n            'right',\n            connectionLastLeg.icon,\n          )\n        : nothing}\n      ${arrivalWalkAttribute && !extendedLastLeg && !connectionLastLeg\n        ? renderWalkTime(\n            arrivalWalkAttribute.duration,\n            arrivalWalkAttribute.text,\n            'right',\n            arrivalWalkAttribute.icon,\n          )\n        : nothing}\n      ${extendedLastLeg\n        ? a11yFootpath\n          ? renderWalkTime(\n              extendedLastLeg.duration,\n              extendedLastLeg.text,\n              'right',\n              extendedLastLeg.icon,\n            )\n          : renderTransferTime(\n              extendedLastLeg.duration,\n              extendedLastLeg.icon,\n              currentLanguage,\n              extendedLastLeg.text,\n              'arrival',\n            )\n        : nothing}\n    `;\n  }\n\n  return {\n    renderDepartureTimeAttribute,\n    renderArrivalTimeAttribute,\n    departureTimeAttribute: getDepartureType(),\n    arrivalTimeAttribute: getArrivalType(),\n  };\n}\n"],"names":[],"mappings":"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"}
@@ -6,6 +6,8 @@ export declare const mapRawDataToSeatReservation: (vehicleType: VehicleType) =>
6
6
  /**
7
7
  * Mapped place and coach information to place selection
8
8
  * @param place
9
+ * @param placeId
10
+ * @param deckIndex
9
11
  * @param coachIndex
10
12
  * @returns PlaceSelection
11
13
  */
@@ -16,7 +18,7 @@ export declare const mapPlaceInfosToPlaceSelection: (place: Place, placeId: stri
16
18
  * @param place
17
19
  * @param coach
18
20
  * @param placeId
19
- * @param coachDeckIndex
21
+ * @param deckIndex
20
22
  * @param coachIndex
21
23
  * @returns SeatReservationPlaceSelection
22
24
  */
@@ -1 +1 @@
1
- {"version":3,"file":"mapper.d.ts","sourceRoot":"","sources":["../../../../../../src/elements-experimental/seat-reservation/common/mapper/mapper.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,SAAS,EACT,uBAAuB,EACvB,KAAK,EACL,cAAc,EAEd,eAAe,EACf,6BAA6B,EAC7B,4BAA4B,EAC5B,WAAW,EACZ,MAAM,aAAa,CAAC;AAIrB;;GAEG;AACH,eAAO,MAAM,2BAA2B,GAAI,aAAa,WAAW,KAAG,eAmFtE,CAAC;AAEF;;;;;GAKG;AACH,eAAO,MAAM,6BAA6B,GACxC,OAAO,KAAK,EACZ,SAAS,MAAM,EACf,WAAW,MAAM,EACjB,YAAY,MAAM,KACjB,cASF,CAAC;AAEF;;;;;;;;;GASG;AACH,eAAO,MAAM,+CAA+C,GAC1D,OAAO,KAAK,EACZ,OAAO,SAAS,EAChB,SAAS,MAAM,EACf,WAAW,MAAM,EACjB,YAAY,MAAM,KACjB,6BAYF,CAAC;AAEF;;;;;;GAMG;AACH,eAAO,MAAM,6BAA6B,GACxC,YAAY,MAAM,EAClB,OAAO,SAAS,EAChB,yBAAyB,uBAAuB,KAC/C,4BAUF,CAAC"}
1
+ {"version":3,"file":"mapper.d.ts","sourceRoot":"","sources":["../../../../../../src/elements-experimental/seat-reservation/common/mapper/mapper.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,SAAS,EACT,uBAAuB,EACvB,KAAK,EACL,cAAc,EAEd,eAAe,EACf,6BAA6B,EAC7B,4BAA4B,EAC5B,WAAW,EACZ,MAAM,aAAa,CAAC;AAIrB;;GAEG;AACH,eAAO,MAAM,2BAA2B,GAAI,aAAa,WAAW,KAAG,eAmFtE,CAAC;AAEF;;;;;;;GAOG;AACH,eAAO,MAAM,6BAA6B,GACxC,OAAO,KAAK,EACZ,SAAS,MAAM,EACf,WAAW,MAAM,EACjB,YAAY,MAAM,KACjB,cASF,CAAC;AAEF;;;;;;;;;GASG;AACH,eAAO,MAAM,+CAA+C,GAC1D,OAAO,KAAK,EACZ,OAAO,SAAS,EAChB,SAAS,MAAM,EACf,WAAW,MAAM,EACjB,YAAY,MAAM,KACjB,6BAYF,CAAC;AAEF;;;;;;GAMG;AACH,eAAO,MAAM,6BAA6B,GACxC,YAAY,MAAM,EAClB,OAAO,SAAS,EAChB,yBAAyB,uBAAuB,KAC/C,4BAUF,CAAC"}