@sbb-esta/lyne-elements-dev 4.6.0-dev.1772035308 → 4.6.0-dev.1772036870

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.
@@ -1,25 +1,25 @@
1
1
  var it = (n) => {
2
2
  throw TypeError(n);
3
3
  };
4
- var st = (n, r, l) => r.has(n) || it("Cannot " + l);
5
- var p = (n, r, l) => (st(n, r, "read from private field"), l ? l.call(n) : r.get(n)), b = (n, r, l) => r.has(n) ? it("Cannot add the same private member more than once") : r instanceof WeakSet ? r.add(n) : r.set(n, l), s = (n, r, l, w) => (st(n, r, "write to private field"), w ? w.call(n, l) : r.set(n, l), l);
4
+ var st = (n, a, l) => a.has(n) || it("Cannot " + l);
5
+ var p = (n, a, l) => (st(n, a, "read from private field"), l ? l.call(n) : a.get(n)), b = (n, a, l) => a.has(n) ? it("Cannot add the same private member more than once") : a instanceof WeakSet ? a.add(n) : a.set(n, l), s = (n, a, l, x) => (st(n, a, "write to private field"), x ? x.call(n, l) : a.set(n, l), l);
6
6
  import { __esDecorate as c, __runInitializers as o } from "tslib";
7
- import { ResizeController as rt } from "@lit-labs/observers/resize-controller.js";
7
+ import { ResizeController as at } from "@lit-labs/observers/resize-controller.js";
8
8
  import { css as lt, isServer as k, nothing as ot, html as pt } from "lit";
9
9
  import { property as h } from "lit/decorators.js";
10
10
  import { ref as nt } from "lit/directives/ref.js";
11
11
  import { SbbOpenCloseBaseElement as bt } from "../core/base-elements.js";
12
12
  import { SbbEscapableOverlayController as ct, SbbPropertyWatcherController as ht } from "../core/controllers.js";
13
- import { idReference as at, forceType as E } from "../core/decorators.js";
13
+ import { idReference as rt, forceType as w } from "../core/decorators.js";
14
14
  import { isLean as dt, isZeroAnimationDuration as gt, isSafari as ut } from "../core/dom.js";
15
15
  import { SbbNegativeMixin as vt, SbbHydrationMixin as _t } from "../core/mixins.js";
16
16
  import { isEventOnElement as S, removeAriaComboBoxAttributes as mt, setOverlayPosition as ft, overlayGapFixCorners as Ot } from "../core/overlay.js";
17
17
  import { boxSizingStyles as yt } from "../core/styles.js";
18
- const xt = lt`.sbb-gap-fix-wrapper{position:relative;overflow:hidden;width:var(--sbb-options-panel-border-radius);height:var(--sbb-options-panel-border-radius);background-color:transparent}.sbb-gap-fix-corner{position:absolute;border-radius:50%;border:calc(var(--sbb-options-panel-border-radius) / 2) solid var(--sbb-options-panel-background-color);width:calc(var(--sbb-options-panel-border-radius) * 3);height:calc(var(--sbb-options-panel-border-radius) * 3);bottom:calc(var(--sbb-options-panel-border-radius) / 2 * -1)}.sbb-gap-fix-corner#left{left:calc(var(--sbb-options-panel-border-radius) / 2 * -1)}:host(:dir(rtl)) .sbb-gap-fix-corner#left{right:calc(var(--sbb-options-panel-border-radius) / 2 * -1);left:unset}.sbb-gap-fix-corner#right{right:calc(var(--sbb-options-panel-border-radius) / 2 * -1)}:host(:dir(rtl)) .sbb-gap-fix-corner#right{left:calc(var(--sbb-options-panel-border-radius) / 2 * -1);right:unset}:host{--sbb-scrollbar-thumb-width: .125rem;--sbb-scrollbar-thumb-width-hover: .25rem;--sbb-scrollbar-width-firefox: thin;--sbb-scrollbar-color: color-mix(in srgb, var(--sbb-color-black) 30%, transparent);--sbb-scrollbar-color: light-dark( color-mix(in srgb, var(--sbb-color-black) 30%, transparent), color-mix(in srgb, var(--sbb-color-white) 30%, transparent) );--sbb-scrollbar-color-hover: color-mix(in srgb, var(--sbb-color-black) 60%, transparent);--sbb-scrollbar-color-hover: light-dark( color-mix(in srgb, var(--sbb-color-black) 60%, transparent), color-mix(in srgb, var(--sbb-color-white) 60%, transparent) );--sbb-scrollbar-track-color: transparent;--sbb-options-panel-position-x: 0;--sbb-options-panel-position-y: 0;--_sbb-options-panel-max-height: min( var(--sbb-options-panel-max-height-calculated), var(--sbb-options-panel-max-height, 100000em) );--sbb-options-panel-min-height: var(--sbb-options-panel-origin-height);--sbb-options-panel-visibility: visible;--sbb-options-panel-width: fit-content;--sbb-options-panel-border-radius: var(--sbb-border-radius-4x);--sbb-options-panel-options-border-radius: 0 0 var(--sbb-options-panel-border-radius) var(--sbb-options-panel-border-radius);--sbb-options-panel-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-4x) );--sbb-options-panel-animation-timing-function: ease;--sbb-options-panel-gap-fix-opacity: 0;--sbb-options-panel-gap-fix-transform: none;--sbb-options-panel-gap-fix-top: calc( var(--sbb-options-panel-position-y) - var(--sbb-options-panel-border-radius) );--sbb-options-panel-background-color: var(--sbb-background-color-1);--sbb-options-panel-padding-block: var(--sbb-spacing-fixed-2x);--sbb-options-panel-divider-margin-block: var(--sbb-spacing-fixed-3x);--sbb-focus-outline-color: var(--sbb-focus-outline-color-default);--sbb-focus-outline-color: light-dark( var(--sbb-focus-outline-color-default), var(--sbb-focus-outline-color-dark) );--sbb-options-pointer-events: all;--sbb-options-panel-internal-z-index: var( --sbb-autocomplete-z-index, var(--sbb-overlay-default-z-index) );display:none}:host([size=s]){--sbb-options-panel-padding-block: var(--sbb-spacing-fixed-1x)}:host(:is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]),:is(:state(state-closing),[state--state-closing]))){display:block}:host([negative]){--sbb-scrollbar-color: color-mix(in srgb, var(--sbb-color-white) 30%, transparent);--sbb-scrollbar-color-hover: color-mix(in srgb, var(--sbb-color-white) 60%, transparent);--sbb-options-panel-background-color: var(--sbb-background-color-1-negative);--sbb-focus-outline-color: var(--sbb-focus-outline-color-dark)}:host(:not(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]),:is(:state(state-closing),[state--state-closing]))),:host(:is(:state(state-closed),[state--state-closed])){--sbb-options-panel-visibility: hidden;--sbb-options-pointer-events: none}:host(:is(:state(state-opening),[state--state-opening])){--sbb-options-panel-animation-name: open}:host(:is(:state(state-closing),[state--state-closing])){--sbb-options-panel-animation-name: close}:host(:is(:state(state-opened),[state--state-opened])),:host(:is(:state(state-opening),[state--state-opening])){--sbb-options-panel-gap-fix-opacity: 1}:host(:is(:state(options-panel-position-below),[state--options-panel-position-below])){--sbb-options-panel-animation-transform: translateY( calc((var(--sbb-options-panel-origin-height) / 2) * -1) )}:host(:is(:state(options-panel-position-above),[state--options-panel-position-above])){--sbb-options-panel-options-border-radius: var(--sbb-options-panel-border-radius) var(--sbb-options-panel-border-radius) 0 0;--sbb-options-panel-gap-fix-top: var(--_sbb-options-panel-max-height);--sbb-options-panel-gap-fix-transform: rotate(180deg);--sbb-options-panel-animation-transform: translateY( calc(var(--sbb-options-panel-origin-height) / 2) )}:host([preserve-icon-space]){--sbb-option-icon-container-display: block}::slotted(sbb-divider){margin-block:var(--sbb-options-panel-divider-margin-block)}.sbb-autocomplete__container{position:fixed;pointer-events:none;inset:0;z-index:var(--sbb-options-panel-internal-z-index)}.sbb-autocomplete__gap-fix{display:flex;justify-content:space-between;position:fixed;visibility:var(--sbb-options-panel-visibility);opacity:var(--sbb-options-panel-gap-fix-opacity);background-color:transparent;width:var(--sbb-options-panel-width);height:var(--sbb-options-panel-border-radius);top:var(--sbb-options-panel-gap-fix-top);left:var(--sbb-options-panel-position-x);transform:var(--sbb-options-panel-gap-fix-transform);transition:opacity var(--sbb-options-panel-animation-duration) var(--sbb-options-panel-animation-timing-function)}.sbb-autocomplete__panel{display:block;position:absolute;visibility:var(--sbb-options-panel-visibility);overflow:hidden;background-color:transparent;border:none;border-radius:var(--sbb-options-panel-border-radius);top:var(--sbb-options-panel-position-y);left:var(--sbb-options-panel-position-x);width:var(--sbb-options-panel-width);transition:box-shadow var(--sbb-options-panel-animation-duration) var(--sbb-options-panel-animation-timing-function)}.sbb-autocomplete__panel:before,.sbb-autocomplete__panel:after{content:"";display:none;position:relative;width:100%;height:var(--sbb-options-panel-origin-height);background-color:transparent;border-radius:var(--sbb-options-panel-border-radius);pointer-events:none;transition:box-shadow var(--sbb-options-panel-animation-duration) var(--sbb-options-panel-animation-timing-function);z-index:1}:host(:is(:state(options-panel-position-below),[state--options-panel-position-below])) .sbb-autocomplete__panel{inset-block-start:calc(var(--sbb-options-panel-position-y) - var(--sbb-options-panel-origin-height))}:host(:is(:is(:state(state-opened),[state--state-opened]),:is(:state(state-opening),[state--state-opening]))) .sbb-autocomplete__panel{box-shadow:var(--sbb-box-shadow-level-5-hard)}:host(:is(:is(:state(state-opened),[state--state-opened]),:is(:state(state-opening),[state--state-opening]))[negative]) .sbb-autocomplete__panel{box-shadow:var(--sbb-box-shadow-level-5-hard-negative)}:host(:is(:state(options-panel-position-below),[state--options-panel-position-below])) .sbb-autocomplete__panel:before{display:block}:host(:is(:state(options-panel-position-above),[state--options-panel-position-above])) .sbb-autocomplete__panel:after{display:block}:host(:is(:is(:state(state-opened),[state--state-opened]),:is(:state(state-opening),[state--state-opening])):is(:state(option-panel-origin-borderless),[state--option-panel-origin-borderless])) .sbb-autocomplete__panel:before,:host(:is(:is(:state(state-opened),[state--state-opened]),:is(:state(state-opening),[state--state-opening])):is(:state(option-panel-origin-borderless),[state--option-panel-origin-borderless])) .sbb-autocomplete__panel:after{box-shadow:var(--sbb-box-shadow-level-5-hard)}:host(:is(:is(:state(state-opened),[state--state-opened]),:is(:state(state-opening),[state--state-opening])):is(:state(option-panel-origin-borderless),[state--option-panel-origin-borderless])[negative]) .sbb-autocomplete__panel:before,:host(:is(:is(:state(state-opened),[state--state-opened]),:is(:state(state-opening),[state--state-opening])):is(:state(option-panel-origin-borderless),[state--option-panel-origin-borderless])[negative]) .sbb-autocomplete__panel:after{box-shadow:var(--sbb-box-shadow-level-5-hard-negative)}.sbb-autocomplete__wrapper{overflow:hidden}.sbb-autocomplete__options{background-color:var(--sbb-options-panel-background-color);padding-block:var(--sbb-options-panel-padding-block);padding-inline:0;border-radius:var(--sbb-options-panel-options-border-radius);max-height:var(--_sbb-options-panel-max-height);min-height:var(--sbb-options-panel-min-height);pointer-events:all;overflow-y:auto;animation-name:var(--sbb-options-panel-animation-name);animation-duration:var(--sbb-options-panel-animation-duration);animation-timing-function:var(--sbb-options-panel-animation-timing-function);--sbb-scrollbar-width: var(--sbb-spacing-fixed-3x)}.sbb-autocomplete__options::-webkit-scrollbar{width:var(--sbb-scrollbar-width);height:var(--sbb-scrollbar-width);background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-autocomplete__options::-webkit-scrollbar-corner{background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-autocomplete__options::-webkit-scrollbar-thumb{background-color:var(--sbb-scrollbar-color, currentcolor);border:calc(.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width))) solid transparent;border-radius:var(--sbb-border-radius-4x);background-clip:padding-box}.sbb-autocomplete__options::-webkit-scrollbar-thumb:hover{background-color:var(--sbb-scrollbar-color-hover, currentcolor);border-width:calc(.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width-hover)))}.sbb-autocomplete__options::-webkit-scrollbar-button,.sbb-autocomplete__options::-webkit-scrollbar-corner{display:none}@supports not selector(::-webkit-scrollbar){.sbb-autocomplete__options{scrollbar-width:var(--sbb-scrollbar-width-firefox);scrollbar-color:var(--sbb-scrollbar-color, currentcolor) var(--sbb-scrollbar-track-color, transparent)}}.sbb-autocomplete__options{pointer-events:var(--sbb-options-pointer-events)}@media(forced-colors:active){.sbb-autocomplete__options{border:var(--sbb-border-width-1x) solid CanvasText;border-top:none}}@keyframes open{0%{transform:var(--sbb-options-panel-animation-transform);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes close{0%{transform:translateY(0);opacity:1}to{transform:var(--sbb-options-panel-animation-transform);opacity:0}}`, C = ut;
18
+ const Et = lt`.sbb-gap-fix-wrapper{position:relative;overflow:hidden;width:var(--sbb-options-panel-border-radius);height:var(--sbb-options-panel-border-radius);background-color:transparent}.sbb-gap-fix-corner{position:absolute;border-radius:50%;border:calc(var(--sbb-options-panel-border-radius) / 2) solid var(--sbb-options-panel-background-color);width:calc(var(--sbb-options-panel-border-radius) * 3);height:calc(var(--sbb-options-panel-border-radius) * 3);bottom:calc(var(--sbb-options-panel-border-radius) / 2 * -1)}.sbb-gap-fix-corner#left{left:calc(var(--sbb-options-panel-border-radius) / 2 * -1)}:host(:dir(rtl)) .sbb-gap-fix-corner#left{right:calc(var(--sbb-options-panel-border-radius) / 2 * -1);left:unset}.sbb-gap-fix-corner#right{right:calc(var(--sbb-options-panel-border-radius) / 2 * -1)}:host(:dir(rtl)) .sbb-gap-fix-corner#right{left:calc(var(--sbb-options-panel-border-radius) / 2 * -1);right:unset}:host{--sbb-scrollbar-thumb-width: .125rem;--sbb-scrollbar-thumb-width-hover: .25rem;--sbb-scrollbar-width-firefox: thin;--sbb-scrollbar-color: color-mix(in srgb, var(--sbb-color-black) 30%, transparent);--sbb-scrollbar-color: light-dark( color-mix(in srgb, var(--sbb-color-black) 30%, transparent), color-mix(in srgb, var(--sbb-color-white) 30%, transparent) );--sbb-scrollbar-color-hover: color-mix(in srgb, var(--sbb-color-black) 60%, transparent);--sbb-scrollbar-color-hover: light-dark( color-mix(in srgb, var(--sbb-color-black) 60%, transparent), color-mix(in srgb, var(--sbb-color-white) 60%, transparent) );--sbb-scrollbar-track-color: transparent;--sbb-options-panel-position-x: 0;--sbb-options-panel-position-y: 0;--_sbb-options-panel-max-height: min( var(--sbb-options-panel-max-height-calculated), var(--sbb-options-panel-max-height, 100000em) );--sbb-options-panel-min-height: var(--sbb-options-panel-origin-height);--sbb-options-panel-visibility: visible;--sbb-options-panel-width: fit-content;--sbb-options-panel-border-radius: var(--sbb-border-radius-4x);--sbb-options-panel-options-border-radius: 0 0 var(--sbb-options-panel-border-radius) var(--sbb-options-panel-border-radius);--sbb-options-panel-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-4x) );--sbb-options-panel-animation-timing-function: ease;--sbb-options-panel-gap-fix-opacity: 0;--sbb-options-panel-gap-fix-transform: none;--sbb-options-panel-gap-fix-top: calc( var(--sbb-options-panel-position-y) - var(--sbb-options-panel-border-radius) );--sbb-options-panel-background-color: var(--sbb-background-color-1);--sbb-options-panel-padding-block: var(--sbb-spacing-fixed-2x);--sbb-options-panel-divider-margin-block: var(--sbb-spacing-fixed-3x);--sbb-focus-outline-color: var(--sbb-focus-outline-color-default);--sbb-focus-outline-color: light-dark( var(--sbb-focus-outline-color-default), var(--sbb-focus-outline-color-dark) );--sbb-options-pointer-events: all;--sbb-options-panel-internal-z-index: var( --sbb-autocomplete-z-index, var(--sbb-overlay-default-z-index) );display:none}:host([size=s]){--sbb-options-panel-padding-block: var(--sbb-spacing-fixed-1x)}:host(:is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]),:is(:state(state-closing),[state--state-closing]))){display:block}:host([negative]){--sbb-scrollbar-color: color-mix(in srgb, var(--sbb-color-white) 30%, transparent);--sbb-scrollbar-color-hover: color-mix(in srgb, var(--sbb-color-white) 60%, transparent);--sbb-options-panel-background-color: var(--sbb-background-color-1-negative);--sbb-focus-outline-color: var(--sbb-focus-outline-color-dark)}:host(:not(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]),:is(:state(state-closing),[state--state-closing]))),:host(:is(:state(state-closed),[state--state-closed])){--sbb-options-panel-visibility: hidden;--sbb-options-pointer-events: none}:host(:is(:state(state-opening),[state--state-opening])){--sbb-options-panel-animation-name: open}:host(:is(:state(state-closing),[state--state-closing])){--sbb-options-panel-animation-name: close}:host(:is(:state(state-opened),[state--state-opened])),:host(:is(:state(state-opening),[state--state-opening])){--sbb-options-panel-gap-fix-opacity: 1}:host(:is(:state(options-panel-position-below),[state--options-panel-position-below])){--sbb-options-panel-animation-transform: translateY( calc((var(--sbb-options-panel-origin-height) / 2) * -1) )}:host(:is(:state(options-panel-position-above),[state--options-panel-position-above])){--sbb-options-panel-options-border-radius: var(--sbb-options-panel-border-radius) var(--sbb-options-panel-border-radius) 0 0;--sbb-options-panel-gap-fix-top: var(--_sbb-options-panel-max-height);--sbb-options-panel-gap-fix-transform: rotate(180deg);--sbb-options-panel-animation-transform: translateY( calc(var(--sbb-options-panel-origin-height) / 2) )}:host([preserve-icon-space]){--sbb-option-icon-container-display: block}::slotted(sbb-divider){margin-block:var(--sbb-options-panel-divider-margin-block)}.sbb-autocomplete__container{position:fixed;pointer-events:none;inset:0;z-index:var(--sbb-options-panel-internal-z-index)}.sbb-autocomplete__gap-fix{display:flex;justify-content:space-between;position:fixed;visibility:var(--sbb-options-panel-visibility);opacity:var(--sbb-options-panel-gap-fix-opacity);background-color:transparent;width:var(--sbb-options-panel-width);height:var(--sbb-options-panel-border-radius);top:var(--sbb-options-panel-gap-fix-top);left:var(--sbb-options-panel-position-x);transform:var(--sbb-options-panel-gap-fix-transform);transition:opacity var(--sbb-options-panel-animation-duration) var(--sbb-options-panel-animation-timing-function)}.sbb-autocomplete__panel{display:block;position:absolute;visibility:var(--sbb-options-panel-visibility);overflow:hidden;background-color:transparent;border:none;border-radius:var(--sbb-options-panel-border-radius);top:var(--sbb-options-panel-position-y);left:var(--sbb-options-panel-position-x);width:var(--sbb-options-panel-width);transition:box-shadow var(--sbb-options-panel-animation-duration) var(--sbb-options-panel-animation-timing-function)}.sbb-autocomplete__panel:before,.sbb-autocomplete__panel:after{content:"";display:none;position:relative;width:100%;height:var(--sbb-options-panel-origin-height);background-color:transparent;border-radius:var(--sbb-options-panel-border-radius);pointer-events:none;transition:box-shadow var(--sbb-options-panel-animation-duration) var(--sbb-options-panel-animation-timing-function);z-index:1}:host(:is(:state(options-panel-position-below),[state--options-panel-position-below])) .sbb-autocomplete__panel{inset-block-start:calc(var(--sbb-options-panel-position-y) - var(--sbb-options-panel-origin-height))}:host(:is(:is(:state(state-opened),[state--state-opened]),:is(:state(state-opening),[state--state-opening]))) .sbb-autocomplete__panel{box-shadow:var(--sbb-box-shadow-level-5-hard)}:host(:is(:is(:state(state-opened),[state--state-opened]),:is(:state(state-opening),[state--state-opening]))[negative]) .sbb-autocomplete__panel{box-shadow:var(--sbb-box-shadow-level-5-hard-negative)}:host(:is(:state(options-panel-position-below),[state--options-panel-position-below])) .sbb-autocomplete__panel:before{display:block}:host(:is(:state(options-panel-position-above),[state--options-panel-position-above])) .sbb-autocomplete__panel:after{display:block}:host(:is(:is(:state(state-opened),[state--state-opened]),:is(:state(state-opening),[state--state-opening])):is(:state(option-panel-origin-borderless),[state--option-panel-origin-borderless])) .sbb-autocomplete__panel:before,:host(:is(:is(:state(state-opened),[state--state-opened]),:is(:state(state-opening),[state--state-opening])):is(:state(option-panel-origin-borderless),[state--option-panel-origin-borderless])) .sbb-autocomplete__panel:after{box-shadow:var(--sbb-box-shadow-level-5-hard)}:host(:is(:is(:state(state-opened),[state--state-opened]),:is(:state(state-opening),[state--state-opening])):is(:state(option-panel-origin-borderless),[state--option-panel-origin-borderless])[negative]) .sbb-autocomplete__panel:before,:host(:is(:is(:state(state-opened),[state--state-opened]),:is(:state(state-opening),[state--state-opening])):is(:state(option-panel-origin-borderless),[state--option-panel-origin-borderless])[negative]) .sbb-autocomplete__panel:after{box-shadow:var(--sbb-box-shadow-level-5-hard-negative)}.sbb-autocomplete__wrapper{overflow:hidden}.sbb-autocomplete__options{background-color:var(--sbb-options-panel-background-color);padding-block:var(--sbb-options-panel-padding-block);padding-inline:0;border-radius:var(--sbb-options-panel-options-border-radius);max-height:var(--_sbb-options-panel-max-height);min-height:var(--sbb-options-panel-min-height);pointer-events:all;overflow-y:auto;animation-name:var(--sbb-options-panel-animation-name);animation-duration:var(--sbb-options-panel-animation-duration);animation-timing-function:var(--sbb-options-panel-animation-timing-function);--sbb-scrollbar-width: var(--sbb-spacing-fixed-3x)}.sbb-autocomplete__options::-webkit-scrollbar{width:var(--sbb-scrollbar-width);height:var(--sbb-scrollbar-width);background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-autocomplete__options::-webkit-scrollbar-corner{background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-autocomplete__options::-webkit-scrollbar-thumb{background-color:var(--sbb-scrollbar-color, currentcolor);border:calc(.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width))) solid transparent;border-radius:var(--sbb-border-radius-4x);background-clip:padding-box}.sbb-autocomplete__options::-webkit-scrollbar-thumb:hover{background-color:var(--sbb-scrollbar-color-hover, currentcolor);border-width:calc(.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width-hover)))}.sbb-autocomplete__options::-webkit-scrollbar-button,.sbb-autocomplete__options::-webkit-scrollbar-corner{display:none}@supports not selector(::-webkit-scrollbar){.sbb-autocomplete__options{scrollbar-width:var(--sbb-scrollbar-width-firefox);scrollbar-color:var(--sbb-scrollbar-color, currentcolor) var(--sbb-scrollbar-track-color, transparent)}}.sbb-autocomplete__options{pointer-events:var(--sbb-options-pointer-events)}@media(forced-colors:active){.sbb-autocomplete__options{border:var(--sbb-border-width-1x) solid CanvasText;border-top:none}}@keyframes open{0%{transform:var(--sbb-options-panel-animation-transform);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes close{0%{transform:translateY(0);opacity:1}to{transform:var(--sbb-options-panel-animation-transform);opacity:0}}`, C = ut;
19
19
  let Bt = (() => {
20
- var d, g, u, v, _, m, f, O, y, x, a;
21
- let n = vt(_t(bt)), r, l = [], w = [], z, I = [], P = [], F, D = [], q = [], L, U = [], B = [], N, W = [], V = [], R, M = [], T = [], $, j = [], H = [], Y, Z = [], K = [], G, J = [], Q = [], X, tt = [], et = [];
22
- return a = class extends n {
20
+ var d, g, u, v, _, m, f, O, y, E, r;
21
+ let n = vt(_t(bt)), a, l = [], x = [], I, z = [], P = [], F, L = [], q = [], D, U = [], B = [], N, W = [], V = [], R, T = [], M = [], $, j = [], H = [], Y, Z = [], K = [], G, J = [], Q = [], X, tt = [], et = [];
22
+ return r = class extends n {
23
23
  constructor() {
24
24
  super();
25
25
  b(this, d);
@@ -31,8 +31,8 @@ let Bt = (() => {
31
31
  b(this, f);
32
32
  b(this, O);
33
33
  b(this, y);
34
- b(this, x);
35
- s(this, d, o(this, l, null)), s(this, g, (o(this, w), o(this, I, null))), s(this, u, (o(this, P), o(this, D, !1))), s(this, v, (o(this, q), o(this, U, !1))), s(this, _, (o(this, B), o(this, W, null))), s(this, m, (o(this, V), o(this, M, dt() ? "s" : "m"))), s(this, f, (o(this, T), o(this, j, !1))), s(this, O, (o(this, H), o(this, Z, !1))), s(this, y, (o(this, K), o(this, J, !1))), s(this, x, (o(this, Q), o(this, tt, "auto"))), this._triggerElement = o(this, et), this.activeOption = null, this.pendingAutoSelectedOption = null, this._originResizeObserver = new rt(this, {
34
+ b(this, E);
35
+ s(this, d, o(this, l, null)), s(this, g, (o(this, x), o(this, z, null))), s(this, u, (o(this, P), o(this, L, !1))), s(this, v, (o(this, q), o(this, U, !1))), s(this, _, (o(this, B), o(this, W, null))), s(this, m, (o(this, V), o(this, T, dt() ? "s" : "m"))), s(this, f, (o(this, M), o(this, j, !1))), s(this, O, (o(this, H), o(this, Z, !1))), s(this, y, (o(this, K), o(this, J, !1))), s(this, E, (o(this, Q), o(this, tt, "auto"))), this._triggerElement = o(this, et), this.activeOption = null, this.pendingAutoSelectedOption = null, this._originResizeObserver = new at(this, {
36
36
  target: null,
37
37
  skipInitial: !0,
38
38
  callback: () => {
@@ -41,7 +41,7 @@ let Bt = (() => {
41
41
  }), this._triggerAttributeObserver = k ? null : new MutationObserver((t) => {
42
42
  const e = t[0].target;
43
43
  (e.hasAttribute("disabled") || e.hasAttribute("readonly")) && this.close();
44
- }), this._isPointerDownEventOnMenu = !1, this._escapableOverlayController = new ct(this), this._optionsCount = 0, this._lastUserInput = null, this._pointerDownListener = (t) => {
44
+ }), this._isPointerDownEventOnMenu = !1, this._escapableOverlayController = new ct(this), this._optionsCount = 0, this._lastUserInput = null, this._isCustomChangeEvent = !1, this._pointerDownListener = (t) => {
45
45
  this._isPointerDownEventOnMenu = S(this._overlay, t);
46
46
  }, this._closeOnBackdropClick = (t) => {
47
47
  !this._isPointerDownEventOnMenu && !S(this._overlay, t) && !S(this.originElement, t) && this.close();
@@ -144,10 +144,10 @@ let Bt = (() => {
144
144
  * @default 'auto'
145
145
  */
146
146
  get position() {
147
- return p(this, x);
147
+ return p(this, E);
148
148
  }
149
149
  set position(t) {
150
- s(this, x, t);
150
+ s(this, E, t);
151
151
  }
152
152
  /** Returns the element where the autocomplete overlay is attached to. */
153
153
  get originElement() {
@@ -206,7 +206,7 @@ let Bt = (() => {
206
206
  this.pendingAutoSelectedOption = t, this._setInputValue(t);
207
207
  }
208
208
  _setValueAndDispatchEvents(t, e = !1) {
209
- this.options.filter((i) => i.id !== t.id && i.selected).forEach((i) => i.selected = !1), this.pendingAutoSelectedOption = null, this.triggerElement && (this._setInputValue(t), this.triggerElement.dispatchEvent(new Event("change", { bubbles: !0 })), this.triggerElement.dispatchEvent(new InputEvent("input", { bubbles: !0, composed: !0 })), this._lastUserInput = null, this.triggerElement.dispatchEvent(new CustomEvent("inputAutocomplete", {
209
+ this.options.filter((i) => i.id !== t.id && i.selected).forEach((i) => i.selected = !1), this.pendingAutoSelectedOption = null, this.triggerElement && (this._setInputValue(t), this._isCustomChangeEvent = !0, this.triggerElement.dispatchEvent(new Event("change", { bubbles: !0 })), this.triggerElement.dispatchEvent(new InputEvent("input", { bubbles: !0, composed: !0 })), this._lastUserInput = null, this.triggerElement.dispatchEvent(new CustomEvent("inputAutocomplete", {
210
210
  detail: { option: t }
211
211
  })), e || this.triggerElement.focus());
212
212
  }
@@ -249,12 +249,16 @@ let Bt = (() => {
249
249
  }), this.triggerElement.addEventListener("input", (i) => {
250
250
  const A = i.target.value;
251
251
  A && this.open(), this._highlightOptions(A), this._lastUserInput = A, this.pendingAutoSelectedOption = null;
252
- }, { signal: this._triggerAbortController.signal }), this.triggerElement.addEventListener("keydown", (i) => this._closedPanelKeyboardInteraction(i), {
252
+ }, { signal: this._triggerAbortController.signal }), this.triggerElement.addEventListener("change", (i) => {
253
+ this.requireSelection && !this._isCustomChangeEvent && i.stopImmediatePropagation(), this._isCustomChangeEvent = !1;
254
+ }, { signal: this._triggerAbortController.signal, capture: !0 }), this.triggerElement.addEventListener("keydown", (i) => this._closedPanelKeyboardInteraction(i), {
253
255
  signal: this._triggerAbortController.signal,
254
256
  // We need key event to run before any other subscription to guarantee a correct
255
257
  // interaction with other components (necessary for the 'sbb-chip-group' use case).
256
258
  capture: !0
257
- });
259
+ }), this.triggerElement.addEventListener("blur", (i) => {
260
+ this.contains(i.relatedTarget) || this.requireSelection && this.triggerElement && this._lastUserInput && (Object.getOwnPropertyDescriptor(HTMLInputElement.prototype, "value").set.call(this.triggerElement, ""), this._highlightOptions(""), this._isCustomChangeEvent = !0, this.triggerElement.dispatchEvent(new Event("change", { bubbles: !0 })), this.triggerElement.dispatchEvent(new InputEvent("input", { bubbles: !0, composed: !0 })));
261
+ }, { signal: this._triggerAbortController.signal, capture: !0 });
258
262
  }
259
263
  // Set overlay position, width and max height
260
264
  _setOverlayPosition(t = this.originElement) {
@@ -272,7 +276,7 @@ let Bt = (() => {
272
276
  this.state = "opened", this.originElement && this._originResizeObserver.observe(this.originElement), this.triggerElement?.setAttribute("aria-expanded", "true"), this.dispatchOpenEvent();
273
277
  }
274
278
  _handleClosing() {
275
- this.state = "closed", this.hidePopover?.(), this.triggerElement?.setAttribute("aria-expanded", "false"), this.requireSelection && this.triggerElement && this._lastUserInput && (Object.getOwnPropertyDescriptor(HTMLInputElement.prototype, "value").set.call(this.triggerElement, ""), this._highlightOptions(""), this.triggerElement.dispatchEvent(new Event("change", { bubbles: !0 })), this.triggerElement.dispatchEvent(new InputEvent("input", { bubbles: !0, composed: !0 }))), this.resetActiveElement(), this._optionContainer.scrollTop = 0, this._escapableOverlayController.disconnect(), this.dispatchCloseEvent();
279
+ this.state = "closed", this.hidePopover?.(), this.triggerElement?.setAttribute("aria-expanded", "false"), this.resetActiveElement(), this._optionContainer.scrollTop = 0, this._escapableOverlayController.disconnect(), this.dispatchCloseEvent();
276
280
  }
277
281
  _attachOpenPanelEvents() {
278
282
  this._openPanelEventsController = new AbortController(), document.addEventListener("scroll", () => this._setOverlayPosition(), {
@@ -300,7 +304,8 @@ let Bt = (() => {
300
304
  }), this.triggerElement?.addEventListener("blur", (t) => {
301
305
  this.contains(t.relatedTarget) || (this.autoSelectActiveOptionOnBlur && this.activeOption && this._lastUserInput && this.triggerElement?.value && (this.activeOption.selected = !0, this._setValueAndDispatchEvents(this.activeOption, !0)), this.close());
302
306
  }, {
303
- signal: this._openPanelEventsController.signal
307
+ signal: this._openPanelEventsController.signal,
308
+ capture: !0
304
309
  });
305
310
  }
306
311
  _closedPanelKeyboardInteraction(t) {
@@ -341,30 +346,30 @@ let Bt = (() => {
341
346
  </div>
342
347
  `;
343
348
  }
344
- }, d = new WeakMap(), g = new WeakMap(), u = new WeakMap(), v = new WeakMap(), _ = new WeakMap(), m = new WeakMap(), f = new WeakMap(), O = new WeakMap(), y = new WeakMap(), x = new WeakMap(), (() => {
349
+ }, d = new WeakMap(), g = new WeakMap(), u = new WeakMap(), v = new WeakMap(), _ = new WeakMap(), m = new WeakMap(), f = new WeakMap(), O = new WeakMap(), y = new WeakMap(), E = new WeakMap(), (() => {
345
350
  const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(n[Symbol.metadata] ?? null) : void 0;
346
- r = [at(), h()], z = [at(), h()], F = [E(), h({ attribute: "preserve-icon-space", reflect: !0, type: Boolean })], L = [E(), h({ attribute: "auto-active-first-option", type: Boolean })], N = [h({ attribute: !1 })], R = [h({ reflect: !0 })], $ = [E(), h({ attribute: "auto-select-active-option", type: Boolean })], Y = [E(), h({ attribute: "auto-select-active-option-on-blur", type: Boolean })], G = [E(), h({ attribute: "require-selection", type: Boolean })], X = [h()], c(a, null, r, { kind: "accessor", name: "origin", static: !1, private: !1, access: { has: (e) => "origin" in e, get: (e) => e.origin, set: (e, i) => {
351
+ a = [rt(), h()], I = [rt(), h()], F = [w(), h({ attribute: "preserve-icon-space", reflect: !0, type: Boolean })], D = [w(), h({ attribute: "auto-active-first-option", type: Boolean })], N = [h({ attribute: !1 })], R = [h({ reflect: !0 })], $ = [w(), h({ attribute: "auto-select-active-option", type: Boolean })], Y = [w(), h({ attribute: "auto-select-active-option-on-blur", type: Boolean })], G = [w(), h({ attribute: "require-selection", type: Boolean })], X = [h()], c(r, null, a, { kind: "accessor", name: "origin", static: !1, private: !1, access: { has: (e) => "origin" in e, get: (e) => e.origin, set: (e, i) => {
347
352
  e.origin = i;
348
- } }, metadata: t }, l, w), c(a, null, z, { kind: "accessor", name: "trigger", static: !1, private: !1, access: { has: (e) => "trigger" in e, get: (e) => e.trigger, set: (e, i) => {
353
+ } }, metadata: t }, l, x), c(r, null, I, { kind: "accessor", name: "trigger", static: !1, private: !1, access: { has: (e) => "trigger" in e, get: (e) => e.trigger, set: (e, i) => {
349
354
  e.trigger = i;
350
- } }, metadata: t }, I, P), c(a, null, F, { kind: "accessor", name: "preserveIconSpace", static: !1, private: !1, access: { has: (e) => "preserveIconSpace" in e, get: (e) => e.preserveIconSpace, set: (e, i) => {
355
+ } }, metadata: t }, z, P), c(r, null, F, { kind: "accessor", name: "preserveIconSpace", static: !1, private: !1, access: { has: (e) => "preserveIconSpace" in e, get: (e) => e.preserveIconSpace, set: (e, i) => {
351
356
  e.preserveIconSpace = i;
352
- } }, metadata: t }, D, q), c(a, null, L, { kind: "accessor", name: "autoActiveFirstOption", static: !1, private: !1, access: { has: (e) => "autoActiveFirstOption" in e, get: (e) => e.autoActiveFirstOption, set: (e, i) => {
357
+ } }, metadata: t }, L, q), c(r, null, D, { kind: "accessor", name: "autoActiveFirstOption", static: !1, private: !1, access: { has: (e) => "autoActiveFirstOption" in e, get: (e) => e.autoActiveFirstOption, set: (e, i) => {
353
358
  e.autoActiveFirstOption = i;
354
- } }, metadata: t }, U, B), c(a, null, N, { kind: "accessor", name: "displayWith", static: !1, private: !1, access: { has: (e) => "displayWith" in e, get: (e) => e.displayWith, set: (e, i) => {
359
+ } }, metadata: t }, U, B), c(r, null, N, { kind: "accessor", name: "displayWith", static: !1, private: !1, access: { has: (e) => "displayWith" in e, get: (e) => e.displayWith, set: (e, i) => {
355
360
  e.displayWith = i;
356
- } }, metadata: t }, W, V), c(a, null, R, { kind: "accessor", name: "size", static: !1, private: !1, access: { has: (e) => "size" in e, get: (e) => e.size, set: (e, i) => {
361
+ } }, metadata: t }, W, V), c(r, null, R, { kind: "accessor", name: "size", static: !1, private: !1, access: { has: (e) => "size" in e, get: (e) => e.size, set: (e, i) => {
357
362
  e.size = i;
358
- } }, metadata: t }, M, T), c(a, null, $, { kind: "accessor", name: "autoSelectActiveOption", static: !1, private: !1, access: { has: (e) => "autoSelectActiveOption" in e, get: (e) => e.autoSelectActiveOption, set: (e, i) => {
363
+ } }, metadata: t }, T, M), c(r, null, $, { kind: "accessor", name: "autoSelectActiveOption", static: !1, private: !1, access: { has: (e) => "autoSelectActiveOption" in e, get: (e) => e.autoSelectActiveOption, set: (e, i) => {
359
364
  e.autoSelectActiveOption = i;
360
- } }, metadata: t }, j, H), c(a, null, Y, { kind: "accessor", name: "autoSelectActiveOptionOnBlur", static: !1, private: !1, access: { has: (e) => "autoSelectActiveOptionOnBlur" in e, get: (e) => e.autoSelectActiveOptionOnBlur, set: (e, i) => {
365
+ } }, metadata: t }, j, H), c(r, null, Y, { kind: "accessor", name: "autoSelectActiveOptionOnBlur", static: !1, private: !1, access: { has: (e) => "autoSelectActiveOptionOnBlur" in e, get: (e) => e.autoSelectActiveOptionOnBlur, set: (e, i) => {
361
366
  e.autoSelectActiveOptionOnBlur = i;
362
- } }, metadata: t }, Z, K), c(a, null, G, { kind: "accessor", name: "requireSelection", static: !1, private: !1, access: { has: (e) => "requireSelection" in e, get: (e) => e.requireSelection, set: (e, i) => {
367
+ } }, metadata: t }, Z, K), c(r, null, G, { kind: "accessor", name: "requireSelection", static: !1, private: !1, access: { has: (e) => "requireSelection" in e, get: (e) => e.requireSelection, set: (e, i) => {
363
368
  e.requireSelection = i;
364
- } }, metadata: t }, J, Q), c(a, null, X, { kind: "accessor", name: "position", static: !1, private: !1, access: { has: (e) => "position" in e, get: (e) => e.position, set: (e, i) => {
369
+ } }, metadata: t }, J, Q), c(r, null, X, { kind: "accessor", name: "position", static: !1, private: !1, access: { has: (e) => "position" in e, get: (e) => e.position, set: (e, i) => {
365
370
  e.position = i;
366
- } }, metadata: t }, tt, et), t && Object.defineProperty(a, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
367
- })(), a.styles = [yt, xt], a;
371
+ } }, metadata: t }, tt, et), t && Object.defineProperty(r, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
372
+ })(), r.styles = [yt, Et], r;
368
373
  })();
369
374
  export {
370
375
  Bt as SbbAutocompleteBaseElement
@@ -2616,6 +2616,16 @@
2616
2616
  "default": "null",
2617
2617
  "description": "Tracks input from keyboard."
2618
2618
  },
2619
+ {
2620
+ "kind": "field",
2621
+ "name": "_isCustomChangeEvent",
2622
+ "type": {
2623
+ "text": "boolean"
2624
+ },
2625
+ "privacy": "private",
2626
+ "default": "false",
2627
+ "description": "If true, the 'change' event source is an option selection or a 'requireSelection' field cleanup"
2628
+ },
2619
2629
  {
2620
2630
  "kind": "field",
2621
2631
  "name": "options",
@@ -4002,6 +4012,20 @@
4002
4012
  "module": "autocomplete/autocomplete-base-element.js"
4003
4013
  }
4004
4014
  },
4015
+ {
4016
+ "kind": "field",
4017
+ "name": "_isCustomChangeEvent",
4018
+ "type": {
4019
+ "text": "boolean"
4020
+ },
4021
+ "privacy": "private",
4022
+ "default": "false",
4023
+ "description": "If true, the 'change' event source is an option selection or a 'requireSelection' field cleanup",
4024
+ "inheritedFrom": {
4025
+ "name": "SbbAutocompleteBaseElement",
4026
+ "module": "autocomplete/autocomplete-base-element.js"
4027
+ }
4028
+ },
4005
4029
  {
4006
4030
  "kind": "method",
4007
4031
  "name": "open",
@@ -108089,219 +108113,6 @@
108089
108113
  }
108090
108114
  ]
108091
108115
  },
108092
- {
108093
- "kind": "javascript-module",
108094
- "path": "teaser-product/teaser-product-static/teaser-product-static.component.js",
108095
- "declarations": [
108096
- {
108097
- "kind": "class",
108098
- "description": "Displays a text and a footnote, combined with an image, to tease a product.",
108099
- "name": "SbbTeaserProductStaticElement",
108100
- "cssProperties": [
108101
- {
108102
- "description": "At which percentage the background should start getting transparent.",
108103
- "name": "--sbb-teaser-product-background-gradient-start",
108104
- "default": "25%"
108105
- },
108106
- {
108107
- "description": "At which percentage the background should be fully transparent.",
108108
- "name": "--sbb-teaser-product-background-gradient-end",
108109
- "default": "75%"
108110
- }
108111
- ],
108112
- "slots": [
108113
- {
108114
- "description": "Use this slot to provide the main content.",
108115
- "name": ""
108116
- },
108117
- {
108118
- "description": "Use this slot to provide an image or a `sbb-image` as a background.",
108119
- "name": "image"
108120
- },
108121
- {
108122
- "description": "Use this slot to provide a footnote.",
108123
- "name": "footnote"
108124
- }
108125
- ],
108126
- "members": [
108127
- {
108128
- "kind": "field",
108129
- "name": "imageAlignment",
108130
- "type": {
108131
- "text": "'after' | 'before'"
108132
- },
108133
- "privacy": "public",
108134
- "default": "'after'",
108135
- "description": "Whether the fully visible part of the image is aligned 'before' or 'after' the content.\nOnly relevant starting from large breakpoint.",
108136
- "attribute": "image-alignment",
108137
- "reflects": true,
108138
- "inheritedFrom": {
108139
- "name": "SbbTeaserProductCommonElementMixin",
108140
- "module": "teaser-product/common/teaser-product-common.js"
108141
- }
108142
- },
108143
- {
108144
- "kind": "method",
108145
- "name": "renderTemplate",
108146
- "privacy": "protected",
108147
- "return": {
108148
- "type": {
108149
- "text": "TemplateResult"
108150
- }
108151
- },
108152
- "description": "Override this method to render the component template.",
108153
- "inheritedFrom": {
108154
- "name": "SbbActionBaseElement",
108155
- "module": "core/base-elements/action-base-element.js"
108156
- }
108157
- },
108158
- {
108159
- "kind": "field",
108160
- "name": "negative",
108161
- "type": {
108162
- "text": "boolean"
108163
- },
108164
- "privacy": "public",
108165
- "default": "false",
108166
- "description": "Negative coloring variant flag.",
108167
- "attribute": "negative",
108168
- "reflects": true,
108169
- "inheritedFrom": {
108170
- "name": "SbbNegativeMixin",
108171
- "module": "core/mixins/negative-mixin.js"
108172
- }
108173
- },
108174
- {
108175
- "kind": "method",
108176
- "name": "toggleState",
108177
- "privacy": "protected",
108178
- "return": {
108179
- "type": {
108180
- "text": "void"
108181
- }
108182
- },
108183
- "parameters": [
108184
- {
108185
- "name": "value",
108186
- "type": {
108187
- "text": "string"
108188
- }
108189
- },
108190
- {
108191
- "name": "force",
108192
- "optional": true,
108193
- "type": {
108194
- "text": "boolean"
108195
- }
108196
- }
108197
- ],
108198
- "inheritedFrom": {
108199
- "name": "SbbActionBaseElement",
108200
- "module": "core/base-elements/action-base-element.js"
108201
- }
108202
- },
108203
- {
108204
- "kind": "field",
108205
- "name": "maybeDisabled",
108206
- "type": {
108207
- "text": "boolean | undefined"
108208
- },
108209
- "privacy": "protected",
108210
- "readonly": true,
108211
- "inheritedFrom": {
108212
- "name": "SbbActionBaseElement",
108213
- "module": "core/base-elements/action-base-element.js"
108214
- }
108215
- },
108216
- {
108217
- "kind": "field",
108218
- "name": "maybeDisabledInteractive",
108219
- "type": {
108220
- "text": "boolean | undefined"
108221
- },
108222
- "privacy": "protected",
108223
- "readonly": true,
108224
- "inheritedFrom": {
108225
- "name": "SbbActionBaseElement",
108226
- "module": "core/base-elements/action-base-element.js"
108227
- }
108228
- },
108229
- {
108230
- "kind": "method",
108231
- "name": "setupBaseEventHandlers",
108232
- "privacy": "protected",
108233
- "return": {
108234
- "type": {
108235
- "text": "void"
108236
- }
108237
- },
108238
- "inheritedFrom": {
108239
- "name": "SbbActionBaseElement",
108240
- "module": "core/base-elements/action-base-element.js"
108241
- }
108242
- }
108243
- ],
108244
- "mixins": [
108245
- {
108246
- "name": "SbbTeaserProductCommonElementMixin",
108247
- "module": "teaser-product/common.js"
108248
- }
108249
- ],
108250
- "superclass": {
108251
- "name": "SbbActionBaseElement",
108252
- "module": "core/base-elements.js"
108253
- },
108254
- "tagName": "sbb-teaser-product-static",
108255
- "customElement": true,
108256
- "attributes": [
108257
- {
108258
- "name": "image-alignment",
108259
- "type": {
108260
- "text": "'after' | 'before'"
108261
- },
108262
- "default": "'after'",
108263
- "description": "Whether the fully visible part of the image is aligned 'before' or 'after' the content.\nOnly relevant starting from large breakpoint.",
108264
- "fieldName": "imageAlignment",
108265
- "inheritedFrom": {
108266
- "name": "SbbTeaserProductCommonElementMixin",
108267
- "module": "teaser-product/common/teaser-product-common.js"
108268
- }
108269
- },
108270
- {
108271
- "name": "negative",
108272
- "type": {
108273
- "text": "boolean"
108274
- },
108275
- "default": "false",
108276
- "description": "Negative coloring variant flag.",
108277
- "fieldName": "negative",
108278
- "inheritedFrom": {
108279
- "name": "SbbNegativeMixin",
108280
- "module": "core/mixins/negative-mixin.js"
108281
- }
108282
- }
108283
- ]
108284
- }
108285
- ],
108286
- "exports": [
108287
- {
108288
- "kind": "js",
108289
- "name": "SbbTeaserProductStaticElement",
108290
- "declaration": {
108291
- "name": "SbbTeaserProductStaticElement",
108292
- "module": "teaser-product/teaser-product-static/teaser-product-static.component.js"
108293
- }
108294
- },
108295
- {
108296
- "kind": "custom-element-definition",
108297
- "name": "sbb-teaser-product-static",
108298
- "declaration": {
108299
- "name": "SbbTeaserProductStaticElement",
108300
- "module": "teaser-product/teaser-product-static/teaser-product-static.component.js"
108301
- }
108302
- }
108303
- ]
108304
- },
108305
108116
  {
108306
108117
  "kind": "javascript-module",
108307
108118
  "path": "teaser-product/teaser-product/teaser-product.component.js",
@@ -108742,6 +108553,219 @@
108742
108553
  }
108743
108554
  ]
108744
108555
  },
108556
+ {
108557
+ "kind": "javascript-module",
108558
+ "path": "teaser-product/teaser-product-static/teaser-product-static.component.js",
108559
+ "declarations": [
108560
+ {
108561
+ "kind": "class",
108562
+ "description": "Displays a text and a footnote, combined with an image, to tease a product.",
108563
+ "name": "SbbTeaserProductStaticElement",
108564
+ "cssProperties": [
108565
+ {
108566
+ "description": "At which percentage the background should start getting transparent.",
108567
+ "name": "--sbb-teaser-product-background-gradient-start",
108568
+ "default": "25%"
108569
+ },
108570
+ {
108571
+ "description": "At which percentage the background should be fully transparent.",
108572
+ "name": "--sbb-teaser-product-background-gradient-end",
108573
+ "default": "75%"
108574
+ }
108575
+ ],
108576
+ "slots": [
108577
+ {
108578
+ "description": "Use this slot to provide the main content.",
108579
+ "name": ""
108580
+ },
108581
+ {
108582
+ "description": "Use this slot to provide an image or a `sbb-image` as a background.",
108583
+ "name": "image"
108584
+ },
108585
+ {
108586
+ "description": "Use this slot to provide a footnote.",
108587
+ "name": "footnote"
108588
+ }
108589
+ ],
108590
+ "members": [
108591
+ {
108592
+ "kind": "field",
108593
+ "name": "imageAlignment",
108594
+ "type": {
108595
+ "text": "'after' | 'before'"
108596
+ },
108597
+ "privacy": "public",
108598
+ "default": "'after'",
108599
+ "description": "Whether the fully visible part of the image is aligned 'before' or 'after' the content.\nOnly relevant starting from large breakpoint.",
108600
+ "attribute": "image-alignment",
108601
+ "reflects": true,
108602
+ "inheritedFrom": {
108603
+ "name": "SbbTeaserProductCommonElementMixin",
108604
+ "module": "teaser-product/common/teaser-product-common.js"
108605
+ }
108606
+ },
108607
+ {
108608
+ "kind": "method",
108609
+ "name": "renderTemplate",
108610
+ "privacy": "protected",
108611
+ "return": {
108612
+ "type": {
108613
+ "text": "TemplateResult"
108614
+ }
108615
+ },
108616
+ "description": "Override this method to render the component template.",
108617
+ "inheritedFrom": {
108618
+ "name": "SbbActionBaseElement",
108619
+ "module": "core/base-elements/action-base-element.js"
108620
+ }
108621
+ },
108622
+ {
108623
+ "kind": "field",
108624
+ "name": "negative",
108625
+ "type": {
108626
+ "text": "boolean"
108627
+ },
108628
+ "privacy": "public",
108629
+ "default": "false",
108630
+ "description": "Negative coloring variant flag.",
108631
+ "attribute": "negative",
108632
+ "reflects": true,
108633
+ "inheritedFrom": {
108634
+ "name": "SbbNegativeMixin",
108635
+ "module": "core/mixins/negative-mixin.js"
108636
+ }
108637
+ },
108638
+ {
108639
+ "kind": "method",
108640
+ "name": "toggleState",
108641
+ "privacy": "protected",
108642
+ "return": {
108643
+ "type": {
108644
+ "text": "void"
108645
+ }
108646
+ },
108647
+ "parameters": [
108648
+ {
108649
+ "name": "value",
108650
+ "type": {
108651
+ "text": "string"
108652
+ }
108653
+ },
108654
+ {
108655
+ "name": "force",
108656
+ "optional": true,
108657
+ "type": {
108658
+ "text": "boolean"
108659
+ }
108660
+ }
108661
+ ],
108662
+ "inheritedFrom": {
108663
+ "name": "SbbActionBaseElement",
108664
+ "module": "core/base-elements/action-base-element.js"
108665
+ }
108666
+ },
108667
+ {
108668
+ "kind": "field",
108669
+ "name": "maybeDisabled",
108670
+ "type": {
108671
+ "text": "boolean | undefined"
108672
+ },
108673
+ "privacy": "protected",
108674
+ "readonly": true,
108675
+ "inheritedFrom": {
108676
+ "name": "SbbActionBaseElement",
108677
+ "module": "core/base-elements/action-base-element.js"
108678
+ }
108679
+ },
108680
+ {
108681
+ "kind": "field",
108682
+ "name": "maybeDisabledInteractive",
108683
+ "type": {
108684
+ "text": "boolean | undefined"
108685
+ },
108686
+ "privacy": "protected",
108687
+ "readonly": true,
108688
+ "inheritedFrom": {
108689
+ "name": "SbbActionBaseElement",
108690
+ "module": "core/base-elements/action-base-element.js"
108691
+ }
108692
+ },
108693
+ {
108694
+ "kind": "method",
108695
+ "name": "setupBaseEventHandlers",
108696
+ "privacy": "protected",
108697
+ "return": {
108698
+ "type": {
108699
+ "text": "void"
108700
+ }
108701
+ },
108702
+ "inheritedFrom": {
108703
+ "name": "SbbActionBaseElement",
108704
+ "module": "core/base-elements/action-base-element.js"
108705
+ }
108706
+ }
108707
+ ],
108708
+ "mixins": [
108709
+ {
108710
+ "name": "SbbTeaserProductCommonElementMixin",
108711
+ "module": "teaser-product/common.js"
108712
+ }
108713
+ ],
108714
+ "superclass": {
108715
+ "name": "SbbActionBaseElement",
108716
+ "module": "core/base-elements.js"
108717
+ },
108718
+ "tagName": "sbb-teaser-product-static",
108719
+ "customElement": true,
108720
+ "attributes": [
108721
+ {
108722
+ "name": "image-alignment",
108723
+ "type": {
108724
+ "text": "'after' | 'before'"
108725
+ },
108726
+ "default": "'after'",
108727
+ "description": "Whether the fully visible part of the image is aligned 'before' or 'after' the content.\nOnly relevant starting from large breakpoint.",
108728
+ "fieldName": "imageAlignment",
108729
+ "inheritedFrom": {
108730
+ "name": "SbbTeaserProductCommonElementMixin",
108731
+ "module": "teaser-product/common/teaser-product-common.js"
108732
+ }
108733
+ },
108734
+ {
108735
+ "name": "negative",
108736
+ "type": {
108737
+ "text": "boolean"
108738
+ },
108739
+ "default": "false",
108740
+ "description": "Negative coloring variant flag.",
108741
+ "fieldName": "negative",
108742
+ "inheritedFrom": {
108743
+ "name": "SbbNegativeMixin",
108744
+ "module": "core/mixins/negative-mixin.js"
108745
+ }
108746
+ }
108747
+ ]
108748
+ }
108749
+ ],
108750
+ "exports": [
108751
+ {
108752
+ "kind": "js",
108753
+ "name": "SbbTeaserProductStaticElement",
108754
+ "declaration": {
108755
+ "name": "SbbTeaserProductStaticElement",
108756
+ "module": "teaser-product/teaser-product-static/teaser-product-static.component.js"
108757
+ }
108758
+ },
108759
+ {
108760
+ "kind": "custom-element-definition",
108761
+ "name": "sbb-teaser-product-static",
108762
+ "declaration": {
108763
+ "name": "SbbTeaserProductStaticElement",
108764
+ "module": "teaser-product/teaser-product-static/teaser-product-static.component.js"
108765
+ }
108766
+ }
108767
+ ]
108768
+ },
108745
108769
  {
108746
108770
  "kind": "javascript-module",
108747
108771
  "path": "timetable-form/timetable-form/timetable-form.component.js",
@@ -72,6 +72,8 @@ export declare abstract class SbbAutocompleteBaseElement<T = string> extends Sbb
72
72
  private _optionsCount;
73
73
  /** Tracks input from keyboard. */
74
74
  private _lastUserInput;
75
+ /** If true, the 'change' event source is an option selection or a 'requireSelection' field cleanup */
76
+ private _isCustomChangeEvent;
75
77
  protected abstract get options(): SbbOptionBaseElement<T>[];
76
78
  constructor();
77
79
  protected abstract syncNegative(): void;
@@ -1 +1 @@
1
- {"version":3,"file":"autocomplete-base-element.d.ts","sourceRoot":"","sources":["../../../../src/elements/autocomplete/autocomplete-base-element.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"autocomplete-base-element.d.ts","sourceRoot":"","sources":["../../../../src/elements/autocomplete/autocomplete-base-element.ts"],"names":[],"mappings":"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"}
@@ -384,6 +384,7 @@ let SbbAutocompleteBaseElement = (() => {
384
384
  this._escapableOverlayController = new SbbEscapableOverlayController(this);
385
385
  this._optionsCount = 0;
386
386
  this._lastUserInput = null;
387
+ this._isCustomChangeEvent = false;
387
388
  this._pointerDownListener = (event) => {
388
389
  this._isPointerDownEventOnMenu = isEventOnElement(this._overlay, event);
389
390
  };
@@ -612,6 +613,7 @@ let SbbAutocompleteBaseElement = (() => {
612
613
  this.pendingAutoSelectedOption = null;
613
614
  if (this.triggerElement) {
614
615
  this._setInputValue(selectedOption);
616
+ this._isCustomChangeEvent = true;
615
617
  this.triggerElement.dispatchEvent(new Event("change", { bubbles: true }));
616
618
  this.triggerElement.dispatchEvent(new InputEvent("input", { bubbles: true, composed: true }));
617
619
  this._lastUserInput = null;
@@ -702,12 +704,31 @@ let SbbAutocompleteBaseElement = (() => {
702
704
  this._lastUserInput = value;
703
705
  this.pendingAutoSelectedOption = null;
704
706
  }, { signal: this._triggerAbortController.signal });
707
+ this.triggerElement.addEventListener("change", (event) => {
708
+ if (this.requireSelection && !this._isCustomChangeEvent) {
709
+ event.stopImmediatePropagation();
710
+ }
711
+ this._isCustomChangeEvent = false;
712
+ }, { signal: this._triggerAbortController.signal, capture: true });
705
713
  this.triggerElement.addEventListener("keydown", (event) => this._closedPanelKeyboardInteraction(event), {
706
714
  signal: this._triggerAbortController.signal,
707
715
  // We need key event to run before any other subscription to guarantee a correct
708
716
  // interaction with other components (necessary for the 'sbb-chip-group' use case).
709
717
  capture: true
710
718
  });
719
+ this.triggerElement.addEventListener("blur", (e) => {
720
+ if (this.contains(e.relatedTarget)) {
721
+ return;
722
+ }
723
+ if (this.requireSelection && this.triggerElement && this._lastUserInput) {
724
+ const setValue = Object.getOwnPropertyDescriptor(HTMLInputElement.prototype, "value").set;
725
+ setValue.call(this.triggerElement, "");
726
+ this._highlightOptions("");
727
+ this._isCustomChangeEvent = true;
728
+ this.triggerElement.dispatchEvent(new Event("change", { bubbles: true }));
729
+ this.triggerElement.dispatchEvent(new InputEvent("input", { bubbles: true, composed: true }));
730
+ }
731
+ }, { signal: this._triggerAbortController.signal, capture: true });
711
732
  }
712
733
  // Set overlay position, width and max height
713
734
  _setOverlayPosition(originElement = this.originElement) {
@@ -740,13 +761,6 @@ let SbbAutocompleteBaseElement = (() => {
740
761
  this.state = "closed";
741
762
  this.hidePopover?.();
742
763
  this.triggerElement?.setAttribute("aria-expanded", "false");
743
- if (this.requireSelection && this.triggerElement && this._lastUserInput) {
744
- const setValue = Object.getOwnPropertyDescriptor(HTMLInputElement.prototype, "value").set;
745
- setValue.call(this.triggerElement, "");
746
- this._highlightOptions("");
747
- this.triggerElement.dispatchEvent(new Event("change", { bubbles: true }));
748
- this.triggerElement.dispatchEvent(new InputEvent("input", { bubbles: true, composed: true }));
749
- }
750
764
  this.resetActiveElement();
751
765
  this._optionContainer.scrollTop = 0;
752
766
  this._escapableOverlayController.disconnect();
@@ -794,7 +808,8 @@ let SbbAutocompleteBaseElement = (() => {
794
808
  this.close();
795
809
  }
796
810
  }, {
797
- signal: this._openPanelEventsController.signal
811
+ signal: this._openPanelEventsController.signal,
812
+ capture: true
798
813
  });
799
814
  }
800
815
  _closedPanelKeyboardInteraction(event) {
@@ -888,4 +903,4 @@ let SbbAutocompleteBaseElement = (() => {
888
903
  export {
889
904
  SbbAutocompleteBaseElement
890
905
  };
891
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"autocomplete-base-element.js","sources":["../../../../src/elements/autocomplete/autocomplete-base-element.ts"],"sourcesContent":["import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  isServer,\n  nothing,\n  type PropertyDeclaration,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { SbbOpenCloseBaseElement } from '../core/base-elements.ts';\nimport {\n  SbbPropertyWatcherController,\n  SbbEscapableOverlayController,\n} from '../core/controllers.ts';\nimport { forceType, idReference } from '../core/decorators.ts';\nimport { isLean, isSafari, isZeroAnimationDuration } from '../core/dom.ts';\nimport { SbbHydrationMixin, SbbNegativeMixin } from '../core/mixins.ts';\nimport {\n  isEventOnElement,\n  overlayGapFixCorners,\n  removeAriaComboBoxAttributes,\n  setOverlayPosition,\n} from '../core/overlay.ts';\nimport { boxSizingStyles } from '../core/styles.ts';\nimport type { SbbFormFieldElement } from '../form-field/form-field/form-field.component.ts';\nimport type { SbbOptionBaseElement } from '../option.ts';\n\nimport style from './autocomplete-base-element.scss?lit&inline';\n\n/**\n * On Safari, the aria role 'listbox' must be on the host element, or else VoiceOver won't work at all.\n * On the other hand, JAWS and NVDA need the role to be \"closer\" to the options, or else optgroups won't work.\n */\nconst ariaRoleOnHost = isSafari;\n\nexport abstract class SbbAutocompleteBaseElement<T = string> extends SbbNegativeMixin(\n  SbbHydrationMixin(SbbOpenCloseBaseElement),\n) {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n\n  /**\n   * The element where the autocomplete will attach.\n   * If not set, as fallback there are two elements which can act as origin with following priority order:\n   * 1. `sbb-form-field` if it is an ancestor.\n   * 2. trigger element if set.\n   *\n   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor origin: HTMLElement | null = null;\n\n  /**\n   * The input element that will trigger the autocomplete opening.\n   * By default, the autocomplete will open on focus, click, input or `ArrowDown` keypress of the 'trigger' element.\n   * If not set, will search for the first 'input' child of a 'sbb-form-field' ancestor.\n   *\n   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor trigger: HTMLInputElement | null = null;\n\n  /** Whether the icon space is preserved when no icon is set. */\n  @forceType()\n  @property({ attribute: 'preserve-icon-space', reflect: true, type: Boolean })\n  public accessor preserveIconSpace: boolean = false;\n\n  /** Whether the first option is automatically activated when the autocomplete is opened. */\n  @forceType()\n  @property({ attribute: 'auto-active-first-option', type: Boolean })\n  public accessor autoActiveFirstOption: boolean = false;\n\n  /** Function that maps an option's control value to its display value in the trigger. */\n  @property({ attribute: false })\n  public accessor displayWith: ((value: T) => string) | null = null;\n\n  /**\n   * Size variant, either m or s.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 'm' | 's' = isLean() ? 's' : 'm';\n\n  /** Whether the active option should be selected as the user is navigating. */\n  @forceType()\n  @property({ attribute: 'auto-select-active-option', type: Boolean })\n  public accessor autoSelectActiveOption: boolean = false;\n\n  /**\n   * When enabled, the active option is automatically selected on blur.\n   * This is an experimental feature. It might be subject to changes.\n   */\n  @forceType()\n  @property({ attribute: 'auto-select-active-option-on-blur', type: Boolean })\n  public accessor autoSelectActiveOptionOnBlur: boolean = false;\n\n  /**\n   * Whether the user is required to make a selection when they're interacting with the\n   * autocomplete. If the user moves away from the autocomplete without selecting an option from\n   * the list, the value will be reset. If the user opens the panel and closes it without\n   * interacting or selecting a value, the initial value will be kept.\n   */\n  @forceType()\n  @property({ attribute: 'require-selection', type: Boolean })\n  public accessor requireSelection: boolean = false;\n\n  /**\n   * The position of the autocomplete panel relative to the trigger.\n   * @default 'auto'\n   */\n  @property()\n  public accessor position: 'auto' | 'above' | 'below' = 'auto';\n\n  /** Returns the element where the autocomplete overlay is attached to. */\n  public get originElement(): HTMLElement | null {\n    return (\n      this.origin ??\n      this.closest?.('sbb-form-field')?.shadowRoot?.querySelector?.('#overlay-anchor') ??\n      this.trigger ??\n      null\n    );\n  }\n\n  /** Returns the trigger element. */\n  public get triggerElement(): HTMLInputElement | null {\n    return this._triggerElement ?? null;\n  }\n  private _triggerElement?: HTMLInputElement | null;\n\n  protected abstract overlayId: string;\n  protected abstract panelRole: string;\n  protected activeOption: SbbOptionBaseElement<T> | null = null;\n  protected pendingAutoSelectedOption: SbbOptionBaseElement<T> | null = null;\n  private _originResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => {\n      if (this.state === 'opened') {\n        this._setOverlayPosition();\n      }\n    },\n  });\n  /** Listens to the changes on the `disabled` or `readonly` attribute of the trigger. */\n  private _triggerAttributeObserver = !isServer\n    ? new MutationObserver((mutations: MutationRecord[]): void => {\n        const input = mutations[0].target as HTMLInputElement;\n        if (input.hasAttribute('disabled') || input.hasAttribute('readonly')) {\n          this.close();\n        }\n      })\n    : null;\n  private _overlay!: HTMLElement;\n  private _optionContainer!: HTMLElement;\n  private _triggerAbortController!: AbortController;\n  private _openPanelEventsController!: AbortController;\n  private _isPointerDownEventOnMenu: boolean = false;\n  private _escapableOverlayController = new SbbEscapableOverlayController(this);\n  private _optionsCount = 0;\n\n  /** Tracks input from keyboard. */\n  private _lastUserInput: string | null = null;\n\n  protected abstract get options(): SbbOptionBaseElement<T>[];\n\n  public constructor() {\n    super();\n    this.addEventListener?.('optionselected', (e: Event) => this.onOptionSelected(e));\n    this.addController(\n      new SbbPropertyWatcherController(\n        this,\n        () => this.closest<SbbFormFieldElement>('sbb-form-field'),\n        {\n          negative: (e) => {\n            this.negative = e.negative;\n            this.syncNegative();\n          },\n          borderless: (e) => this.toggleState('option-panel-origin-borderless', e.borderless),\n        },\n      ),\n    );\n  }\n\n  protected abstract syncNegative(): void;\n  protected abstract setTriggerAttributes(element: HTMLInputElement): void;\n  protected abstract openedPanelKeyboardInteraction(event: KeyboardEvent): void;\n  protected abstract selectByKeyboard(event: KeyboardEvent): void;\n  protected abstract setNextActiveOption(event?: KeyboardEvent): void;\n  protected abstract resetActiveElement(): void;\n\n  /** Opens the autocomplete. */\n  public open(): void {\n    if (\n      this.state === 'opening' ||\n      this.state === 'opened' ||\n      !this._overlay ||\n      this.options.length === 0 ||\n      this._readonly() ||\n      !this.dispatchBeforeOpenEvent()\n    ) {\n      return;\n    }\n\n    this.showPopover?.();\n    this.state = 'opening';\n    this.triggerElement?.toggleAttribute('data-expanded', true);\n    const originElement = this.originElement;\n    if (!originElement) {\n      throw new Error(\n        'Cannot find the origin element. Please specify a valid element or check the usage of the \"origin\" property from the documentation',\n      );\n    }\n    this._setOverlayPosition(originElement);\n    this._setNextActiveOptionIfAutoActiveFirstOption();\n    this._attachOpenPanelEvents();\n    this._escapableOverlayController.connect();\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `opened` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleOpening();\n    }\n  }\n\n  /** Closes the autocomplete. */\n  public close(): void {\n    if (this.state === 'closing' || this.state === 'closed' || !this.dispatchBeforeCloseEvent()) {\n      return;\n    }\n\n    // A 'pending selection' is confirmed on panel close\n    if (this.pendingAutoSelectedOption) {\n      this.pendingAutoSelectedOption.selected = true;\n      this._setValueAndDispatchEvents(this.pendingAutoSelectedOption, true);\n    }\n\n    this.state = 'closing';\n    this.triggerElement?.removeAttribute('data-expanded');\n    this._openPanelEventsController.abort();\n    if (this.originElement) {\n      this._originResizeObserver.unobserve(this.originElement);\n    }\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `closed` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleClosing();\n    }\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-options-panel-animation-duration');\n  }\n\n  public override connectedCallback(): void {\n    this.popover = 'manual';\n    super.connectedCallback();\n    if (ariaRoleOnHost) {\n      this.id ||= this.overlayId;\n    }\n\n    if (this.hasUpdated) {\n      this._componentSetup();\n    }\n    this.syncNegative();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('negative')) {\n      this.syncNegative();\n    }\n\n    if (changedProperties.has('autoActiveFirstOption') && this.isOpen) {\n      this._setNextActiveOptionIfAutoActiveFirstOption();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    this._componentSetup();\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._triggerElement = null;\n    this._triggerAbortController?.abort();\n    this._openPanelEventsController?.abort();\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n\n    if (isServer || !this.hasUpdated) {\n      return;\n    }\n    if (!name || name === 'trigger') {\n      this._configureTrigger();\n    } else if ((!name || name === 'origin') && this.isOpen) {\n      this._setOverlayPosition();\n    }\n  }\n\n  /** When an option is selected, update the input value and close the autocomplete. */\n  protected onOptionSelected(event: Event): void {\n    const target = event.target as SbbOptionBaseElement<T>;\n    this._setValueAndDispatchEvents(target);\n    this.close();\n  }\n\n  /** @deprecated */\n  protected onOptionArrowsSelected(_activeOption: SbbOptionBaseElement<T>): void {}\n\n  /**\n   * A 'pending selection' sets the option value in the input element without emitting events.\n   * A 'pending selection' is confirmed when the panel closes. Any other user interaction\n   * will reset the pending value.\n   */\n  protected setPendingSelection(activeOption: SbbOptionBaseElement<T>): void {\n    this.pendingAutoSelectedOption = activeOption;\n    this._setInputValue(activeOption);\n  }\n\n  private _setValueAndDispatchEvents(\n    selectedOption: SbbOptionBaseElement<T>,\n    preventFocus = false,\n  ): void {\n    // Deselect the previous options\n    this.options\n      .filter((option) => option.id !== selectedOption.id && option.selected)\n      .forEach((option) => (option.selected = false));\n    this.pendingAutoSelectedOption = null;\n\n    if (this.triggerElement) {\n      this._setInputValue(selectedOption);\n\n      // Manually trigger the change events\n      this.triggerElement.dispatchEvent(new Event('change', { bubbles: true }));\n      this.triggerElement.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n\n      // Dispatching the input event changes _lastInput, which should stay empty since there's no keyboard interaction.\n      this._lastUserInput = null;\n\n      // Custom input event emitted when input value changes after an option is selected\n      this.triggerElement.dispatchEvent(\n        new CustomEvent<{ option: SbbOptionBaseElement<T> }>('inputAutocomplete', {\n          detail: { option: selectedOption },\n        }),\n      );\n      if (!preventFocus) {\n        this.triggerElement.focus();\n      }\n    }\n  }\n\n  /** Set the option value within the input element */\n  private _setInputValue(option: SbbOptionBaseElement<T>): void {\n    if (!this.triggerElement) {\n      return;\n    }\n\n    // Given a value, returns the string that should be shown within the input.\n    const toDisplay = this.displayWith?.(option.value as T) ?? option.value;\n\n    // Set the option value\n    // In order to support React onChange event, we have to get the setter and call it.\n    // https://github.com/facebook/react/issues/11600#issuecomment-345813130\n    const setValue = Object.getOwnPropertyDescriptor(HTMLInputElement.prototype, 'value')!.set!;\n    setValue.call(this.triggerElement, toDisplay);\n  }\n\n  private _handleSlotchange(): void {\n    this._highlightOptions(this.triggerElement?.value);\n\n    /**\n     * It's possible to filter out options with an opened panel on input change.\n     * In this case, the panel's position must be recalculated considering the new option's list.\n     */\n    if (this.isOpen) {\n      this._setOverlayPosition();\n      this._setNextActiveOptionIfAutoActiveFirstOption();\n\n      // If the autocomplete is open and the option count gets to zero, we close the autocomplete.\n      if (this._optionsCount > 0 && this.options.length === 0) {\n        this.close();\n      }\n    } else if (\n      // If the 'input' is focused and the count of options changes from 0 to > 0,\n      // the autocomplete should open automatically.\n      document?.activeElement === this.triggerElement &&\n      this._optionsCount === 0 &&\n      this.options.length > 0\n    ) {\n      this.open();\n    }\n\n    this._optionsCount = this.options.length;\n  }\n\n  private _setNextActiveOptionIfAutoActiveFirstOption(): void {\n    if (this.autoActiveFirstOption) {\n      this.resetActiveElement();\n      this.setNextActiveOption();\n    }\n  }\n\n  /** The autocomplete should inherit 'readonly' state from the trigger. */\n  private _readonly(): boolean {\n    return this.triggerElement?.hasAttribute('readonly') ?? false;\n  }\n\n  private _componentSetup(): void {\n    if (isServer) {\n      return;\n    }\n\n    this._configureTrigger();\n  }\n\n  private _configureTrigger(): void {\n    const triggerElement = (this.trigger ??\n      this.closest?.('sbb-form-field')?.querySelector('input')) as HTMLInputElement | null;\n    if (triggerElement === this.triggerElement) {\n      return;\n    }\n\n    this._triggerAbortController?.abort();\n    removeAriaComboBoxAttributes(this.triggerElement);\n    this.triggerElement?.removeAttribute('data-expanded');\n    this._triggerElement = triggerElement;\n\n    if (!this.triggerElement) {\n      return;\n    }\n\n    // As the trigger can be the fallback of the origin, we eventually have to update the position.\n    const originElement = this.originElement;\n    if (this.triggerElement === originElement && this.isOpen) {\n      this._setOverlayPosition(originElement);\n    }\n\n    this._triggerAttributeObserver?.observe(this.triggerElement!, {\n      attributes: true,\n      attributeFilter: ['disabled', 'readonly'],\n    });\n\n    this.setTriggerAttributes(this.triggerElement);\n    this._triggerAbortController = new AbortController();\n\n    // Open the overlay on focus, click, input and `ArrowDown` event\n    this.triggerElement.addEventListener('focus', () => this.open(), {\n      signal: this._triggerAbortController.signal,\n    });\n    this.triggerElement.addEventListener('click', () => this.open(), {\n      signal: this._triggerAbortController.signal,\n    });\n    this.triggerElement.addEventListener(\n      'input',\n      (event) => {\n        const value: string = (event.target as HTMLInputElement).value;\n\n        if (value) {\n          this.open();\n        }\n        this._highlightOptions(value);\n        this._lastUserInput = value;\n        this.pendingAutoSelectedOption = null;\n      },\n      { signal: this._triggerAbortController.signal },\n    );\n    this.triggerElement.addEventListener(\n      'keydown',\n      (event: KeyboardEvent) => this._closedPanelKeyboardInteraction(event),\n      {\n        signal: this._triggerAbortController.signal,\n        // We need key event to run before any other subscription to guarantee a correct\n        // interaction with other components (necessary for the 'sbb-chip-group' use case).\n        capture: true,\n      },\n    );\n  }\n\n  // Set overlay position, width and max height\n  private _setOverlayPosition(originElement = this.originElement): void {\n    // An undefined originElement should only occur in the unlikely event\n    // that the autocomplete loses its originElement and triggerElement during an open state.\n    if (!originElement) {\n      return;\n    }\n    setOverlayPosition(\n      this._overlay,\n      originElement,\n      this._optionContainer,\n      this.shadowRoot!.querySelector('.sbb-autocomplete__container')!,\n      this,\n      this.position,\n    );\n  }\n\n  /**\n   * On open/close animation end.\n   * In rare cases it can be that the animationEnd event is triggered twice.\n   * To avoid entering a corrupt state, exit when state is not expected.\n   */\n  private _onAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open' && this.state === 'opening') {\n      this._handleOpening();\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._handleClosing();\n    }\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n    if (this.originElement) {\n      this._originResizeObserver.observe(this.originElement);\n    }\n    this.triggerElement?.setAttribute('aria-expanded', 'true');\n    this.dispatchOpenEvent();\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    this.hidePopover?.();\n    this.triggerElement?.setAttribute('aria-expanded', 'false');\n\n    // Clears the input if there's user interaction without selection (selection clears `_lastUserInput`).\n    if (this.requireSelection && this.triggerElement && this._lastUserInput) {\n      const setValue = Object.getOwnPropertyDescriptor(HTMLInputElement.prototype, 'value')!.set!;\n      setValue.call(this.triggerElement, '');\n      this._highlightOptions('');\n      this.triggerElement.dispatchEvent(new Event('change', { bubbles: true }));\n      this.triggerElement.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n    }\n    this.resetActiveElement();\n    this._optionContainer.scrollTop = 0;\n    this._escapableOverlayController.disconnect();\n    this.dispatchCloseEvent();\n  }\n\n  private _attachOpenPanelEvents(): void {\n    this._openPanelEventsController = new AbortController();\n\n    // Recalculate the overlay position on scroll and window resize\n    document.addEventListener('scroll', () => this._setOverlayPosition(), {\n      passive: true,\n      signal: this._openPanelEventsController.signal,\n      // Without capture, other scroll contexts would not bubble to this event listener.\n      // Capture allows us to react to all scroll contexts in this DOM.\n      capture: true,\n    });\n    window.addEventListener('resize', () => this._setOverlayPosition(), {\n      passive: true,\n      signal: this._openPanelEventsController.signal,\n    });\n\n    // Close autocomplete on backdrop click\n    window.addEventListener('pointerdown', (ev) => this._pointerDownListener(ev), {\n      signal: this._openPanelEventsController.signal,\n    });\n    window.addEventListener('pointerup', (ev) => this._closeOnBackdropClick(ev), {\n      signal: this._openPanelEventsController.signal,\n    });\n\n    this.addEventListener(\n      'ɵdisabledchange',\n      () => {\n        if (this.activeOption?.disabled) {\n          this.resetActiveElement();\n        }\n        this._setNextActiveOptionIfAutoActiveFirstOption();\n      },\n      {\n        signal: this._openPanelEventsController.signal,\n      },\n    );\n\n    // Keyboard interactions\n    this.triggerElement?.addEventListener(\n      'keydown',\n      (event: KeyboardEvent) => this.openedPanelKeyboardInteraction(event),\n      {\n        signal: this._openPanelEventsController.signal,\n        // We need key event to run before any other subscription to guarantee a correct\n        // interaction with other components (necessary for the 'sbb-chip-group' use case).\n        capture: true,\n      },\n    );\n\n    this.triggerElement?.addEventListener(\n      'blur',\n      (e) => {\n        // If the new focus is the autocomplete or inside of it then an option\n        // was selected and there is a separate mechanism that closes this instance.\n        if (!this.contains(e.relatedTarget as Node)) {\n          if (\n            this.autoSelectActiveOptionOnBlur &&\n            this.activeOption &&\n            this._lastUserInput &&\n            this.triggerElement?.value\n          ) {\n            this.activeOption.selected = true;\n            this._setValueAndDispatchEvents(this.activeOption, true);\n          }\n\n          this.close();\n        }\n      },\n      {\n        signal: this._openPanelEventsController.signal,\n      },\n    );\n  }\n\n  // Check if the pointerdown event target is triggered on the menu.\n  private _pointerDownListener = (event: PointerEvent): void => {\n    this._isPointerDownEventOnMenu = isEventOnElement(this._overlay, event);\n  };\n\n  // If the click is outside the autocomplete, closes the panel.\n  private _closeOnBackdropClick = (event: PointerEvent): void => {\n    if (\n      !this._isPointerDownEventOnMenu &&\n      !isEventOnElement(this._overlay, event) &&\n      !isEventOnElement(this.originElement, event)\n    ) {\n      this.close();\n    }\n  };\n\n  private _closedPanelKeyboardInteraction(event: KeyboardEvent): void {\n    if (this.state === 'opening' || this.state === 'opened') {\n      return;\n    }\n\n    switch (event.key) {\n      case 'ArrowDown':\n      case 'ArrowUp':\n        this.open();\n        break;\n    }\n  }\n\n  /** Highlight the searched text on the options. */\n  private _highlightOptions(searchTerm?: string): void {\n    if (searchTerm === null || searchTerm === undefined) {\n      return;\n    }\n    this.options.forEach((option) => option.highlight(searchTerm));\n  }\n\n  protected override render(): TemplateResult {\n    // Scroll areas without containing an interactive element will receive focus when tabbing through the document.\n    // If there are a lot of options and when pressing tab key, the scroll area on sbb-autocomplete__options gets focus.\n    // As elements inside the panel should never get focus, we have to avoid that by setting tabindex=-1.\n    return html`\n      <div class=\"sbb-autocomplete__gap-fix\"></div>\n      <div class=\"sbb-autocomplete__container\">\n        <div class=\"sbb-autocomplete__gap-fix\">${overlayGapFixCorners()}</div>\n        <div\n          @animationend=${this._onAnimationEnd}\n          class=\"sbb-autocomplete__panel\"\n          ${ref((overlayRef?: Element) => (this._overlay = overlayRef as HTMLElement))}\n        >\n          <div class=\"sbb-autocomplete__wrapper\">\n            <div\n              class=\"sbb-autocomplete__options\"\n              role=${!ariaRoleOnHost ? this.panelRole : nothing}\n              id=${!ariaRoleOnHost ? this.overlayId : nothing}\n              tabindex=\"-1\"\n              ${ref((containerRef) => (this._optionContainer = containerRef as HTMLElement))}\n            >\n              <slot @slotchange=${this._handleSlotchange}></slot>\n            </div>\n          </div>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementEventMap {\n    inputAutocomplete: CustomEvent<{ option: SbbOptionBaseElement<any> }>;\n  }\n}\n"],"names":[],"mappings":"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"}
906
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"autocomplete-base-element.js","sources":["../../../../src/elements/autocomplete/autocomplete-base-element.ts"],"sourcesContent":["import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  isServer,\n  nothing,\n  type PropertyDeclaration,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { SbbOpenCloseBaseElement } from '../core/base-elements.ts';\nimport {\n  SbbPropertyWatcherController,\n  SbbEscapableOverlayController,\n} from '../core/controllers.ts';\nimport { forceType, idReference } from '../core/decorators.ts';\nimport { isLean, isSafari, isZeroAnimationDuration } from '../core/dom.ts';\nimport { SbbHydrationMixin, SbbNegativeMixin } from '../core/mixins.ts';\nimport {\n  isEventOnElement,\n  overlayGapFixCorners,\n  removeAriaComboBoxAttributes,\n  setOverlayPosition,\n} from '../core/overlay.ts';\nimport { boxSizingStyles } from '../core/styles.ts';\nimport type { SbbFormFieldElement } from '../form-field/form-field/form-field.component.ts';\nimport type { SbbOptionBaseElement } from '../option.ts';\n\nimport style from './autocomplete-base-element.scss?lit&inline';\n\n/**\n * On Safari, the aria role 'listbox' must be on the host element, or else VoiceOver won't work at all.\n * On the other hand, JAWS and NVDA need the role to be \"closer\" to the options, or else optgroups won't work.\n */\nconst ariaRoleOnHost = isSafari;\n\nexport abstract class SbbAutocompleteBaseElement<T = string> extends SbbNegativeMixin(\n  SbbHydrationMixin(SbbOpenCloseBaseElement),\n) {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n\n  /**\n   * The element where the autocomplete will attach.\n   * If not set, as fallback there are two elements which can act as origin with following priority order:\n   * 1. `sbb-form-field` if it is an ancestor.\n   * 2. trigger element if set.\n   *\n   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor origin: HTMLElement | null = null;\n\n  /**\n   * The input element that will trigger the autocomplete opening.\n   * By default, the autocomplete will open on focus, click, input or `ArrowDown` keypress of the 'trigger' element.\n   * If not set, will search for the first 'input' child of a 'sbb-form-field' ancestor.\n   *\n   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor trigger: HTMLInputElement | null = null;\n\n  /** Whether the icon space is preserved when no icon is set. */\n  @forceType()\n  @property({ attribute: 'preserve-icon-space', reflect: true, type: Boolean })\n  public accessor preserveIconSpace: boolean = false;\n\n  /** Whether the first option is automatically activated when the autocomplete is opened. */\n  @forceType()\n  @property({ attribute: 'auto-active-first-option', type: Boolean })\n  public accessor autoActiveFirstOption: boolean = false;\n\n  /** Function that maps an option's control value to its display value in the trigger. */\n  @property({ attribute: false })\n  public accessor displayWith: ((value: T) => string) | null = null;\n\n  /**\n   * Size variant, either m or s.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 'm' | 's' = isLean() ? 's' : 'm';\n\n  /** Whether the active option should be selected as the user is navigating. */\n  @forceType()\n  @property({ attribute: 'auto-select-active-option', type: Boolean })\n  public accessor autoSelectActiveOption: boolean = false;\n\n  /**\n   * When enabled, the active option is automatically selected on blur.\n   * This is an experimental feature. It might be subject to changes.\n   */\n  @forceType()\n  @property({ attribute: 'auto-select-active-option-on-blur', type: Boolean })\n  public accessor autoSelectActiveOptionOnBlur: boolean = false;\n\n  /**\n   * Whether the user is required to make a selection when they're interacting with the\n   * autocomplete. If the user moves away from the autocomplete without selecting an option from\n   * the list, the value will be reset. If the user opens the panel and closes it without\n   * interacting or selecting a value, the initial value will be kept.\n   */\n  @forceType()\n  @property({ attribute: 'require-selection', type: Boolean })\n  public accessor requireSelection: boolean = false;\n\n  /**\n   * The position of the autocomplete panel relative to the trigger.\n   * @default 'auto'\n   */\n  @property()\n  public accessor position: 'auto' | 'above' | 'below' = 'auto';\n\n  /** Returns the element where the autocomplete overlay is attached to. */\n  public get originElement(): HTMLElement | null {\n    return (\n      this.origin ??\n      this.closest?.('sbb-form-field')?.shadowRoot?.querySelector?.('#overlay-anchor') ??\n      this.trigger ??\n      null\n    );\n  }\n\n  /** Returns the trigger element. */\n  public get triggerElement(): HTMLInputElement | null {\n    return this._triggerElement ?? null;\n  }\n  private _triggerElement?: HTMLInputElement | null;\n\n  protected abstract overlayId: string;\n  protected abstract panelRole: string;\n  protected activeOption: SbbOptionBaseElement<T> | null = null;\n  protected pendingAutoSelectedOption: SbbOptionBaseElement<T> | null = null;\n  private _originResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => {\n      if (this.state === 'opened') {\n        this._setOverlayPosition();\n      }\n    },\n  });\n  /** Listens to the changes on the `disabled` or `readonly` attribute of the trigger. */\n  private _triggerAttributeObserver = !isServer\n    ? new MutationObserver((mutations: MutationRecord[]): void => {\n        const input = mutations[0].target as HTMLInputElement;\n        if (input.hasAttribute('disabled') || input.hasAttribute('readonly')) {\n          this.close();\n        }\n      })\n    : null;\n  private _overlay!: HTMLElement;\n  private _optionContainer!: HTMLElement;\n  private _triggerAbortController!: AbortController;\n  private _openPanelEventsController!: AbortController;\n  private _isPointerDownEventOnMenu: boolean = false;\n  private _escapableOverlayController = new SbbEscapableOverlayController(this);\n  private _optionsCount = 0;\n\n  /** Tracks input from keyboard. */\n  private _lastUserInput: string | null = null;\n\n  /** If true, the 'change' event source is an option selection or a 'requireSelection' field cleanup */\n  private _isCustomChangeEvent = false;\n\n  protected abstract get options(): SbbOptionBaseElement<T>[];\n\n  public constructor() {\n    super();\n    this.addEventListener?.('optionselected', (e: Event) => this.onOptionSelected(e));\n    this.addController(\n      new SbbPropertyWatcherController(\n        this,\n        () => this.closest<SbbFormFieldElement>('sbb-form-field'),\n        {\n          negative: (e) => {\n            this.negative = e.negative;\n            this.syncNegative();\n          },\n          borderless: (e) => this.toggleState('option-panel-origin-borderless', e.borderless),\n        },\n      ),\n    );\n  }\n\n  protected abstract syncNegative(): void;\n  protected abstract setTriggerAttributes(element: HTMLInputElement): void;\n  protected abstract openedPanelKeyboardInteraction(event: KeyboardEvent): void;\n  protected abstract selectByKeyboard(event: KeyboardEvent): void;\n  protected abstract setNextActiveOption(event?: KeyboardEvent): void;\n  protected abstract resetActiveElement(): void;\n\n  /** Opens the autocomplete. */\n  public open(): void {\n    if (\n      this.state === 'opening' ||\n      this.state === 'opened' ||\n      !this._overlay ||\n      this.options.length === 0 ||\n      this._readonly() ||\n      !this.dispatchBeforeOpenEvent()\n    ) {\n      return;\n    }\n\n    this.showPopover?.();\n    this.state = 'opening';\n    this.triggerElement?.toggleAttribute('data-expanded', true);\n    const originElement = this.originElement;\n    if (!originElement) {\n      throw new Error(\n        'Cannot find the origin element. Please specify a valid element or check the usage of the \"origin\" property from the documentation',\n      );\n    }\n    this._setOverlayPosition(originElement);\n    this._setNextActiveOptionIfAutoActiveFirstOption();\n    this._attachOpenPanelEvents();\n    this._escapableOverlayController.connect();\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `opened` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleOpening();\n    }\n  }\n\n  /** Closes the autocomplete. */\n  public close(): void {\n    if (this.state === 'closing' || this.state === 'closed' || !this.dispatchBeforeCloseEvent()) {\n      return;\n    }\n\n    // A 'pending selection' is confirmed on panel close\n    if (this.pendingAutoSelectedOption) {\n      this.pendingAutoSelectedOption.selected = true;\n      this._setValueAndDispatchEvents(this.pendingAutoSelectedOption, true);\n    }\n\n    this.state = 'closing';\n    this.triggerElement?.removeAttribute('data-expanded');\n    this._openPanelEventsController.abort();\n    if (this.originElement) {\n      this._originResizeObserver.unobserve(this.originElement);\n    }\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `closed` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleClosing();\n    }\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-options-panel-animation-duration');\n  }\n\n  public override connectedCallback(): void {\n    this.popover = 'manual';\n    super.connectedCallback();\n    if (ariaRoleOnHost) {\n      this.id ||= this.overlayId;\n    }\n\n    if (this.hasUpdated) {\n      this._componentSetup();\n    }\n    this.syncNegative();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('negative')) {\n      this.syncNegative();\n    }\n\n    if (changedProperties.has('autoActiveFirstOption') && this.isOpen) {\n      this._setNextActiveOptionIfAutoActiveFirstOption();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    this._componentSetup();\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._triggerElement = null;\n    this._triggerAbortController?.abort();\n    this._openPanelEventsController?.abort();\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n\n    if (isServer || !this.hasUpdated) {\n      return;\n    }\n    if (!name || name === 'trigger') {\n      this._configureTrigger();\n    } else if ((!name || name === 'origin') && this.isOpen) {\n      this._setOverlayPosition();\n    }\n  }\n\n  /** When an option is selected, update the input value and close the autocomplete. */\n  protected onOptionSelected(event: Event): void {\n    const target = event.target as SbbOptionBaseElement<T>;\n    this._setValueAndDispatchEvents(target);\n    this.close();\n  }\n\n  /** @deprecated */\n  protected onOptionArrowsSelected(_activeOption: SbbOptionBaseElement<T>): void {}\n\n  /**\n   * A 'pending selection' sets the option value in the input element without emitting events.\n   * A 'pending selection' is confirmed when the panel closes. Any other user interaction\n   * will reset the pending value.\n   */\n  protected setPendingSelection(activeOption: SbbOptionBaseElement<T>): void {\n    this.pendingAutoSelectedOption = activeOption;\n    this._setInputValue(activeOption);\n  }\n\n  private _setValueAndDispatchEvents(\n    selectedOption: SbbOptionBaseElement<T>,\n    preventFocus = false,\n  ): void {\n    // Deselect the previous options\n    this.options\n      .filter((option) => option.id !== selectedOption.id && option.selected)\n      .forEach((option) => (option.selected = false));\n    this.pendingAutoSelectedOption = null;\n\n    if (this.triggerElement) {\n      this._setInputValue(selectedOption);\n\n      // Manually trigger the change events\n      this._isCustomChangeEvent = true;\n      this.triggerElement.dispatchEvent(new Event('change', { bubbles: true }));\n      this.triggerElement.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n\n      // Dispatching the input event changes _lastInput, which should stay empty since there's no keyboard interaction.\n      this._lastUserInput = null;\n\n      // Custom input event emitted when input value changes after an option is selected\n      this.triggerElement.dispatchEvent(\n        new CustomEvent<{ option: SbbOptionBaseElement<T> }>('inputAutocomplete', {\n          detail: { option: selectedOption },\n        }),\n      );\n      if (!preventFocus) {\n        this.triggerElement.focus();\n      }\n    }\n  }\n\n  /** Set the option value within the input element */\n  private _setInputValue(option: SbbOptionBaseElement<T>): void {\n    if (!this.triggerElement) {\n      return;\n    }\n\n    // Given a value, returns the string that should be shown within the input.\n    const toDisplay = this.displayWith?.(option.value as T) ?? option.value;\n\n    // Set the option value\n    // In order to support React onChange event, we have to get the setter and call it.\n    // https://github.com/facebook/react/issues/11600#issuecomment-345813130\n    const setValue = Object.getOwnPropertyDescriptor(HTMLInputElement.prototype, 'value')!.set!;\n    setValue.call(this.triggerElement, toDisplay);\n  }\n\n  private _handleSlotchange(): void {\n    this._highlightOptions(this.triggerElement?.value);\n\n    /**\n     * It's possible to filter out options with an opened panel on input change.\n     * In this case, the panel's position must be recalculated considering the new option's list.\n     */\n    if (this.isOpen) {\n      this._setOverlayPosition();\n      this._setNextActiveOptionIfAutoActiveFirstOption();\n\n      // If the autocomplete is open and the option count gets to zero, we close the autocomplete.\n      if (this._optionsCount > 0 && this.options.length === 0) {\n        this.close();\n      }\n    } else if (\n      // If the 'input' is focused and the count of options changes from 0 to > 0,\n      // the autocomplete should open automatically.\n      document?.activeElement === this.triggerElement &&\n      this._optionsCount === 0 &&\n      this.options.length > 0\n    ) {\n      this.open();\n    }\n\n    this._optionsCount = this.options.length;\n  }\n\n  private _setNextActiveOptionIfAutoActiveFirstOption(): void {\n    if (this.autoActiveFirstOption) {\n      this.resetActiveElement();\n      this.setNextActiveOption();\n    }\n  }\n\n  /** The autocomplete should inherit 'readonly' state from the trigger. */\n  private _readonly(): boolean {\n    return this.triggerElement?.hasAttribute('readonly') ?? false;\n  }\n\n  private _componentSetup(): void {\n    if (isServer) {\n      return;\n    }\n\n    this._configureTrigger();\n  }\n\n  private _configureTrigger(): void {\n    const triggerElement = (this.trigger ??\n      this.closest?.('sbb-form-field')?.querySelector('input')) as HTMLInputElement | null;\n    if (triggerElement === this.triggerElement) {\n      return;\n    }\n\n    this._triggerAbortController?.abort();\n    removeAriaComboBoxAttributes(this.triggerElement);\n    this.triggerElement?.removeAttribute('data-expanded');\n    this._triggerElement = triggerElement;\n\n    if (!this.triggerElement) {\n      return;\n    }\n\n    // As the trigger can be the fallback of the origin, we eventually have to update the position.\n    const originElement = this.originElement;\n    if (this.triggerElement === originElement && this.isOpen) {\n      this._setOverlayPosition(originElement);\n    }\n\n    this._triggerAttributeObserver?.observe(this.triggerElement!, {\n      attributes: true,\n      attributeFilter: ['disabled', 'readonly'],\n    });\n\n    this.setTriggerAttributes(this.triggerElement);\n    this._triggerAbortController = new AbortController();\n\n    // Open the overlay on focus, click, input and `ArrowDown` event\n    this.triggerElement.addEventListener('focus', () => this.open(), {\n      signal: this._triggerAbortController.signal,\n    });\n    this.triggerElement.addEventListener('click', () => this.open(), {\n      signal: this._triggerAbortController.signal,\n    });\n    this.triggerElement.addEventListener(\n      'input',\n      (event) => {\n        const value: string = (event.target as HTMLInputElement).value;\n\n        if (value) {\n          this.open();\n        }\n        this._highlightOptions(value);\n        this._lastUserInput = value;\n        this.pendingAutoSelectedOption = null;\n      },\n      { signal: this._triggerAbortController.signal },\n    );\n    this.triggerElement.addEventListener(\n      'change',\n      (event) => {\n        /**\n         * In 'requireSelection' mode, we block the native change events and\n         * let only pass the ones that come with a valid value (when an option is selected)\n         */\n        if (this.requireSelection && !this._isCustomChangeEvent) {\n          event.stopImmediatePropagation();\n        }\n        this._isCustomChangeEvent = false;\n      },\n      { signal: this._triggerAbortController.signal, capture: true },\n    );\n    this.triggerElement.addEventListener(\n      'keydown',\n      (event: KeyboardEvent) => this._closedPanelKeyboardInteraction(event),\n      {\n        signal: this._triggerAbortController.signal,\n        // We need key event to run before any other subscription to guarantee a correct\n        // interaction with other components (necessary for the 'sbb-chip-group' use case).\n        capture: true,\n      },\n    );\n\n    this.triggerElement.addEventListener(\n      'blur',\n      (e) => {\n        if (this.contains(e.relatedTarget as Node)) {\n          return;\n        }\n\n        // Clears the input if there's user interaction without selection (selection clears `_lastUserInput`).\n        if (this.requireSelection && this.triggerElement && this._lastUserInput) {\n          const setValue = Object.getOwnPropertyDescriptor(\n            HTMLInputElement.prototype,\n            'value',\n          )!.set!;\n          setValue.call(this.triggerElement, '');\n          this._highlightOptions('');\n          this._isCustomChangeEvent = true;\n          this.triggerElement.dispatchEvent(new Event('change', { bubbles: true }));\n          this.triggerElement.dispatchEvent(\n            new InputEvent('input', { bubbles: true, composed: true }),\n          );\n        }\n      },\n      { signal: this._triggerAbortController.signal, capture: true },\n    );\n  }\n\n  // Set overlay position, width and max height\n  private _setOverlayPosition(originElement = this.originElement): void {\n    // An undefined originElement should only occur in the unlikely event\n    // that the autocomplete loses its originElement and triggerElement during an open state.\n    if (!originElement) {\n      return;\n    }\n    setOverlayPosition(\n      this._overlay,\n      originElement,\n      this._optionContainer,\n      this.shadowRoot!.querySelector('.sbb-autocomplete__container')!,\n      this,\n      this.position,\n    );\n  }\n\n  /**\n   * On open/close animation end.\n   * In rare cases it can be that the animationEnd event is triggered twice.\n   * To avoid entering a corrupt state, exit when state is not expected.\n   */\n  private _onAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open' && this.state === 'opening') {\n      this._handleOpening();\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._handleClosing();\n    }\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n    if (this.originElement) {\n      this._originResizeObserver.observe(this.originElement);\n    }\n    this.triggerElement?.setAttribute('aria-expanded', 'true');\n    this.dispatchOpenEvent();\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    this.hidePopover?.();\n    this.triggerElement?.setAttribute('aria-expanded', 'false');\n\n    this.resetActiveElement();\n    this._optionContainer.scrollTop = 0;\n    this._escapableOverlayController.disconnect();\n    this.dispatchCloseEvent();\n  }\n\n  private _attachOpenPanelEvents(): void {\n    this._openPanelEventsController = new AbortController();\n\n    // Recalculate the overlay position on scroll and window resize\n    document.addEventListener('scroll', () => this._setOverlayPosition(), {\n      passive: true,\n      signal: this._openPanelEventsController.signal,\n      // Without capture, other scroll contexts would not bubble to this event listener.\n      // Capture allows us to react to all scroll contexts in this DOM.\n      capture: true,\n    });\n    window.addEventListener('resize', () => this._setOverlayPosition(), {\n      passive: true,\n      signal: this._openPanelEventsController.signal,\n    });\n\n    // Close autocomplete on backdrop click\n    window.addEventListener('pointerdown', (ev) => this._pointerDownListener(ev), {\n      signal: this._openPanelEventsController.signal,\n    });\n    window.addEventListener('pointerup', (ev) => this._closeOnBackdropClick(ev), {\n      signal: this._openPanelEventsController.signal,\n    });\n\n    this.addEventListener(\n      'ɵdisabledchange',\n      () => {\n        if (this.activeOption?.disabled) {\n          this.resetActiveElement();\n        }\n        this._setNextActiveOptionIfAutoActiveFirstOption();\n      },\n      {\n        signal: this._openPanelEventsController.signal,\n      },\n    );\n\n    // Keyboard interactions\n    this.triggerElement?.addEventListener(\n      'keydown',\n      (event: KeyboardEvent) => this.openedPanelKeyboardInteraction(event),\n      {\n        signal: this._openPanelEventsController.signal,\n        // We need key event to run before any other subscription to guarantee a correct\n        // interaction with other components (necessary for the 'sbb-chip-group' use case).\n        capture: true,\n      },\n    );\n\n    this.triggerElement?.addEventListener(\n      'blur',\n      (e) => {\n        // If the new focus is the autocomplete or inside of it then an option\n        // was selected and there is a separate mechanism that closes this instance.\n        if (!this.contains(e.relatedTarget as Node)) {\n          if (\n            this.autoSelectActiveOptionOnBlur &&\n            this.activeOption &&\n            this._lastUserInput &&\n            this.triggerElement?.value\n          ) {\n            this.activeOption.selected = true;\n            this._setValueAndDispatchEvents(this.activeOption, true);\n          }\n\n          this.close();\n        }\n      },\n      {\n        signal: this._openPanelEventsController.signal,\n        capture: true,\n      },\n    );\n  }\n\n  // Check if the pointerdown event target is triggered on the menu.\n  private _pointerDownListener = (event: PointerEvent): void => {\n    this._isPointerDownEventOnMenu = isEventOnElement(this._overlay, event);\n  };\n\n  // If the click is outside the autocomplete, closes the panel.\n  private _closeOnBackdropClick = (event: PointerEvent): void => {\n    if (\n      !this._isPointerDownEventOnMenu &&\n      !isEventOnElement(this._overlay, event) &&\n      !isEventOnElement(this.originElement, event)\n    ) {\n      this.close();\n    }\n  };\n\n  private _closedPanelKeyboardInteraction(event: KeyboardEvent): void {\n    if (this.state === 'opening' || this.state === 'opened') {\n      return;\n    }\n\n    switch (event.key) {\n      case 'ArrowDown':\n      case 'ArrowUp':\n        this.open();\n        break;\n    }\n  }\n\n  /** Highlight the searched text on the options. */\n  private _highlightOptions(searchTerm?: string): void {\n    if (searchTerm === null || searchTerm === undefined) {\n      return;\n    }\n    this.options.forEach((option) => option.highlight(searchTerm));\n  }\n\n  protected override render(): TemplateResult {\n    // Scroll areas without containing an interactive element will receive focus when tabbing through the document.\n    // If there are a lot of options and when pressing tab key, the scroll area on sbb-autocomplete__options gets focus.\n    // As elements inside the panel should never get focus, we have to avoid that by setting tabindex=-1.\n    return html`\n      <div class=\"sbb-autocomplete__gap-fix\"></div>\n      <div class=\"sbb-autocomplete__container\">\n        <div class=\"sbb-autocomplete__gap-fix\">${overlayGapFixCorners()}</div>\n        <div\n          @animationend=${this._onAnimationEnd}\n          class=\"sbb-autocomplete__panel\"\n          ${ref((overlayRef?: Element) => (this._overlay = overlayRef as HTMLElement))}\n        >\n          <div class=\"sbb-autocomplete__wrapper\">\n            <div\n              class=\"sbb-autocomplete__options\"\n              role=${!ariaRoleOnHost ? this.panelRole : nothing}\n              id=${!ariaRoleOnHost ? this.overlayId : nothing}\n              tabindex=\"-1\"\n              ${ref((containerRef) => (this._optionContainer = containerRef as HTMLElement))}\n            >\n              <slot @slotchange=${this._handleSlotchange}></slot>\n            </div>\n          </div>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementEventMap {\n    inputAutocomplete: CustomEvent<{ option: SbbOptionBaseElement<any> }>;\n  }\n}\n"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,13 +1,13 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-dev",
3
- "version": "4.6.0-dev.1772035308",
3
+ "version": "4.6.0-dev.1772036870",
4
4
  "description": "Lyne Design System",
5
5
  "keywords": [
6
6
  "design system",
7
7
  "web components",
8
8
  "lit",
9
9
  "storybook",
10
- "https://github.com/sbb-design-systems/lyne-components/commit/4dc626dac4a51e017fec037f6aa10dbe703fa631"
10
+ "https://github.com/sbb-design-systems/lyne-components/commit/3706b378aecd3064608b671c5e4d26a030932651"
11
11
  ],
12
12
  "type": "module",
13
13
  "exports": {