@sbb-esta/lyne-elements 1.11.0 → 1.11.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -2,7 +2,6 @@ import { property, state } from "lit/decorators.js";
2
2
  import { defaultConverter, html, nothing, css } from "lit";
3
3
  import { hostAttributes } from "./decorators.js";
4
4
  import { preventScrollOnSpacebarPress, EventEmitter } from "./eventing.js";
5
- import { getLocalName } from "./dom.js";
6
5
  import "../screen-reader-only.js";
7
6
  var __defProp$6 = Object.defineProperty;
8
7
  var __getOwnPropDesc$3 = Object.getOwnPropertyDescriptor;
@@ -481,7 +480,7 @@ const SbbNamedSlotListMixin = (superClass) => {
481
480
  if (listSlotNames.length >= 2) {
482
481
  return html`
483
482
  <ul
484
- class=${attributes.class || (this.localName ?? getLocalName(this))}
483
+ class=${attributes.class || this.localName}
485
484
  aria-label=${attributes.ariaLabel || nothing}
486
485
  aria-labelledby=${attributes.ariaLabelledby || nothing}
487
486
  >
@@ -497,7 +496,7 @@ const SbbNamedSlotListMixin = (superClass) => {
497
496
  `;
498
497
  } else if (listSlotNames.length === 1) {
499
498
  return html`<sbb-screen-reader-only>${attributes.ariaLabel}</sbb-screen-reader-only>
500
- <span class=${attributes.class || (this.localName ?? getLocalName(this))}>
499
+ <span class=${attributes.class || this.localName}>
501
500
  <span><slot name=${listSlotNames[0].name}></slot></span>
502
501
  </span>
503
502
  ${this.renderHiddenSlot()} `;
@@ -748,4 +747,4 @@ export {
748
747
  SbbUpdateSchedulerMixin,
749
748
  panelCommon as panelCommonStyle
750
749
  };
751
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"mixins.js","sources":["../../../../src/elements/core/mixins/disabled-mixin.ts","../../../../src/elements/core/mixins/form-associated-mixin.ts","../../../../src/elements/core/mixins/required-mixin.ts","../../../../src/elements/core/mixins/form-associated-checkbox-mixin.ts","../../../../src/elements/core/mixins/hydration-mixin.ts","../../../../src/elements/core/mixins/named-slot-list-mixin.ts","../../../../src/elements/core/mixins/negative-mixin.ts","../../../../src/elements/core/mixins/panel-mixin.ts","../../../../src/elements/core/mixins/update-scheduler-mixin.ts"],"sourcesContent":["import type { LitElement, PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport type { AbstractConstructor } from './constructor.js';\n\nexport declare class SbbDisabledMixinType {\n  public set disabled(value: boolean);\n  public get disabled(): boolean;\n  protected isDisabledExternally(): boolean;\n}\n\nexport declare class SbbDisabledInteractiveMixinType {\n  public disabledInteractive: boolean;\n}\n\n/**\n * Enhance your component with a disabled property.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbDisabledMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbDisabledMixinType> & T => {\n  abstract class SbbDisabledElement extends superClass implements Partial<SbbDisabledMixinType> {\n    /** Whether the component is disabled. */\n    @property({ reflect: true, type: Boolean })\n    public set disabled(value: boolean) {\n      // To provide the same behavior as the native disabled state,\n      // any value is converted to a boolean.\n      this._disabled = Boolean(value);\n    }\n    public get disabled(): boolean {\n      return this._disabled || this.isDisabledExternally();\n    }\n    private _disabled: boolean = false;\n\n    /**\n     * Will be used as 'or' check to the current disabled state.\n     * Can e.g. be used to read disabled state of a group.\n     */\n    protected isDisabledExternally(): boolean {\n      return false;\n    }\n  }\n\n  return SbbDisabledElement as unknown as AbstractConstructor<SbbDisabledMixinType> & T;\n};\n\n/**\n * Enhance your component with a disabled interactive property.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbDisabledInteractiveMixin = <\n  T extends AbstractConstructor<LitElement & SbbDisabledMixinType>,\n>(\n  superClass: T,\n): AbstractConstructor<SbbDisabledInteractiveMixinType> & T => {\n  abstract class SbbDisabledInteractiveElement\n    extends superClass\n    implements Partial<SbbDisabledInteractiveMixinType>\n  {\n    /** Whether disabled buttons should be interactive. */\n    @property({ attribute: 'disabled-interactive', type: Boolean }) public disabledInteractive =\n      false;\n  }\n\n  return SbbDisabledInteractiveElement as unknown as AbstractConstructor<SbbDisabledInteractiveMixinType> &\n    T;\n};\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbDisabledTabIndexActionMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbDisabledMixinType & SbbDisabledInteractiveMixinType> & T => {\n  abstract class SbbDisabledTabIndexAction\n    extends SbbDisabledInteractiveMixin(SbbDisabledMixin(superClass))\n    implements SbbDisabledMixinType, SbbDisabledInteractiveMixinType\n  {\n    protected override willUpdate(changedProperties: PropertyValues<this>): void {\n      super.willUpdate(changedProperties);\n\n      if (!changedProperties.has('disabled') && !changedProperties.has('disabledInteractive')) {\n        return;\n      }\n\n      if (!this.disabled || this.disabledInteractive) {\n        this.setAttribute('tabindex', '0');\n      } else {\n        this.removeAttribute('tabindex');\n      }\n\n      if (this.disabled) {\n        this.setAttribute('aria-disabled', 'true');\n      } else {\n        this.removeAttribute('aria-disabled');\n      }\n    }\n  }\n  return SbbDisabledTabIndexAction as AbstractConstructor<\n    SbbDisabledMixinType & SbbDisabledInteractiveMixinType\n  > &\n    T;\n};\n\n/**\n * Extends `SbbDisabledMixin` with the `aria-disabled` attribute.\n * For a11y purposes, keeps the element focusable even when disabled.\n * @deprecated Will be removed with next major version\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbFocusableDisabledActionMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbDisabledMixinType> & T => {\n  abstract class SbbFocusableDisabledAction\n    extends SbbDisabledMixin(superClass)\n    implements SbbDisabledMixinType\n  {\n    protected override willUpdate(changedProperties: PropertyValues<this>): void {\n      super.willUpdate(changedProperties);\n\n      if (!changedProperties.has('disabled')) {\n        return;\n      }\n\n      if (this.disabled) {\n        this.setAttribute('aria-disabled', 'true');\n      } else {\n        this.removeAttribute('aria-disabled');\n      }\n    }\n  }\n  return SbbFocusableDisabledAction as AbstractConstructor<SbbDisabledMixinType> & T;\n};\n","import type { LitElement } from 'lit';\nimport { property, state } from 'lit/decorators.js';\n\nimport type { Constructor } from './constructor.js';\n\nexport declare abstract class SbbFormAssociatedMixinType {\n  public get form(): HTMLFormElement | null;\n  public get name(): string;\n  public set name(value: string);\n  public get type(): string;\n  public get value(): string | null;\n  public set value(value: string | null);\n\n  public get validity(): ValidityState;\n  public get validationMessage(): string;\n  public get willValidate(): boolean;\n\n  protected formDisabled: boolean;\n  protected readonly internals: ElementInternals;\n\n  public checkValidity(): boolean;\n  public reportValidity(): boolean;\n\n  public formAssociatedCallback?(form: HTMLFormElement | null): void;\n  public formDisabledCallback(disabled: boolean): void;\n  public abstract formResetCallback(): void;\n  public abstract formStateRestoreCallback(\n    state: FormRestoreState | null,\n    reason: FormRestoreReason,\n  ): void;\n\n  protected updateFormValue(): void;\n}\n\n/**\n * The FormAssociatedMixin enables native form support for custom controls.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbFormAssociatedMixin = <T extends Constructor<LitElement>>(\n  superClass: T,\n): Constructor<SbbFormAssociatedMixinType> & T => {\n  abstract class SbbFormAssociatedElement\n    extends superClass\n    implements Partial<SbbFormAssociatedMixinType>\n  {\n    public static formAssociated = true;\n\n    /**\n     * Returns the form owner of internals target element.\n     */\n    public get form(): HTMLFormElement | null {\n      return this.internals.form;\n    }\n\n    /**\n     * Name of the form element. Will be read from name attribute.\n     *\n     * @description Developer note: In this case updating the attribute must be synchronous.\n     * Due to this it is implemented as a getter/setter and the attributeChangedCallback() handles the diff check.\n     */\n    @property()\n    public set name(name: string) {\n      this.setAttribute('name', `${name}`);\n    }\n    public get name(): string {\n      return this.getAttribute('name') ?? '';\n    }\n\n    /** @internal */\n    public get type(): string {\n      return this.localName;\n    }\n\n    /** Value of the form element. */\n    @property()\n    public set value(value: string | null) {\n      this._value = value;\n      this.updateFormValue();\n    }\n    public get value(): string | null {\n      return this._value;\n    }\n    private _value: string | null = null;\n\n    /**\n     * Returns the ValidityState object for internals target element.\n     *\n     * @internal\n     */\n    public get validity(): ValidityState {\n      return this.internals.validity;\n    }\n\n    /**\n     * Returns the error message that would be shown to the user\n     * if internals target element was to be checked for validity.\n     *\n     * @internal\n     */\n    public get validationMessage(): string {\n      return this.internals.validationMessage;\n    }\n\n    /**\n     * Returns true if internals target element will be validated\n     * when the form is submitted; false otherwise.\n     *\n     * @internal\n     */\n    public get willValidate(): boolean {\n      return this.internals.willValidate;\n    }\n\n    /** @internal */\n    protected readonly internals: ElementInternals = this.attachInternals();\n\n    /** Whenever a surrounding form or fieldset is changing its disabled state. */\n    @state() protected formDisabled: boolean = false;\n\n    public override attributeChangedCallback(\n      name: string,\n      old: string | null,\n      value: string | null,\n    ): void {\n      if (name !== 'name' || old !== value) {\n        super.attributeChangedCallback(name, old, value);\n      }\n    }\n\n    /**\n     * Returns true if internals target element has no validity problems; false otherwise.\n     * Fires an invalid event at the element in the latter case.\n     *\n     * @internal\n     */\n    public checkValidity(): boolean {\n      return this.internals.checkValidity();\n    }\n\n    /**\n     * Returns true if internals target element has no validity problems; otherwise,\n     * returns false, fires an invalid event at the element,\n     * and (if the event isn't canceled) reports the problem to the user.\n     *\n     * @internal\n     */\n    public reportValidity(): boolean {\n      return this.internals.reportValidity();\n    }\n\n    /**\n     * Called when the associated form element changes.\n     * ElementInternals.form returns the associated from element.\n     *\n     * @internal\n     */\n    public formAssociatedCallback?(form: HTMLFormElement | null): void;\n\n    /**\n     * Is called whenever a surrounding form / fieldset changes disabled state.\n     * @param disabled\n     *\n     * @internal\n     */\n    public formDisabledCallback(disabled: boolean): void {\n      // This callback is triggered if the disabled property changes or the disabled attribute of a fieldset or form changes.\n      // We need to postpone the assignment, otherwise it interferes with disabled status setting\n      // and leads to a wrong state (e.g. embedded sbb-visual-checkbox).\n      Promise.resolve().then(() => {\n        this.formDisabled = disabled;\n      });\n    }\n\n    /**\n     * Is called whenever the form is being reset.\n     *\n     * @internal\n     */\n    public abstract formResetCallback(): void;\n\n    /**\n     *  Called when the browser is trying to restore element’s state to state in which case\n     *  reason is “restore”, or when the browser is trying to fulfill autofill on behalf of\n     *  user in which case reason is “autocomplete”.\n     *  In the case of “restore”, state is a string, File, or FormData object\n     *  previously set as the second argument to setFormValue.\n     *\n     * @internal\n     */\n    public abstract formStateRestoreCallback(\n      state: FormRestoreState | null,\n      reason: FormRestoreReason,\n    ): void;\n\n    /** Should be called when form value is changed. */\n    protected updateFormValue(): void {\n      this.internals.setFormValue(this.value);\n    }\n  }\n  return SbbFormAssociatedElement as unknown as Constructor<SbbFormAssociatedMixinType> & T;\n};\n\n/**\n * A value to be restored for a component's form value. If a component's form\n * state is a `FormData` object, its entry list of name and values will be\n * provided.\n */\nexport type FormRestoreState = File | string | [string, FormDataEntryValue][];\n\n/**\n * The reason a form component is being restored for, either `'restore'` for\n * browser restoration or `'autocomplete'` for restoring user values.\n */\nexport type FormRestoreReason = 'restore' | 'autocomplete';\n","import type { LitElement, PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport type { AbstractConstructor } from './constructor.js';\nimport type { SbbFormAssociatedMixinType } from './form-associated-mixin.js';\n\nexport declare class SbbRequiredMixinType {\n  public set required(value: boolean);\n  public get required(): boolean;\n  protected isRequiredExternally(): boolean;\n}\n\n/**\n * Enhance your component with a required property.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbRequiredMixin = <\n  T extends AbstractConstructor<LitElement & SbbFormAssociatedMixinType>,\n>(\n  superClass: T,\n): AbstractConstructor<SbbRequiredMixinType> & T => {\n  abstract class SbbRequiredElement extends superClass implements Partial<SbbRequiredMixinType> {\n    /** Whether the component is required. */\n    @property({ reflect: true, type: Boolean })\n    public set required(value: boolean) {\n      // To provide the same behavior as the native required state,\n      // any value is converted to a boolean.\n      this._required = Boolean(value);\n    }\n    public get required(): boolean {\n      return this._required || this.isRequiredExternally();\n    }\n    private _required: boolean = false;\n\n    protected override async willUpdate(changedProperties: PropertyValues<this>): Promise<void> {\n      super.willUpdate(changedProperties);\n\n      if (changedProperties.has('required')) {\n        // Firefox needs explicitly set aria-required value.\n        this.internals.ariaRequired = `${this.required}`;\n      }\n    }\n\n    /**\n     * Will be used as 'or' check to the current required state.\n     * Can e.g. be used to read required state of a group.\n     */\n    protected isRequiredExternally(): boolean {\n      return false;\n    }\n  }\n\n  return SbbRequiredElement as unknown as AbstractConstructor<SbbRequiredMixinType> & T;\n};\n","import { defaultConverter, type LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { hostAttributes } from '../decorators.js';\nimport { preventScrollOnSpacebarPress } from '../eventing.js';\n\nimport type { Constructor } from './constructor.js';\nimport { SbbDisabledMixin, type SbbDisabledMixinType } from './disabled-mixin.js';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbFormAssociatedMixin,\n  type SbbFormAssociatedMixinType,\n} from './form-associated-mixin.js';\nimport { SbbRequiredMixin, type SbbRequiredMixinType } from './required-mixin.js';\n\ntype CheckedSetterValue = { value: boolean; attribute: boolean };\n\nexport declare abstract class SbbFormAssociatedCheckboxMixinType\n  extends SbbFormAssociatedMixinType\n  implements Partial<SbbDisabledMixinType>, Partial<SbbRequiredMixinType>\n{\n  public get checked(): boolean;\n  public set checked(value: boolean);\n\n  public set disabled(value: boolean);\n  public get disabled(): boolean;\n\n  public set required(value: boolean);\n  public get required(): boolean;\n\n  public formResetCallback(): void;\n  public formStateRestoreCallback(state: FormRestoreState | null, reason: FormRestoreReason): void;\n\n  protected isDisabledExternally(): boolean;\n  protected isRequiredExternally(): boolean;\n  protected withUserInteraction?(): void;\n}\n\n/**\n * The FormAssociatedCheckboxMixin enables native form support for checkbox controls.\n *\n * Inherited classes MUST implement the ariaChecked state (ElementInternals) themselves.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbFormAssociatedCheckboxMixin = <T extends Constructor<LitElement>>(\n  superClass: T,\n): Constructor<SbbFormAssociatedCheckboxMixinType> & T => {\n  @hostAttributes({\n    tabindex: '0',\n  })\n  abstract class SbbFormAssociatedCheckboxElement\n    extends SbbDisabledMixin(SbbRequiredMixin(SbbFormAssociatedMixin(superClass)))\n    implements Partial<SbbFormAssociatedCheckboxMixinType>\n  {\n    private _attributeMutationBlocked = false;\n\n    /** Whether the checkbox is checked. */\n    @property({\n      type: Boolean,\n      converter: {\n        ...defaultConverter,\n        // We need to pass information to the setter so that we know it was called by attribute change.\n        fromAttribute: (value: string | null, type?: unknown): CheckedSetterValue => {\n          const result = defaultConverter.fromAttribute?.(value, type);\n          return { value: result, attribute: true } as CheckedSetterValue;\n        },\n      },\n    })\n    public set checked(value: boolean) {\n      const attributeSetter =\n        typeof value === 'object' ? (value as unknown as CheckedSetterValue).attribute : false;\n      if (attributeSetter) {\n        value = (value as unknown as CheckedSetterValue).value;\n      }\n\n      // As soon as mutation was done not by setting attribute,\n      // we need to block syncing attribute.\n      if (this.hasUpdated && !attributeSetter) {\n        this._attributeMutationBlocked = true;\n      }\n      this._checked = Boolean(value);\n      this.updateFormValue();\n    }\n    public get checked(): boolean {\n      return this._checked;\n    }\n    private _checked = false;\n\n    protected constructor() {\n      super();\n      /** @internal */\n      this.internals.role = 'checkbox';\n    }\n\n    public override connectedCallback(): void {\n      super.connectedCallback();\n\n      this.addEventListener('click', this._handleUserInteraction);\n      this.addEventListener('keydown', preventScrollOnSpacebarPress);\n      this.addEventListener('keyup', this._handleKeyboardInteraction);\n    }\n\n    public override disconnectedCallback(): void {\n      super.disconnectedCallback();\n\n      this.removeEventListener('click', this._handleUserInteraction);\n      this.removeEventListener('keydown', preventScrollOnSpacebarPress);\n      this.removeEventListener('keyup', this._handleKeyboardInteraction);\n    }\n\n    public override attributeChangedCallback(\n      name: string,\n      old: string | null,\n      value: string | null,\n    ): void {\n      // Attribute should not be interpreted after programmatic or manual state change.\n      if (name !== 'checked' || !this._attributeMutationBlocked) {\n        super.attributeChangedCallback(name, old, value);\n      }\n    }\n\n    /**\n     * Is called whenever the form is being reset.\n     *\n     * @internal\n     */\n    public override formResetCallback(): void {\n      this.checked = this.hasAttribute('checked');\n      this._attributeMutationBlocked = false;\n    }\n\n    /**\n     *  Called when the browser is trying to restore element’s state to state in which case\n     *  reason is “restore”, or when the browser is trying to fulfill autofill on behalf of\n     *  user in which case reason is “autocomplete”.\n     *  In the case of “restore”, state is a string, File, or FormData object\n     *  previously set as the second argument to setFormValue.\n     *\n     * @internal\n     */\n    public override formStateRestoreCallback(\n      state: FormRestoreState | null,\n      _reason: FormRestoreReason,\n    ): void {\n      if (state) {\n        this.checked = state === 'true';\n      }\n    }\n\n    /**\n     * Additional logic which is being executed when user\n     * interaction happens and state is not disabled.\n     */\n    protected withUserInteraction?(): void;\n\n    protected override updateFormValue(): void {\n      if (this.checked) {\n        this.internals.setFormValue(this.value, `${this.checked}`);\n      } else {\n        this.internals.setFormValue(null);\n      }\n    }\n\n    /** Method triggered on keyboard user interaction with checkbox. */\n    private _handleKeyboardInteraction = (event: KeyboardEvent): void => {\n      if (event.key === ' ') {\n        this._handleUserInteraction();\n      }\n    };\n\n    /** Method triggered on user interaction with checkbox. */\n    private _handleUserInteraction = (): void => {\n      if (this.disabled) {\n        return;\n      }\n      this.withUserInteraction?.();\n      this.checked = !this.checked;\n      this._attributeMutationBlocked = true;\n\n      this.dispatchEvent(new InputEvent('input', { composed: true, bubbles: true }));\n      this.dispatchEvent(new Event('change', { bubbles: true }));\n      this.dispatchEvent(new CustomEvent('didChange', { bubbles: true }));\n    };\n  }\n\n  return SbbFormAssociatedCheckboxElement as unknown as Constructor<SbbFormAssociatedCheckboxMixinType> &\n    T;\n};\n","import type { LitElement, PropertyValues } from 'lit';\n\nimport type { AbstractConstructor } from './constructor.js';\n\n// Define the interface for the mixin\nexport declare abstract class SbbHydrationMixinType {\n  /**\n   * Returns a Promise that resolves when the element has completed hydration.\n   * The Promise value is a boolean that is `true` if the element required hydration\n   * and `false` if not.\n   *\n   * @return A promise of a boolean that resolves to true once the hydration completed.\n   */\n  public get hydrationComplete(): Promise<boolean>;\n\n  /** Returns whether hydration is required and not completed. */\n  protected get hydrationRequired(): boolean;\n}\n\n/**\n * This mixin extends a base class with functionality to check if hydration is completed.\n * It also delays slotchange events until hydration is complete.\n *\n * @param base The class to extend.\n * @returns A class extended with the hydration check functionality.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbHydrationMixin = <T extends AbstractConstructor<LitElement>>(\n  base: T,\n): AbstractConstructor<SbbHydrationMixinType> & T => {\n  abstract class SbbHydrationMixinClass extends base implements Partial<SbbHydrationMixinType> {\n    private _hydrationRequired: boolean;\n    private _hydrationComplete = new Promise<boolean>(\n      (resolve) => (this._resolveHydration = resolve),\n    );\n    private _resolveHydration!: (hydrationRequired: boolean) => void;\n\n    /**\n     * Returns a Promise that resolves when the element has completed hydration.\n     * The Promise value is a boolean that is `true` if the element required hydration\n     * and `false` if not.\n     *\n     * @return A promise of a boolean that resolves to true once the hydration completed.\n     * @internal\n     */\n    public get hydrationComplete(): Promise<boolean> {\n      return this._hydrationComplete;\n    }\n\n    /** Returns whether hydration is required and not completed. */\n    protected get hydrationRequired(): boolean {\n      return this._hydrationRequired;\n    }\n\n    public constructor(...args: any[]) {\n      super(...args);\n      // Check whether hydration is needed by checking whether the shadow root\n      // is available during construction/upgrade phase.\n      this._hydrationRequired = !!this.shadowRoot;\n      if (!this._hydrationRequired) {\n        this._resolveHydration(false);\n      } else {\n        // During hydration phase, we want to suppress slotchange events as they\n        // can cause render differences, which would break hydration. After\n        // hydration is complete, we dispatch a manual slotchange event, if there\n        // are elements assigned to a slot.\n        const suppressSlotchangeEvent = (event: Event): void => {\n          if (this._hydrationRequired) {\n            event.stopImmediatePropagation();\n          }\n        };\n        const eventOptions: EventListenerOptions = { capture: true };\n        const slots = this.shadowRoot?.querySelectorAll('slot');\n        if (slots?.length) {\n          slots.forEach((slot) =>\n            slot.addEventListener('slotchange', suppressSlotchangeEvent, eventOptions),\n          );\n          this.hydrationComplete.then(() =>\n            slots.forEach((slot) => {\n              slot.removeEventListener('slotchange', suppressSlotchangeEvent, eventOptions);\n              if (slot.assignedNodes().length) {\n                slot.dispatchEvent(new Event('slotchange', { bubbles: true }));\n              }\n            }),\n          );\n        }\n      }\n    }\n\n    protected override update(changedProperties: PropertyValues<this>): void {\n      // When hydration is needed, we wait the hydration process to finish, which is patched\n      // into the update method of the LitElement base class.\n      super.update(changedProperties);\n\n      if (this._hydrationRequired) {\n        this._hydrationRequired = false;\n        this._resolveHydration(true);\n      }\n    }\n  }\n  return SbbHydrationMixinClass as unknown as AbstractConstructor<SbbHydrationMixinType> & T;\n};\n","import { html, type LitElement, nothing, type TemplateResult } from 'lit';\nimport { state } from 'lit/decorators.js';\n\nimport { getLocalName } from '../dom.js';\n\nimport type { AbstractConstructor } from './constructor.js';\nimport { SbbHydrationMixin, type SbbHydrationMixinType } from './hydration-mixin.js';\n\nimport '../../screen-reader-only.js';\n\nconst SSR_CHILD_COUNT_ATTRIBUTE = 'data-ssr-child-count';\nconst SLOTNAME_PREFIX = 'li';\n\nexport type SbbNamedSlotProperties = {\n  name: string;\n  ariaHidden: boolean;\n};\n\n/**\n * Helper type for willUpdate or similar checks.\n * Allows the usage of the string literal 'listChildren'.\n *\n * @example\n * protected override willUpdate(changedProperties: PropertyValues<WithListChildren<this>>): void {\n *   if (changedProperties.has('listChildren')) {\n *     ...\n *   }\n * }\n */\nexport type WithListChildren<\n  T extends SbbNamedSlotListMixinType<C>,\n  C extends HTMLElement = HTMLElement,\n> = T & { listChildren: C[] };\n\nexport declare abstract class SbbNamedSlotListMixinType<\n  C extends HTMLElement,\n> extends SbbHydrationMixinType {\n  protected abstract readonly listChildLocalNames: string[];\n  @state() protected listChildren: C[];\n  protected renderList(\n    attributes?: {\n      class?: string;\n      ariaLabel?: string;\n      ariaLabelledby?: string;\n    },\n    listItemAttributes?: {\n      localNameVisualOnly?: string[];\n    },\n  ): TemplateResult;\n  protected listSlotEntries(): SbbNamedSlotProperties[];\n  protected renderHiddenSlot(): TemplateResult;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbNamedSlotListMixin = <\n  C extends HTMLElement,\n  T extends AbstractConstructor<LitElement>,\n>(\n  superClass: T,\n): AbstractConstructor<SbbNamedSlotListMixinType<C>> & T => {\n  /**\n   * This base class provides named slot list observer functionality.\n   * This allows using the pattern of rendering a named slot for each child, which allows\n   * wrapping children in an ul/li list.\n   */\n  abstract class NamedSlotListElement<C extends HTMLElement = HTMLElement>\n    extends SbbHydrationMixin(superClass)\n    implements Partial<SbbNamedSlotListMixinType<C>>\n  {\n    /** A list of lower-cased tag names to match against. (e.g. `sbb-link`) */\n    protected abstract readonly listChildLocalNames: string[];\n\n    /**\n     * A list of children with the defined tag names.\n     * This array is only updated if there is an actual change\n     * to the child elements.\n     */\n    @state() protected listChildren: C[] = [];\n\n    public override connectedCallback(): void {\n      super.connectedCallback();\n      this.shadowRoot?.addEventListener('slotchange', this._handleSlotchange, { passive: true });\n    }\n\n    public override disconnectedCallback(): void {\n      super.disconnectedCallback();\n      this.shadowRoot?.removeEventListener('slotchange', this._handleSlotchange);\n    }\n\n    private _handleSlotchange = (): void => {\n      const listChildren = Array.from(this.children ?? []).filter((e): e is C =>\n        this.listChildLocalNames.includes(e.localName),\n      );\n      // If the slotted child instances have not changed, we can skip syncing and updating\n      // the link reference list.\n      if (\n        listChildren.length === this.listChildren.length &&\n        this.listChildren.every((e, i) => listChildren[i] === e)\n      ) {\n        return;\n      }\n\n      this.listChildren\n        .filter((c) => !listChildren.includes(c))\n        .forEach((c) => c.removeAttribute('slot'));\n      this.listChildren = listChildren;\n      this.listChildren.forEach((c, index) =>\n        c.setAttribute('slot', `${SLOTNAME_PREFIX}-${index}`),\n      );\n\n      // Remove the ssr attribute, once we have actually initialized the children elements.\n      this.removeAttribute(SSR_CHILD_COUNT_ATTRIBUTE);\n    };\n\n    /**\n     * Renders list and list slots for slotted children or a number of list slots\n     * corresponding to the `data-ssr-child-count` attribute value.\n     *\n     * This is a possible optimization for SSR, as in an SSR Lit environment\n     * other elements are not available, but might be available in the meta\n     * framework wrapper (like e.g. React). This allows to provide the number of\n     * children to be passed via the `data-ssr-child-count` attribute value.\n     */\n    protected renderList(\n      attributes: { class?: string; ariaLabel?: string; ariaLabelledby?: string } = {},\n      listItemAttributes: { localNameVisualOnly?: string[] } = {},\n    ): TemplateResult {\n      const listSlotNames: SbbNamedSlotProperties[] = this.listSlotEntries(listItemAttributes);\n\n      if (listSlotNames.length >= 2) {\n        return html`\n          <ul\n            class=${attributes.class || (this.localName ?? getLocalName(this))}\n            aria-label=${attributes.ariaLabel || nothing}\n            aria-labelledby=${attributes.ariaLabelledby || nothing}\n          >\n            ${listSlotNames.map(\n              (slot) => html`\n                <li aria-hidden=${slot.ariaHidden || nothing}>\n                  <slot name=${slot.name}></slot>\n                </li>\n              `,\n            )}\n          </ul>\n          ${this.renderHiddenSlot()}\n        `;\n      } else if (listSlotNames.length === 1) {\n        return html`<sbb-screen-reader-only>${attributes.ariaLabel}</sbb-screen-reader-only>\n          <span class=${attributes.class || (this.localName ?? getLocalName(this))}>\n            <span><slot name=${listSlotNames[0].name}></slot></span>\n          </span>\n          ${this.renderHiddenSlot()} `;\n      } else {\n        return this.renderHiddenSlot();\n      }\n    }\n\n    /**\n     * Returns an array of SbbNamedSlotProperties, which holds the list slot names and the hidden property;\n     * its length corresponds to the number of matched children or the `data-ssr-child-count` attribute value.\n     *\n     * This is a possible optimization for SSR, as in an SSR Lit environment\n     * other elements are not available, but might be available in the meta\n     * framework wrapper (like e.g. React). This allows to provide the number of\n     * children to be passed via the `data-ssr-child-count` attribute value.\n     */\n    protected listSlotEntries(listItemAttributes: {\n      localNameVisualOnly?: string[];\n    }): SbbNamedSlotProperties[] {\n      const listChildren = this.listChildren.length\n        ? this.listChildren\n        : Array.from({ length: +(this.getAttribute(SSR_CHILD_COUNT_ATTRIBUTE) ?? 0) });\n      return listChildren.map((e, i) => {\n        return {\n          name: `${SLOTNAME_PREFIX}-${i}`,\n          ariaHidden:\n            listItemAttributes?.localNameVisualOnly?.includes((e as HTMLElement).localName) ??\n            false,\n        };\n      });\n    }\n\n    /**\n     * Returns a hidden slot, which is intended as the children change detection.\n     * When an element without a slot attribute is slotted to the element, it triggers\n     * the slotchange event, which can be used to assign it to the appropriate named slot.\n     */\n    protected renderHiddenSlot(): TemplateResult {\n      return html`<span hidden><slot></slot></span>`;\n    }\n  }\n\n  return NamedSlotListElement as unknown as AbstractConstructor<SbbNamedSlotListMixinType<C>> & T;\n};\n","import type { LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport type { AbstractConstructor } from './constructor.js';\n\nexport declare class SbbNegativeMixinType {\n  public negative: boolean;\n}\n\n/**\n * Enhance your component with a negative property.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbNegativeMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbNegativeMixinType> & T => {\n  abstract class SbbNegativeElement extends superClass implements SbbNegativeMixinType {\n    /** Negative coloring variant flag. */\n    @property({ reflect: true, type: Boolean }) public negative: boolean = false;\n  }\n\n  return SbbNegativeElement as AbstractConstructor<SbbNegativeMixinType> & T;\n};\n","import type { LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { EventEmitter } from '../eventing.js';\n\nimport type { AbstractConstructor } from './constructor.js';\n\nexport declare class SbbPanelMixinType {\n  public color: 'white' | 'milk';\n  public borderless: boolean;\n  public expansionState?: string;\n}\n\nexport type SbbPanelSize = 's' | 'm';\n\n/**\n * Mixin for common panel behaviors\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbPanelMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbPanelMixinType> & T => {\n  abstract class SbbPanelElement extends superClass implements SbbPanelMixinType {\n    public static readonly events = {\n      panelConnected: 'panelConnected',\n    } as const;\n\n    /** The background color of the panel. */\n    @property() public color: 'white' | 'milk' = 'white';\n\n    /** Whether the unselected panel has a border. */\n    @property({ reflect: true, type: Boolean }) public borderless = false;\n\n    /** @internal used for accessibility label when in expansion panel */\n    @property() public expansionState?: string;\n\n    /**\n     * @internal\n     * Internal event that emits when the checkbox is loaded.\n     */\n    private _panelConnected: EventEmitter<void> = new EventEmitter(\n      this,\n      SbbPanelElement.events.panelConnected,\n      { bubbles: true },\n    );\n\n    public override connectedCallback(): void {\n      super.connectedCallback();\n\n      this._panelConnected.emit();\n    }\n  }\n\n  return SbbPanelElement as AbstractConstructor<SbbPanelMixinType> & T;\n};\n","import type { LitElement } from 'lit';\n\nimport type { AbstractConstructor } from './constructor.js';\n\n// Define the interface for the mixin\nexport declare class SbbUpdateSchedulerMixinType {\n  protected startUpdate(): void;\n  protected completeUpdate(): void;\n}\n\n/**\n * This mixin allows scheduling manual updates, which affect updateComplete.\n * @param base The class to extend.\n * @returns A class extended with the slot child observer functionality.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbUpdateSchedulerMixin = <T extends AbstractConstructor<LitElement>>(\n  base: T,\n): AbstractConstructor<SbbUpdateSchedulerMixinType> & T => {\n  abstract class SbbUpdateSchedulerElement\n    extends base\n    implements Partial<SbbUpdateSchedulerMixinType>\n  {\n    private _updatePromise = Promise.resolve();\n    private _updateResolve = (): void => {};\n\n    protected startUpdate(): void {\n      this._updatePromise = new Promise<void>((r) => (this._updateResolve = r));\n    }\n\n    protected completeUpdate(): void {\n      this._updateResolve();\n    }\n\n    protected override async getUpdateComplete(): Promise<boolean> {\n      const result = await super.getUpdateComplete();\n      await this._updatePromise;\n      return result;\n    }\n  }\n  return SbbUpdateSchedulerElement as unknown as AbstractConstructor<SbbUpdateSchedulerMixinType> &\n    T;\n};\n"],"names":["__decorateClass","state"],"mappings":";;;;;;;;;;;;;;;;AAmBa,MAAA,mBAAmB,CAC9B,eACkD;AAAA,EAClD,MAAe,2BAA2B,WAAoD;AAAA,IAA9F,cAAA;AAAA,YAAA,GAAA,SAAA;AAWE,WAAQ,YAAqB;AAAA,IAAA;AAAA,IAR7B,IAAW,SAAS,OAAgB;AAG7B,WAAA,YAAY,QAAQ,KAAK;AAAA,IAChC;AAAA,IACA,IAAW,WAAoB;AACtB,aAAA,KAAK,aAAa,KAAK,qBAAqB;AAAA,IACrD;AAAA;AAAA;AAAA;AAAA;AAAA,IAOU,uBAAgC;AACjC,aAAA;AAAA,IACT;AAAA,EACF;AAjBaA,oBAAA;AAAA,IADV,SAAS,EAAE,SAAS,MAAM,MAAM,SAAS;AAAA,EAAA,GAF7B,mBAGF,WAAA,YAAA,CAAA;AAmBN,SAAA;AACT;AAMa,MAAA,8BAA8B,CAGzC,eAC6D;AAAA,EAC7D,MAAe,sCACL,WAEV;AAAA,IAHA,cAAA;AAAA,YAAA,GAAA,SAAA;AAKkE,WAAO,sBACrE;AAAA,IAAA;AAAA,EACJ;AAFyEA,oBAAA;AAAA,IAAtE,SAAS,EAAE,WAAW,wBAAwB,MAAM,SAAS;AAAA,EAAA,GALjD,8BAK0D,WAAA,uBAAA,CAAA;AAIlE,SAAA;AAET;AAGa,MAAA,iCAAiC,CAC5C,eACoF;AAAA,EACpF,MAAe,kCACL,4BAA4B,iBAAiB,UAAU,CAAC,EAElE;AAAA,IACqB,WAAW,mBAA+C;AAC3E,YAAM,WAAW,iBAAiB;AAE9B,UAAA,CAAC,kBAAkB,IAAI,UAAU,KAAK,CAAC,kBAAkB,IAAI,qBAAqB,GAAG;AACvF;AAAA,MACF;AAEA,UAAI,CAAC,KAAK,YAAY,KAAK,qBAAqB;AACzC,aAAA,aAAa,YAAY,GAAG;AAAA,MAAA,OAC5B;AACL,aAAK,gBAAgB,UAAU;AAAA,MACjC;AAEA,UAAI,KAAK,UAAU;AACZ,aAAA,aAAa,iBAAiB,MAAM;AAAA,MAAA,OACpC;AACL,aAAK,gBAAgB,eAAe;AAAA,MACtC;AAAA,IACF;AAAA,EACF;AACO,SAAA;AAIT;AAQa,MAAA,kCAAkC,CAC7C,eACkD;AAAA,EAClD,MAAe,mCACL,iBAAiB,UAAU,EAErC;AAAA,IACqB,WAAW,mBAA+C;AAC3E,YAAM,WAAW,iBAAiB;AAElC,UAAI,CAAC,kBAAkB,IAAI,UAAU,GAAG;AACtC;AAAA,MACF;AAEA,UAAI,KAAK,UAAU;AACZ,aAAA,aAAa,iBAAiB,MAAM;AAAA,MAAA,OACpC;AACL,aAAK,gBAAgB,eAAe;AAAA,MACtC;AAAA,IACF;AAAA,EACF;AACO,SAAA;AACT;;;;;;;;;;;AC7Fa,MAAA,yBAAyB,CACpC,eACgD;AAChD,QAAe,4BAAf,MAAe,kCACL,WAEV;AAAA,IAHA,cAAA;AAAA,YAAA,GAAA,SAAA;AAyCE,WAAQ,SAAwB;AAgCb,WAAA,YAA8B,KAAK;AAG7C,WAAU,eAAwB;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA,IAnE3C,IAAW,OAA+B;AACxC,aAAO,KAAK,UAAU;AAAA,IACxB;AAAA,IASA,IAAW,KAAK,MAAc;AAC5B,WAAK,aAAa,QAAQ,GAAG,IAAI,EAAE;AAAA,IACrC;AAAA,IACA,IAAW,OAAe;AACjB,aAAA,KAAK,aAAa,MAAM,KAAK;AAAA,IACtC;AAAA;AAAA,IAGA,IAAW,OAAe;AACxB,aAAO,KAAK;AAAA,IACd;AAAA,IAIA,IAAW,MAAM,OAAsB;AACrC,WAAK,SAAS;AACd,WAAK,gBAAgB;AAAA,IACvB;AAAA,IACA,IAAW,QAAuB;AAChC,aAAO,KAAK;AAAA,IACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQA,IAAW,WAA0B;AACnC,aAAO,KAAK,UAAU;AAAA,IACxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQA,IAAW,oBAA4B;AACrC,aAAO,KAAK,UAAU;AAAA,IACxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQA,IAAW,eAAwB;AACjC,aAAO,KAAK,UAAU;AAAA,IACxB;AAAA,IAQgB,yBACd,MACA,KACA,OACM;AACF,UAAA,SAAS,UAAU,QAAQ,OAAO;AAC9B,cAAA,yBAAyB,MAAM,KAAK,KAAK;AAAA,MACjD;AAAA,IACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQO,gBAAyB;AACvB,aAAA,KAAK,UAAU;IACxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IASO,iBAA0B;AACxB,aAAA,KAAK,UAAU;IACxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAgBO,qBAAqB,UAAyB;AAI3C,cAAA,UAAU,KAAK,MAAM;AAC3B,aAAK,eAAe;AAAA,MAAA,CACrB;AAAA,IACH;AAAA;AAAA,IAwBU,kBAAwB;AAC3B,WAAA,UAAU,aAAa,KAAK,KAAK;AAAA,IACxC;AAAA,EACF;AAzJE,4BAAc,iBAAiB;AAJjC,MAAe,2BAAf;AAoBaA,oBAAA;AAAA,IADV,SAAS;AAAA,EAAA,GAnBG,yBAoBF,WAAA,QAAA,CAAA;AAcAA,oBAAA;AAAA,IADV,SAAS;AAAA,EAAA,GAjCG,yBAkCF,WAAA,SAAA,CAAA;AA0CQA,oBAAA;AAAA,IAAlB,MAAM;AAAA,EAAA,GA5EM,yBA4EM,WAAA,gBAAA,CAAA;AAkFd,SAAA;AACT;;;;;;;;;;;ACxLa,MAAA,mBAAmB,CAG9B,eACkD;AAAA,EAClD,MAAe,2BAA2B,WAAoD;AAAA,IAA9F,cAAA;AAAA,YAAA,GAAA,SAAA;AAWE,WAAQ,YAAqB;AAAA,IAAA;AAAA,IAR7B,IAAW,SAAS,OAAgB;AAG7B,WAAA,YAAY,QAAQ,KAAK;AAAA,IAChC;AAAA,IACA,IAAW,WAAoB;AACtB,aAAA,KAAK,aAAa,KAAK,qBAAqB;AAAA,IACrD;AAAA,IAGA,MAAyB,WAAW,mBAAwD;AAC1F,YAAM,WAAW,iBAAiB;AAE9B,UAAA,kBAAkB,IAAI,UAAU,GAAG;AAErC,aAAK,UAAU,eAAe,GAAG,KAAK,QAAQ;AAAA,MAChD;AAAA,IACF;AAAA;AAAA;AAAA;AAAA;AAAA,IAMU,uBAAgC;AACjC,aAAA;AAAA,IACT;AAAA,EACF;AA1BaA,oBAAA;AAAA,IADV,SAAS,EAAE,SAAS,MAAM,MAAM,SAAS;AAAA,EAAA,GAF7B,mBAGF,WAAA,UAAA;AA4BN,SAAA;AACT;;;;;;;;;;;ACRa,MAAA,iCAAiC,CAC5C,eACwD;AAIzC,MAAA,mCAAf,cACU,iBAAiB,iBAAiB,uBAAuB,UAAU,CAAC,CAAC,EAE/E;AAAA,IAmCY,cAAc;AAChB;AAnCR,WAAQ,4BAA4B;AAgCpC,WAAQ,WAAW;AA8EX,WAAA,6BAA6B,CAAC,UAA+B;AAC/D,YAAA,MAAM,QAAQ,KAAK;AACrB,eAAK,uBAAuB;AAAA,QAC9B;AAAA,MAAA;AAIF,WAAQ,yBAAyB,MAAY;;AAC3C,YAAI,KAAK,UAAU;AACjB;AAAA,QACF;AACA,mBAAK,wBAAL;AACK,aAAA,UAAU,CAAC,KAAK;AACrB,aAAK,4BAA4B;AAE5B,aAAA,cAAc,IAAI,WAAW,SAAS,EAAE,UAAU,MAAM,SAAS,KAAM,CAAA,CAAC;AACxE,aAAA,cAAc,IAAI,MAAM,UAAU,EAAE,SAAS,KAAM,CAAA,CAAC;AACpD,aAAA,cAAc,IAAI,YAAY,aAAa,EAAE,SAAS,KAAM,CAAA,CAAC;AAAA,MAAA;AA1FlE,WAAK,UAAU,OAAO;AAAA,IACxB;AAAA,IAxBA,IAAW,QAAQ,OAAgB;AACjC,YAAM,kBACJ,OAAO,UAAU,WAAY,MAAwC,YAAY;AACnF,UAAI,iBAAiB;AACnB,gBAAS,MAAwC;AAAA,MACnD;AAII,UAAA,KAAK,cAAc,CAAC,iBAAiB;AACvC,aAAK,4BAA4B;AAAA,MACnC;AACK,WAAA,WAAW,QAAQ,KAAK;AAC7B,WAAK,gBAAgB;AAAA,IACvB;AAAA,IACA,IAAW,UAAmB;AAC5B,aAAO,KAAK;AAAA,IACd;AAAA,IASgB,oBAA0B;AACxC,YAAM,kBAAkB;AAEnB,WAAA,iBAAiB,SAAS,KAAK,sBAAsB;AACrD,WAAA,iBAAiB,WAAW,4BAA4B;AACxD,WAAA,iBAAiB,SAAS,KAAK,0BAA0B;AAAA,IAChE;AAAA,IAEgB,uBAA6B;AAC3C,YAAM,qBAAqB;AAEtB,WAAA,oBAAoB,SAAS,KAAK,sBAAsB;AACxD,WAAA,oBAAoB,WAAW,4BAA4B;AAC3D,WAAA,oBAAoB,SAAS,KAAK,0BAA0B;AAAA,IACnE;AAAA,IAEgB,yBACd,MACA,KACA,OACM;AAEN,UAAI,SAAS,aAAa,CAAC,KAAK,2BAA2B;AACnD,cAAA,yBAAyB,MAAM,KAAK,KAAK;AAAA,MACjD;AAAA,IACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOgB,oBAA0B;AACnC,WAAA,UAAU,KAAK,aAAa,SAAS;AAC1C,WAAK,4BAA4B;AAAA,IACnC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAWgB,yBACdC,QACA,SACM;AACN,UAAIA,QAAO;AACT,aAAK,UAAUA,WAAU;AAAA,MAC3B;AAAA,IACF;AAAA,IAQmB,kBAAwB;AACzC,UAAI,KAAK,SAAS;AAChB,aAAK,UAAU,aAAa,KAAK,OAAO,GAAG,KAAK,OAAO,EAAE;AAAA,MAAA,OACpD;AACA,aAAA,UAAU,aAAa,IAAI;AAAA,MAClC;AAAA,IACF;AAAA,EAAA;AA7FWD,oBAAA;AAAA,IAXV,SAAS;AAAA,MACR,MAAM;AAAA,MACN,WAAW;AAAA,QACT,GAAG;AAAA;AAAA,QAEH,eAAe,CAAC,OAAsB,SAAuC;;AAC3E,gBAAM,UAAS,6BAAiB,kBAAjB,4BAAiC,OAAO;AACvD,iBAAO,EAAE,OAAO,QAAQ,WAAW,KAAK;AAAA,QAC1C;AAAA,MACF;AAAA,IAAA,CACD;AAAA,EAAA,GAjBY,iCAkBF,WAAA,WAAA,CAAA;AAlBb,qCAAAA,kBAAA;AAAA,IAHC,eAAe;AAAA,MACd,UAAU;AAAA,IAAA,CACX;AAAA,EACc,GAAA,gCAAA;AAuIR,SAAA;AAET;ACjKa,MAAA,oBAAoB,CAC/B,SACmD;AAAA,EACnD,MAAe,+BAA+B,KAA+C;AAAA,IAwBpF,eAAe,MAAa;;AACjC,YAAM,GAAG,IAAI;AAvBf,WAAQ,qBAAqB,IAAI;AAAA,QAC/B,CAAC,YAAa,KAAK,oBAAoB;AAAA,MAAA;AAyBlC,WAAA,qBAAqB,CAAC,CAAC,KAAK;AAC7B,UAAA,CAAC,KAAK,oBAAoB;AAC5B,aAAK,kBAAkB,KAAK;AAAA,MAAA,OACvB;AAKC,cAAA,0BAA0B,CAAC,UAAuB;AACtD,cAAI,KAAK,oBAAoB;AAC3B,kBAAM,yBAAyB;AAAA,UACjC;AAAA,QAAA;AAEI,cAAA,eAAqC,EAAE,SAAS;AACtD,cAAM,SAAQ,UAAK,eAAL,mBAAiB,iBAAiB;AAChD,YAAI,+BAAO,QAAQ;AACX,gBAAA;AAAA,YAAQ,CAAC,SACb,KAAK,iBAAiB,cAAc,yBAAyB,YAAY;AAAA,UAAA;AAE3E,eAAK,kBAAkB;AAAA,YAAK,MAC1B,MAAM,QAAQ,CAAC,SAAS;AACjB,mBAAA,oBAAoB,cAAc,yBAAyB,YAAY;AACxE,kBAAA,KAAK,cAAc,EAAE,QAAQ;AAC1B,qBAAA,cAAc,IAAI,MAAM,cAAc,EAAE,SAAS,KAAM,CAAA,CAAC;AAAA,cAC/D;AAAA,YAAA,CACD;AAAA,UAAA;AAAA,QAEL;AAAA,MACF;AAAA,IACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IA1CA,IAAW,oBAAsC;AAC/C,aAAO,KAAK;AAAA,IACd;AAAA;AAAA,IAGA,IAAc,oBAA6B;AACzC,aAAO,KAAK;AAAA,IACd;AAAA,IAqCmB,OAAO,mBAA+C;AAGvE,YAAM,OAAO,iBAAiB;AAE9B,UAAI,KAAK,oBAAoB;AAC3B,aAAK,qBAAqB;AAC1B,aAAK,kBAAkB,IAAI;AAAA,MAC7B;AAAA,IACF;AAAA,EACF;AACO,SAAA;AACT;;;;;;;;;;AC3FA,MAAM,4BAA4B;AAClC,MAAM,kBAAkB;AA2CX,MAAA,wBAAwB,CAInC,eAC0D;AAAA,EAM1D,MAAe,6BACL,kBAAkB,UAAU,EAEtC;AAAA,IAHA,cAAA;AAAA,YAAA,GAAA,SAAA;AAYW,WAAU,eAAoB;AAYvC,WAAQ,oBAAoB,MAAY;AACtC,cAAM,eAAe,MAAM,KAAK,KAAK,YAAY,CAAE,CAAA,EAAE;AAAA,UAAO,CAAC,MAC3D,KAAK,oBAAoB,SAAS,EAAE,SAAS;AAAA,QAAA;AAI/C,YACE,aAAa,WAAW,KAAK,aAAa,UAC1C,KAAK,aAAa,MAAM,CAAC,GAAG,MAAM,aAAa,CAAC,MAAM,CAAC,GACvD;AACA;AAAA,QACF;AAEA,aAAK,aACF,OAAO,CAAC,MAAM,CAAC,aAAa,SAAS,CAAC,CAAC,EACvC,QAAQ,CAAC,MAAM,EAAE,gBAAgB,MAAM,CAAC;AAC3C,aAAK,eAAe;AACpB,aAAK,aAAa;AAAA,UAAQ,CAAC,GAAG,UAC5B,EAAE,aAAa,QAAQ,GAAG,eAAe,IAAI,KAAK,EAAE;AAAA,QAAA;AAItD,aAAK,gBAAgB,yBAAyB;AAAA,MAAA;AAAA,IAChD;AAAA,IAjCgB,oBAA0B;;AACxC,YAAM,kBAAkB;AACnB,iBAAA,eAAA,mBAAY,iBAAiB,cAAc,KAAK,mBAAmB,EAAE,SAAS;IACrF;AAAA,IAEgB,uBAA6B;;AAC3C,YAAM,qBAAqB;AAC3B,iBAAK,eAAL,mBAAiB,oBAAoB,cAAc,KAAK;AAAA,IAC1D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAoCU,WACR,aAA8E,IAC9E,qBAAyD,CAAA,GACzC;AACV,YAAA,gBAA0C,KAAK,gBAAgB,kBAAkB;AAEnF,UAAA,cAAc,UAAU,GAAG;AACtB,eAAA;AAAA;AAAA,oBAEK,WAAW,UAAU,KAAK,aAAa,aAAa,IAAI,EAAE;AAAA,yBACrD,WAAW,aAAa,OAAO;AAAA,8BAC1B,WAAW,kBAAkB,OAAO;AAAA;AAAA,cAEpD,cAAc;AAAA,UACd,CAAC,SAAS;AAAA,kCACU,KAAK,cAAc,OAAO;AAAA,+BAC7B,KAAK,IAAI;AAAA;AAAA;AAAA,QAAA,CAG3B;AAAA;AAAA,YAED,KAAK,kBAAkB;AAAA;AAAA,MAAA,WAElB,cAAc,WAAW,GAAG;AAC9B,eAAA,+BAA+B,WAAW,SAAS;AAAA,wBAC1C,WAAW,UAAU,KAAK,aAAa,aAAa,IAAI,EAAE;AAAA,+BACnD,cAAc,CAAC,EAAE,IAAI;AAAA;AAAA,YAExC,KAAK,kBAAkB;AAAA,MAAA,OACtB;AACL,eAAO,KAAK;MACd;AAAA,IACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAWU,gBAAgB,oBAEG;AAC3B,YAAM,eAAe,KAAK,aAAa,SACnC,KAAK,eACL,MAAM,KAAK,EAAE,QAAQ,EAAE,KAAK,aAAa,yBAAyB,KAAK,IAAI;AAC/E,aAAO,aAAa,IAAI,CAAC,GAAG,MAAM;;AACzB,eAAA;AAAA,UACL,MAAM,GAAG,eAAe,IAAI,CAAC;AAAA,UAC7B,cACE,8DAAoB,wBAApB,mBAAyC,SAAU,EAAkB,eACrE;AAAA,QAAA;AAAA,MACJ,CACD;AAAA,IACH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOU,mBAAmC;AACpC,aAAA;AAAA,IACT;AAAA,EACF;AAjHqBA,oBAAA;AAAA,IAAlB,MAAM;AAAA,EAAA,GAZM,qBAYM,WAAA,cAAA;AAmHd,SAAA;AACT;;;;;;;;;;ACpLa,MAAA,mBAAmB,CAC9B,eACkD;AAAA,EAClD,MAAe,2BAA2B,WAA2C;AAAA,IAArF,cAAA;AAAA,YAAA,GAAA,SAAA;AAE8C,WAAO,WAAoB;AAAA,IAAA;AAAA,EACzE;AADqDA,oBAAA;AAAA,IAAlD,SAAS,EAAE,SAAS,MAAM,MAAM,SAAS;AAAA,EAAA,GAF7B,mBAEsC,WAAA,UAAA;AAG9C,SAAA;AACT;;;;;;;;;;ACHa,MAAA,gBAAgB,CAC3B,eAC+C;;AAChC,QAAA,oBAAf,mBAAuC,WAAwC;AAAA,IAA/E,cAAA;AAAA,YAAA,GAAA,SAAA;AAMc,WAAO,QAA0B;AAGD,WAAO,aAAa;AAShE,WAAQ,kBAAsC,IAAI;AAAA,QAChD;AAAA,QACA,GAAgB,OAAO;AAAA,QACvB,EAAE,SAAS,KAAK;AAAA,MAAA;AAAA,IAClB;AAAA,IAEgB,oBAA0B;AACxC,YAAM,kBAAkB;AAExB,WAAK,gBAAgB;IACvB;AAAA,EAAA,GA3BA,GAAuB,SAAS;AAAA,IAC9B,gBAAgB;AAAA,EAAA,GAFpB;AAMqB,kBAAA;AAAA,IAAlB,SAAS;AAAA,EAAA,GANG,iBAMM,WAAA,OAAA;AAGgC,kBAAA;AAAA,IAAlD,SAAS,EAAE,SAAS,MAAM,MAAM,SAAS;AAAA,EAAA,GAT7B,iBASsC,WAAA,YAAA;AAGhC,kBAAA;AAAA,IAAlB,SAAS;AAAA,EAAA,GAZG,iBAYM,WAAA,gBAAA;AAZrB,MAAe,kBAAf;AA+BO,SAAA;AACT;ACtCa,MAAA,0BAA0B,CACrC,SACyD;AAAA,EACzD,MAAe,kCACL,KAEV;AAAA,IAHA,cAAA;AAAA,YAAA,GAAA,SAAA;AAIU,WAAA,iBAAiB,QAAQ;AACjC,WAAQ,iBAAiB,MAAY;AAAA,MAAA;AAAA,IAAC;AAAA,IAE5B,cAAoB;AAC5B,WAAK,iBAAiB,IAAI,QAAc,CAAC,MAAO,KAAK,iBAAiB,CAAE;AAAA,IAC1E;AAAA,IAEU,iBAAuB;AAC/B,WAAK,eAAe;AAAA,IACtB;AAAA,IAEA,MAAyB,oBAAsC;AACvD,YAAA,SAAS,MAAM,MAAM;AAC3B,YAAM,KAAK;AACJ,aAAA;AAAA,IACT;AAAA,EACF;AACO,SAAA;AAET;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
750
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"mixins.js","sources":["../../../../src/elements/core/mixins/disabled-mixin.ts","../../../../src/elements/core/mixins/form-associated-mixin.ts","../../../../src/elements/core/mixins/required-mixin.ts","../../../../src/elements/core/mixins/form-associated-checkbox-mixin.ts","../../../../src/elements/core/mixins/hydration-mixin.ts","../../../../src/elements/core/mixins/named-slot-list-mixin.ts","../../../../src/elements/core/mixins/negative-mixin.ts","../../../../src/elements/core/mixins/panel-mixin.ts","../../../../src/elements/core/mixins/update-scheduler-mixin.ts"],"sourcesContent":["import type { LitElement, PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport type { AbstractConstructor } from './constructor.js';\n\nexport declare class SbbDisabledMixinType {\n  public set disabled(value: boolean);\n  public get disabled(): boolean;\n  protected isDisabledExternally(): boolean;\n}\n\nexport declare class SbbDisabledInteractiveMixinType {\n  public disabledInteractive: boolean;\n}\n\n/**\n * Enhance your component with a disabled property.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbDisabledMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbDisabledMixinType> & T => {\n  abstract class SbbDisabledElement extends superClass implements Partial<SbbDisabledMixinType> {\n    /** Whether the component is disabled. */\n    @property({ reflect: true, type: Boolean })\n    public set disabled(value: boolean) {\n      // To provide the same behavior as the native disabled state,\n      // any value is converted to a boolean.\n      this._disabled = Boolean(value);\n    }\n    public get disabled(): boolean {\n      return this._disabled || this.isDisabledExternally();\n    }\n    private _disabled: boolean = false;\n\n    /**\n     * Will be used as 'or' check to the current disabled state.\n     * Can e.g. be used to read disabled state of a group.\n     */\n    protected isDisabledExternally(): boolean {\n      return false;\n    }\n  }\n\n  return SbbDisabledElement as unknown as AbstractConstructor<SbbDisabledMixinType> & T;\n};\n\n/**\n * Enhance your component with a disabled interactive property.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbDisabledInteractiveMixin = <\n  T extends AbstractConstructor<LitElement & SbbDisabledMixinType>,\n>(\n  superClass: T,\n): AbstractConstructor<SbbDisabledInteractiveMixinType> & T => {\n  abstract class SbbDisabledInteractiveElement\n    extends superClass\n    implements Partial<SbbDisabledInteractiveMixinType>\n  {\n    /** Whether disabled buttons should be interactive. */\n    @property({ attribute: 'disabled-interactive', type: Boolean }) public disabledInteractive =\n      false;\n  }\n\n  return SbbDisabledInteractiveElement as unknown as AbstractConstructor<SbbDisabledInteractiveMixinType> &\n    T;\n};\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbDisabledTabIndexActionMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbDisabledMixinType & SbbDisabledInteractiveMixinType> & T => {\n  abstract class SbbDisabledTabIndexAction\n    extends SbbDisabledInteractiveMixin(SbbDisabledMixin(superClass))\n    implements SbbDisabledMixinType, SbbDisabledInteractiveMixinType\n  {\n    protected override willUpdate(changedProperties: PropertyValues<this>): void {\n      super.willUpdate(changedProperties);\n\n      if (!changedProperties.has('disabled') && !changedProperties.has('disabledInteractive')) {\n        return;\n      }\n\n      if (!this.disabled || this.disabledInteractive) {\n        this.setAttribute('tabindex', '0');\n      } else {\n        this.removeAttribute('tabindex');\n      }\n\n      if (this.disabled) {\n        this.setAttribute('aria-disabled', 'true');\n      } else {\n        this.removeAttribute('aria-disabled');\n      }\n    }\n  }\n  return SbbDisabledTabIndexAction as AbstractConstructor<\n    SbbDisabledMixinType & SbbDisabledInteractiveMixinType\n  > &\n    T;\n};\n\n/**\n * Extends `SbbDisabledMixin` with the `aria-disabled` attribute.\n * For a11y purposes, keeps the element focusable even when disabled.\n * @deprecated Will be removed with next major version\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbFocusableDisabledActionMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbDisabledMixinType> & T => {\n  abstract class SbbFocusableDisabledAction\n    extends SbbDisabledMixin(superClass)\n    implements SbbDisabledMixinType\n  {\n    protected override willUpdate(changedProperties: PropertyValues<this>): void {\n      super.willUpdate(changedProperties);\n\n      if (!changedProperties.has('disabled')) {\n        return;\n      }\n\n      if (this.disabled) {\n        this.setAttribute('aria-disabled', 'true');\n      } else {\n        this.removeAttribute('aria-disabled');\n      }\n    }\n  }\n  return SbbFocusableDisabledAction as AbstractConstructor<SbbDisabledMixinType> & T;\n};\n","import type { LitElement } from 'lit';\nimport { property, state } from 'lit/decorators.js';\n\nimport type { Constructor } from './constructor.js';\n\nexport declare abstract class SbbFormAssociatedMixinType {\n  public get form(): HTMLFormElement | null;\n  public get name(): string;\n  public set name(value: string);\n  public get type(): string;\n  public get value(): string | null;\n  public set value(value: string | null);\n\n  public get validity(): ValidityState;\n  public get validationMessage(): string;\n  public get willValidate(): boolean;\n\n  protected formDisabled: boolean;\n  protected readonly internals: ElementInternals;\n\n  public checkValidity(): boolean;\n  public reportValidity(): boolean;\n\n  public formAssociatedCallback?(form: HTMLFormElement | null): void;\n  public formDisabledCallback(disabled: boolean): void;\n  public abstract formResetCallback(): void;\n  public abstract formStateRestoreCallback(\n    state: FormRestoreState | null,\n    reason: FormRestoreReason,\n  ): void;\n\n  protected updateFormValue(): void;\n}\n\n/**\n * The FormAssociatedMixin enables native form support for custom controls.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbFormAssociatedMixin = <T extends Constructor<LitElement>>(\n  superClass: T,\n): Constructor<SbbFormAssociatedMixinType> & T => {\n  abstract class SbbFormAssociatedElement\n    extends superClass\n    implements Partial<SbbFormAssociatedMixinType>\n  {\n    public static formAssociated = true;\n\n    /**\n     * Returns the form owner of internals target element.\n     */\n    public get form(): HTMLFormElement | null {\n      return this.internals.form;\n    }\n\n    /**\n     * Name of the form element. Will be read from name attribute.\n     *\n     * @description Developer note: In this case updating the attribute must be synchronous.\n     * Due to this it is implemented as a getter/setter and the attributeChangedCallback() handles the diff check.\n     */\n    @property()\n    public set name(name: string) {\n      this.setAttribute('name', `${name}`);\n    }\n    public get name(): string {\n      return this.getAttribute('name') ?? '';\n    }\n\n    /** @internal */\n    public get type(): string {\n      return this.localName;\n    }\n\n    /** Value of the form element. */\n    @property()\n    public set value(value: string | null) {\n      this._value = value;\n      this.updateFormValue();\n    }\n    public get value(): string | null {\n      return this._value;\n    }\n    private _value: string | null = null;\n\n    /**\n     * Returns the ValidityState object for internals target element.\n     *\n     * @internal\n     */\n    public get validity(): ValidityState {\n      return this.internals.validity;\n    }\n\n    /**\n     * Returns the error message that would be shown to the user\n     * if internals target element was to be checked for validity.\n     *\n     * @internal\n     */\n    public get validationMessage(): string {\n      return this.internals.validationMessage;\n    }\n\n    /**\n     * Returns true if internals target element will be validated\n     * when the form is submitted; false otherwise.\n     *\n     * @internal\n     */\n    public get willValidate(): boolean {\n      return this.internals.willValidate;\n    }\n\n    /** @internal */\n    protected readonly internals: ElementInternals = this.attachInternals();\n\n    /** Whenever a surrounding form or fieldset is changing its disabled state. */\n    @state() protected formDisabled: boolean = false;\n\n    public override attributeChangedCallback(\n      name: string,\n      old: string | null,\n      value: string | null,\n    ): void {\n      if (name !== 'name' || old !== value) {\n        super.attributeChangedCallback(name, old, value);\n      }\n    }\n\n    /**\n     * Returns true if internals target element has no validity problems; false otherwise.\n     * Fires an invalid event at the element in the latter case.\n     *\n     * @internal\n     */\n    public checkValidity(): boolean {\n      return this.internals.checkValidity();\n    }\n\n    /**\n     * Returns true if internals target element has no validity problems; otherwise,\n     * returns false, fires an invalid event at the element,\n     * and (if the event isn't canceled) reports the problem to the user.\n     *\n     * @internal\n     */\n    public reportValidity(): boolean {\n      return this.internals.reportValidity();\n    }\n\n    /**\n     * Called when the associated form element changes.\n     * ElementInternals.form returns the associated from element.\n     *\n     * @internal\n     */\n    public formAssociatedCallback?(form: HTMLFormElement | null): void;\n\n    /**\n     * Is called whenever a surrounding form / fieldset changes disabled state.\n     * @param disabled\n     *\n     * @internal\n     */\n    public formDisabledCallback(disabled: boolean): void {\n      // This callback is triggered if the disabled property changes or the disabled attribute of a fieldset or form changes.\n      // We need to postpone the assignment, otherwise it interferes with disabled status setting\n      // and leads to a wrong state (e.g. embedded sbb-visual-checkbox).\n      Promise.resolve().then(() => {\n        this.formDisabled = disabled;\n      });\n    }\n\n    /**\n     * Is called whenever the form is being reset.\n     *\n     * @internal\n     */\n    public abstract formResetCallback(): void;\n\n    /**\n     *  Called when the browser is trying to restore element’s state to state in which case\n     *  reason is “restore”, or when the browser is trying to fulfill autofill on behalf of\n     *  user in which case reason is “autocomplete”.\n     *  In the case of “restore”, state is a string, File, or FormData object\n     *  previously set as the second argument to setFormValue.\n     *\n     * @internal\n     */\n    public abstract formStateRestoreCallback(\n      state: FormRestoreState | null,\n      reason: FormRestoreReason,\n    ): void;\n\n    /** Should be called when form value is changed. */\n    protected updateFormValue(): void {\n      this.internals.setFormValue(this.value);\n    }\n  }\n  return SbbFormAssociatedElement as unknown as Constructor<SbbFormAssociatedMixinType> & T;\n};\n\n/**\n * A value to be restored for a component's form value. If a component's form\n * state is a `FormData` object, its entry list of name and values will be\n * provided.\n */\nexport type FormRestoreState = File | string | [string, FormDataEntryValue][];\n\n/**\n * The reason a form component is being restored for, either `'restore'` for\n * browser restoration or `'autocomplete'` for restoring user values.\n */\nexport type FormRestoreReason = 'restore' | 'autocomplete';\n","import type { LitElement, PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport type { AbstractConstructor } from './constructor.js';\nimport type { SbbFormAssociatedMixinType } from './form-associated-mixin.js';\n\nexport declare class SbbRequiredMixinType {\n  public set required(value: boolean);\n  public get required(): boolean;\n  protected isRequiredExternally(): boolean;\n}\n\n/**\n * Enhance your component with a required property.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbRequiredMixin = <\n  T extends AbstractConstructor<LitElement & SbbFormAssociatedMixinType>,\n>(\n  superClass: T,\n): AbstractConstructor<SbbRequiredMixinType> & T => {\n  abstract class SbbRequiredElement extends superClass implements Partial<SbbRequiredMixinType> {\n    /** Whether the component is required. */\n    @property({ reflect: true, type: Boolean })\n    public set required(value: boolean) {\n      // To provide the same behavior as the native required state,\n      // any value is converted to a boolean.\n      this._required = Boolean(value);\n    }\n    public get required(): boolean {\n      return this._required || this.isRequiredExternally();\n    }\n    private _required: boolean = false;\n\n    protected override async willUpdate(changedProperties: PropertyValues<this>): Promise<void> {\n      super.willUpdate(changedProperties);\n\n      if (changedProperties.has('required')) {\n        // Firefox needs explicitly set aria-required value.\n        this.internals.ariaRequired = `${this.required}`;\n      }\n    }\n\n    /**\n     * Will be used as 'or' check to the current required state.\n     * Can e.g. be used to read required state of a group.\n     */\n    protected isRequiredExternally(): boolean {\n      return false;\n    }\n  }\n\n  return SbbRequiredElement as unknown as AbstractConstructor<SbbRequiredMixinType> & T;\n};\n","import { defaultConverter, type LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { hostAttributes } from '../decorators.js';\nimport { preventScrollOnSpacebarPress } from '../eventing.js';\n\nimport type { Constructor } from './constructor.js';\nimport { SbbDisabledMixin, type SbbDisabledMixinType } from './disabled-mixin.js';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbFormAssociatedMixin,\n  type SbbFormAssociatedMixinType,\n} from './form-associated-mixin.js';\nimport { SbbRequiredMixin, type SbbRequiredMixinType } from './required-mixin.js';\n\ntype CheckedSetterValue = { value: boolean; attribute: boolean };\n\nexport declare abstract class SbbFormAssociatedCheckboxMixinType\n  extends SbbFormAssociatedMixinType\n  implements Partial<SbbDisabledMixinType>, Partial<SbbRequiredMixinType>\n{\n  public get checked(): boolean;\n  public set checked(value: boolean);\n\n  public set disabled(value: boolean);\n  public get disabled(): boolean;\n\n  public set required(value: boolean);\n  public get required(): boolean;\n\n  public formResetCallback(): void;\n  public formStateRestoreCallback(state: FormRestoreState | null, reason: FormRestoreReason): void;\n\n  protected isDisabledExternally(): boolean;\n  protected isRequiredExternally(): boolean;\n  protected withUserInteraction?(): void;\n}\n\n/**\n * The FormAssociatedCheckboxMixin enables native form support for checkbox controls.\n *\n * Inherited classes MUST implement the ariaChecked state (ElementInternals) themselves.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbFormAssociatedCheckboxMixin = <T extends Constructor<LitElement>>(\n  superClass: T,\n): Constructor<SbbFormAssociatedCheckboxMixinType> & T => {\n  @hostAttributes({\n    tabindex: '0',\n  })\n  abstract class SbbFormAssociatedCheckboxElement\n    extends SbbDisabledMixin(SbbRequiredMixin(SbbFormAssociatedMixin(superClass)))\n    implements Partial<SbbFormAssociatedCheckboxMixinType>\n  {\n    private _attributeMutationBlocked = false;\n\n    /** Whether the checkbox is checked. */\n    @property({\n      type: Boolean,\n      converter: {\n        ...defaultConverter,\n        // We need to pass information to the setter so that we know it was called by attribute change.\n        fromAttribute: (value: string | null, type?: unknown): CheckedSetterValue => {\n          const result = defaultConverter.fromAttribute?.(value, type);\n          return { value: result, attribute: true } as CheckedSetterValue;\n        },\n      },\n    })\n    public set checked(value: boolean) {\n      const attributeSetter =\n        typeof value === 'object' ? (value as unknown as CheckedSetterValue).attribute : false;\n      if (attributeSetter) {\n        value = (value as unknown as CheckedSetterValue).value;\n      }\n\n      // As soon as mutation was done not by setting attribute,\n      // we need to block syncing attribute.\n      if (this.hasUpdated && !attributeSetter) {\n        this._attributeMutationBlocked = true;\n      }\n      this._checked = Boolean(value);\n      this.updateFormValue();\n    }\n    public get checked(): boolean {\n      return this._checked;\n    }\n    private _checked = false;\n\n    protected constructor() {\n      super();\n      /** @internal */\n      this.internals.role = 'checkbox';\n    }\n\n    public override connectedCallback(): void {\n      super.connectedCallback();\n\n      this.addEventListener('click', this._handleUserInteraction);\n      this.addEventListener('keydown', preventScrollOnSpacebarPress);\n      this.addEventListener('keyup', this._handleKeyboardInteraction);\n    }\n\n    public override disconnectedCallback(): void {\n      super.disconnectedCallback();\n\n      this.removeEventListener('click', this._handleUserInteraction);\n      this.removeEventListener('keydown', preventScrollOnSpacebarPress);\n      this.removeEventListener('keyup', this._handleKeyboardInteraction);\n    }\n\n    public override attributeChangedCallback(\n      name: string,\n      old: string | null,\n      value: string | null,\n    ): void {\n      // Attribute should not be interpreted after programmatic or manual state change.\n      if (name !== 'checked' || !this._attributeMutationBlocked) {\n        super.attributeChangedCallback(name, old, value);\n      }\n    }\n\n    /**\n     * Is called whenever the form is being reset.\n     *\n     * @internal\n     */\n    public override formResetCallback(): void {\n      this.checked = this.hasAttribute('checked');\n      this._attributeMutationBlocked = false;\n    }\n\n    /**\n     *  Called when the browser is trying to restore element’s state to state in which case\n     *  reason is “restore”, or when the browser is trying to fulfill autofill on behalf of\n     *  user in which case reason is “autocomplete”.\n     *  In the case of “restore”, state is a string, File, or FormData object\n     *  previously set as the second argument to setFormValue.\n     *\n     * @internal\n     */\n    public override formStateRestoreCallback(\n      state: FormRestoreState | null,\n      _reason: FormRestoreReason,\n    ): void {\n      if (state) {\n        this.checked = state === 'true';\n      }\n    }\n\n    /**\n     * Additional logic which is being executed when user\n     * interaction happens and state is not disabled.\n     */\n    protected withUserInteraction?(): void;\n\n    protected override updateFormValue(): void {\n      if (this.checked) {\n        this.internals.setFormValue(this.value, `${this.checked}`);\n      } else {\n        this.internals.setFormValue(null);\n      }\n    }\n\n    /** Method triggered on keyboard user interaction with checkbox. */\n    private _handleKeyboardInteraction = (event: KeyboardEvent): void => {\n      if (event.key === ' ') {\n        this._handleUserInteraction();\n      }\n    };\n\n    /** Method triggered on user interaction with checkbox. */\n    private _handleUserInteraction = (): void => {\n      if (this.disabled) {\n        return;\n      }\n      this.withUserInteraction?.();\n      this.checked = !this.checked;\n      this._attributeMutationBlocked = true;\n\n      this.dispatchEvent(new InputEvent('input', { composed: true, bubbles: true }));\n      this.dispatchEvent(new Event('change', { bubbles: true }));\n      this.dispatchEvent(new CustomEvent('didChange', { bubbles: true }));\n    };\n  }\n\n  return SbbFormAssociatedCheckboxElement as unknown as Constructor<SbbFormAssociatedCheckboxMixinType> &\n    T;\n};\n","import type { LitElement, PropertyValues } from 'lit';\n\nimport type { AbstractConstructor } from './constructor.js';\n\n// Define the interface for the mixin\nexport declare abstract class SbbHydrationMixinType {\n  /**\n   * Returns a Promise that resolves when the element has completed hydration.\n   * The Promise value is a boolean that is `true` if the element required hydration\n   * and `false` if not.\n   *\n   * @return A promise of a boolean that resolves to true once the hydration completed.\n   */\n  public get hydrationComplete(): Promise<boolean>;\n\n  /** Returns whether hydration is required and not completed. */\n  protected get hydrationRequired(): boolean;\n}\n\n/**\n * This mixin extends a base class with functionality to check if hydration is completed.\n * It also delays slotchange events until hydration is complete.\n *\n * @param base The class to extend.\n * @returns A class extended with the hydration check functionality.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbHydrationMixin = <T extends AbstractConstructor<LitElement>>(\n  base: T,\n): AbstractConstructor<SbbHydrationMixinType> & T => {\n  abstract class SbbHydrationMixinClass extends base implements Partial<SbbHydrationMixinType> {\n    private _hydrationRequired: boolean;\n    private _hydrationComplete = new Promise<boolean>(\n      (resolve) => (this._resolveHydration = resolve),\n    );\n    private _resolveHydration!: (hydrationRequired: boolean) => void;\n\n    /**\n     * Returns a Promise that resolves when the element has completed hydration.\n     * The Promise value is a boolean that is `true` if the element required hydration\n     * and `false` if not.\n     *\n     * @return A promise of a boolean that resolves to true once the hydration completed.\n     * @internal\n     */\n    public get hydrationComplete(): Promise<boolean> {\n      return this._hydrationComplete;\n    }\n\n    /** Returns whether hydration is required and not completed. */\n    protected get hydrationRequired(): boolean {\n      return this._hydrationRequired;\n    }\n\n    public constructor(...args: any[]) {\n      super(...args);\n      // Check whether hydration is needed by checking whether the shadow root\n      // is available during construction/upgrade phase.\n      this._hydrationRequired = !!this.shadowRoot;\n      if (!this._hydrationRequired) {\n        this._resolveHydration(false);\n      } else {\n        // During hydration phase, we want to suppress slotchange events as they\n        // can cause render differences, which would break hydration. After\n        // hydration is complete, we dispatch a manual slotchange event, if there\n        // are elements assigned to a slot.\n        const suppressSlotchangeEvent = (event: Event): void => {\n          if (this._hydrationRequired) {\n            event.stopImmediatePropagation();\n          }\n        };\n        const eventOptions: EventListenerOptions = { capture: true };\n        const slots = this.shadowRoot?.querySelectorAll('slot');\n        if (slots?.length) {\n          slots.forEach((slot) =>\n            slot.addEventListener('slotchange', suppressSlotchangeEvent, eventOptions),\n          );\n          this.hydrationComplete.then(() =>\n            slots.forEach((slot) => {\n              slot.removeEventListener('slotchange', suppressSlotchangeEvent, eventOptions);\n              if (slot.assignedNodes().length) {\n                slot.dispatchEvent(new Event('slotchange', { bubbles: true }));\n              }\n            }),\n          );\n        }\n      }\n    }\n\n    protected override update(changedProperties: PropertyValues<this>): void {\n      // When hydration is needed, we wait the hydration process to finish, which is patched\n      // into the update method of the LitElement base class.\n      super.update(changedProperties);\n\n      if (this._hydrationRequired) {\n        this._hydrationRequired = false;\n        this._resolveHydration(true);\n      }\n    }\n  }\n  return SbbHydrationMixinClass as unknown as AbstractConstructor<SbbHydrationMixinType> & T;\n};\n","import { html, type LitElement, nothing, type TemplateResult } from 'lit';\nimport { state } from 'lit/decorators.js';\n\nimport type { AbstractConstructor } from './constructor.js';\nimport { SbbHydrationMixin, type SbbHydrationMixinType } from './hydration-mixin.js';\n\nimport '../../screen-reader-only.js';\n\nconst SSR_CHILD_COUNT_ATTRIBUTE = 'data-ssr-child-count';\nconst SLOTNAME_PREFIX = 'li';\n\nexport type SbbNamedSlotProperties = {\n  name: string;\n  ariaHidden: boolean;\n};\n\n/**\n * Helper type for willUpdate or similar checks.\n * Allows the usage of the string literal 'listChildren'.\n *\n * @example\n * protected override willUpdate(changedProperties: PropertyValues<WithListChildren<this>>): void {\n *   if (changedProperties.has('listChildren')) {\n *     ...\n *   }\n * }\n */\nexport type WithListChildren<\n  T extends SbbNamedSlotListMixinType<C>,\n  C extends HTMLElement = HTMLElement,\n> = T & { listChildren: C[] };\n\nexport declare abstract class SbbNamedSlotListMixinType<\n  C extends HTMLElement,\n> extends SbbHydrationMixinType {\n  protected abstract readonly listChildLocalNames: string[];\n  @state() protected listChildren: C[];\n  protected renderList(\n    attributes?: {\n      class?: string;\n      ariaLabel?: string;\n      ariaLabelledby?: string;\n    },\n    listItemAttributes?: {\n      localNameVisualOnly?: string[];\n    },\n  ): TemplateResult;\n  protected listSlotEntries(): SbbNamedSlotProperties[];\n  protected renderHiddenSlot(): TemplateResult;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbNamedSlotListMixin = <\n  C extends HTMLElement,\n  T extends AbstractConstructor<LitElement>,\n>(\n  superClass: T,\n): AbstractConstructor<SbbNamedSlotListMixinType<C>> & T => {\n  /**\n   * This base class provides named slot list observer functionality.\n   * This allows using the pattern of rendering a named slot for each child, which allows\n   * wrapping children in an ul/li list.\n   */\n  abstract class NamedSlotListElement<C extends HTMLElement = HTMLElement>\n    extends SbbHydrationMixin(superClass)\n    implements Partial<SbbNamedSlotListMixinType<C>>\n  {\n    /** A list of lower-cased tag names to match against. (e.g. `sbb-link`) */\n    protected abstract readonly listChildLocalNames: string[];\n\n    /**\n     * A list of children with the defined tag names.\n     * This array is only updated if there is an actual change\n     * to the child elements.\n     */\n    @state() protected listChildren: C[] = [];\n\n    public override connectedCallback(): void {\n      super.connectedCallback();\n      this.shadowRoot?.addEventListener('slotchange', this._handleSlotchange, { passive: true });\n    }\n\n    public override disconnectedCallback(): void {\n      super.disconnectedCallback();\n      this.shadowRoot?.removeEventListener('slotchange', this._handleSlotchange);\n    }\n\n    private _handleSlotchange = (): void => {\n      const listChildren = Array.from(this.children ?? []).filter((e): e is C =>\n        this.listChildLocalNames.includes(e.localName),\n      );\n      // If the slotted child instances have not changed, we can skip syncing and updating\n      // the link reference list.\n      if (\n        listChildren.length === this.listChildren.length &&\n        this.listChildren.every((e, i) => listChildren[i] === e)\n      ) {\n        return;\n      }\n\n      this.listChildren\n        .filter((c) => !listChildren.includes(c))\n        .forEach((c) => c.removeAttribute('slot'));\n      this.listChildren = listChildren;\n      this.listChildren.forEach((c, index) =>\n        c.setAttribute('slot', `${SLOTNAME_PREFIX}-${index}`),\n      );\n\n      // Remove the ssr attribute, once we have actually initialized the children elements.\n      this.removeAttribute(SSR_CHILD_COUNT_ATTRIBUTE);\n    };\n\n    /**\n     * Renders list and list slots for slotted children or a number of list slots\n     * corresponding to the `data-ssr-child-count` attribute value.\n     *\n     * This is a possible optimization for SSR, as in an SSR Lit environment\n     * other elements are not available, but might be available in the meta\n     * framework wrapper (like e.g. React). This allows to provide the number of\n     * children to be passed via the `data-ssr-child-count` attribute value.\n     */\n    protected renderList(\n      attributes: { class?: string; ariaLabel?: string; ariaLabelledby?: string } = {},\n      listItemAttributes: { localNameVisualOnly?: string[] } = {},\n    ): TemplateResult {\n      const listSlotNames: SbbNamedSlotProperties[] = this.listSlotEntries(listItemAttributes);\n\n      if (listSlotNames.length >= 2) {\n        return html`\n          <ul\n            class=${attributes.class || this.localName}\n            aria-label=${attributes.ariaLabel || nothing}\n            aria-labelledby=${attributes.ariaLabelledby || nothing}\n          >\n            ${listSlotNames.map(\n              (slot) => html`\n                <li aria-hidden=${slot.ariaHidden || nothing}>\n                  <slot name=${slot.name}></slot>\n                </li>\n              `,\n            )}\n          </ul>\n          ${this.renderHiddenSlot()}\n        `;\n      } else if (listSlotNames.length === 1) {\n        return html`<sbb-screen-reader-only>${attributes.ariaLabel}</sbb-screen-reader-only>\n          <span class=${attributes.class || this.localName}>\n            <span><slot name=${listSlotNames[0].name}></slot></span>\n          </span>\n          ${this.renderHiddenSlot()} `;\n      } else {\n        return this.renderHiddenSlot();\n      }\n    }\n\n    /**\n     * Returns an array of SbbNamedSlotProperties, which holds the list slot names and the hidden property;\n     * its length corresponds to the number of matched children or the `data-ssr-child-count` attribute value.\n     *\n     * This is a possible optimization for SSR, as in an SSR Lit environment\n     * other elements are not available, but might be available in the meta\n     * framework wrapper (like e.g. React). This allows to provide the number of\n     * children to be passed via the `data-ssr-child-count` attribute value.\n     */\n    protected listSlotEntries(listItemAttributes: {\n      localNameVisualOnly?: string[];\n    }): SbbNamedSlotProperties[] {\n      const listChildren = this.listChildren.length\n        ? this.listChildren\n        : Array.from({ length: +(this.getAttribute(SSR_CHILD_COUNT_ATTRIBUTE) ?? 0) });\n      return listChildren.map((e, i) => {\n        return {\n          name: `${SLOTNAME_PREFIX}-${i}`,\n          ariaHidden:\n            listItemAttributes?.localNameVisualOnly?.includes((e as HTMLElement).localName) ??\n            false,\n        };\n      });\n    }\n\n    /**\n     * Returns a hidden slot, which is intended as the children change detection.\n     * When an element without a slot attribute is slotted to the element, it triggers\n     * the slotchange event, which can be used to assign it to the appropriate named slot.\n     */\n    protected renderHiddenSlot(): TemplateResult {\n      return html`<span hidden><slot></slot></span>`;\n    }\n  }\n\n  return NamedSlotListElement as unknown as AbstractConstructor<SbbNamedSlotListMixinType<C>> & T;\n};\n","import type { LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport type { AbstractConstructor } from './constructor.js';\n\nexport declare class SbbNegativeMixinType {\n  public negative: boolean;\n}\n\n/**\n * Enhance your component with a negative property.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbNegativeMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbNegativeMixinType> & T => {\n  abstract class SbbNegativeElement extends superClass implements SbbNegativeMixinType {\n    /** Negative coloring variant flag. */\n    @property({ reflect: true, type: Boolean }) public negative: boolean = false;\n  }\n\n  return SbbNegativeElement as AbstractConstructor<SbbNegativeMixinType> & T;\n};\n","import type { LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { EventEmitter } from '../eventing.js';\n\nimport type { AbstractConstructor } from './constructor.js';\n\nexport declare class SbbPanelMixinType {\n  public color: 'white' | 'milk';\n  public borderless: boolean;\n  public expansionState?: string;\n}\n\nexport type SbbPanelSize = 's' | 'm';\n\n/**\n * Mixin for common panel behaviors\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbPanelMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbPanelMixinType> & T => {\n  abstract class SbbPanelElement extends superClass implements SbbPanelMixinType {\n    public static readonly events = {\n      panelConnected: 'panelConnected',\n    } as const;\n\n    /** The background color of the panel. */\n    @property() public color: 'white' | 'milk' = 'white';\n\n    /** Whether the unselected panel has a border. */\n    @property({ reflect: true, type: Boolean }) public borderless = false;\n\n    /** @internal used for accessibility label when in expansion panel */\n    @property() public expansionState?: string;\n\n    /**\n     * @internal\n     * Internal event that emits when the checkbox is loaded.\n     */\n    private _panelConnected: EventEmitter<void> = new EventEmitter(\n      this,\n      SbbPanelElement.events.panelConnected,\n      { bubbles: true },\n    );\n\n    public override connectedCallback(): void {\n      super.connectedCallback();\n\n      this._panelConnected.emit();\n    }\n  }\n\n  return SbbPanelElement as AbstractConstructor<SbbPanelMixinType> & T;\n};\n","import type { LitElement } from 'lit';\n\nimport type { AbstractConstructor } from './constructor.js';\n\n// Define the interface for the mixin\nexport declare class SbbUpdateSchedulerMixinType {\n  protected startUpdate(): void;\n  protected completeUpdate(): void;\n}\n\n/**\n * This mixin allows scheduling manual updates, which affect updateComplete.\n * @param base The class to extend.\n * @returns A class extended with the slot child observer functionality.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbUpdateSchedulerMixin = <T extends AbstractConstructor<LitElement>>(\n  base: T,\n): AbstractConstructor<SbbUpdateSchedulerMixinType> & T => {\n  abstract class SbbUpdateSchedulerElement\n    extends base\n    implements Partial<SbbUpdateSchedulerMixinType>\n  {\n    private _updatePromise = Promise.resolve();\n    private _updateResolve = (): void => {};\n\n    protected startUpdate(): void {\n      this._updatePromise = new Promise<void>((r) => (this._updateResolve = r));\n    }\n\n    protected completeUpdate(): void {\n      this._updateResolve();\n    }\n\n    protected override async getUpdateComplete(): Promise<boolean> {\n      const result = await super.getUpdateComplete();\n      await this._updatePromise;\n      return result;\n    }\n  }\n  return SbbUpdateSchedulerElement as unknown as AbstractConstructor<SbbUpdateSchedulerMixinType> &\n    T;\n};\n"],"names":["__decorateClass","state"],"mappings":"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"}
@@ -235,7 +235,7 @@ let SbbMapContainerElement = class extends LitElement {
235
235
  icon-name="location-pin-map-small"
236
236
  type="button"
237
237
  @click=${() => this._onScrollButtonClick()}
238
- .inert=${!this._scrollUpButtonVisible}
238
+ ?inert=${!this._scrollUpButtonVisible}
239
239
  >
240
240
  ${i18nMapContainerButtonLabel[this._language.current]}
241
241
  </sbb-tertiary-button>` : nothing}
@@ -257,4 +257,4 @@ SbbMapContainerElement = __decorateClass([
257
257
  export {
258
258
  SbbMapContainerElement
259
259
  };
260
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"map-container.js","sources":["../../../src/elements/map-container/map-container.ts"],"sourcesContent":["import { IntersectionController } from '@lit-labs/observers/intersection-controller.js';\nimport type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\n\nimport { SbbLanguageController } from '../core/controllers.js';\nimport { i18nMapContainerButtonLabel } from '../core/i18n.js';\n\nimport style from './map-container.scss?lit&inline';\n\nimport '../button/tertiary-button.js';\n\n/**\n * It can be used as a container for maps.\n *\n * @slot - Use the unnamed slot to add content to the sidebar.\n * @slot map - Used for slotting the map.\n * @cssprop [--sbb-map-container-margin-start=var(--sbb-header-height)] - The component\n * comes along with a height calculation that subtracts the height of the header.\n * For specific use cases, this variable can be used to modify the preset height.\n * @cssprop [--sbb-map-container-sidebar-width=zero-large:400px;wide-ultra:480px] - Can be used\n * to modify the width of the left sidebar.\n * @cssprop [--sbb-map-container-mobile-sticky-block-start=0] - If e.g. a header with a fixed height\n * is placed before the map-container, the map should be sticky respecting\n * this offset from the document's top. Only applied on mobile views.\n * Most commonly it can be set to `var(--sbb-header-height)`.\n */\n@customElement('sbb-map-container')\nexport class SbbMapContainerElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /** Flag to show/hide the scroll up button inside the sidebar on mobile. */\n  @property({ attribute: 'hide-scroll-up-button', reflect: true, type: Boolean })\n  public hideScrollUpButton = false;\n\n  @state() private _scrollUpButtonVisible = false;\n\n  private _language = new SbbLanguageController(this);\n  private _observer = new IntersectionController(this, {\n    target: null,\n    callback: (entries) => this._toggleButtonVisibilityOnIntersect(entries),\n  });\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('hideScrollUpButton')) {\n      const intersectorElement = this._intersector();\n\n      if (!this.hideScrollUpButton && intersectorElement) {\n        this._observer.observe(intersectorElement);\n      } else if (intersectorElement) {\n        this._observer.unobserve(intersectorElement);\n      }\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    if (!this.hideScrollUpButton) {\n      this._observer.observe(this._intersector()!);\n    }\n  }\n\n  private _intersector(): HTMLElement | null {\n    return this.shadowRoot?.querySelector('#intersector') ?? null;\n  }\n\n  /**\n   * Button click callback to trigger the scroll to container top\n   * @private\n   */\n  private _onScrollButtonClick(): void {\n    this.scrollIntoView({ behavior: 'smooth' });\n  }\n\n  /**\n   * Intersection callback. Toggles the visibility.\n   * @param entries\n   * @private\n   */\n  private _toggleButtonVisibilityOnIntersect(entries: IntersectionObserverEntry[]): void {\n    entries.forEach((entry) => {\n      const mapIsHidden = !entry.isIntersecting;\n      this.toggleAttribute('data-scroll-up-button-visible', mapIsHidden);\n      this._scrollUpButtonVisible = mapIsHidden;\n    });\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-map-container\">\n        <div class=\"sbb-map-container__map\">\n          <slot name=\"map\"></slot>\n        </div>\n        <div class=\"sbb-map-container__sidebar\">\n          <span id=\"intersector\"></span>\n\n          <slot></slot>\n\n          ${!this.hideScrollUpButton\n            ? html`<sbb-tertiary-button\n                class=\"sbb-map-container__sidebar-button\"\n                size=\"l\"\n                icon-name=\"location-pin-map-small\"\n                type=\"button\"\n                @click=${() => this._onScrollButtonClick()}\n                .inert=${!this._scrollUpButtonVisible}\n              >\n                ${i18nMapContainerButtonLabel[this._language.current]}\n              </sbb-tertiary-button>`\n            : nothing}\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-map-container': SbbMapContainerElement;\n  }\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4Ba,IAAA,yBAAN,cAAqC,WAAW;AAAA,EAAhD,cAAA;AAAA,UAAA,GAAA,SAAA;AAKL,SAAO,qBAAqB;AAEnB,SAAQ,yBAAyB;AAElC,SAAA,YAAY,IAAI,sBAAsB,IAAI;AAC1C,SAAA,YAAY,IAAI,uBAAuB,MAAM;AAAA,MACnD,QAAQ;AAAA,MACR,UAAU,CAAC,YAAY,KAAK,mCAAmC,OAAO;AAAA,IAAA,CACvE;AAAA,EAAA;AAAA,EAEkB,WAAW,mBAA+C;AAC3E,UAAM,WAAW,iBAAiB;AAE9B,QAAA,kBAAkB,IAAI,oBAAoB,GAAG;AACzC,YAAA,qBAAqB,KAAK;AAE5B,UAAA,CAAC,KAAK,sBAAsB,oBAAoB;AAC7C,aAAA,UAAU,QAAQ,kBAAkB;AAAA,iBAChC,oBAAoB;AACxB,aAAA,UAAU,UAAU,kBAAkB;AAAA,MAC7C;AAAA,IACF;AAAA,EACF;AAAA,EAEmB,aAAa,mBAA+C;AAC7E,UAAM,aAAa,iBAAiB;AAChC,QAAA,CAAC,KAAK,oBAAoB;AAC5B,WAAK,UAAU,QAAQ,KAAK,aAAe,CAAA;AAAA,IAC7C;AAAA,EACF;AAAA,EAEQ,eAAmC;;AACzC,aAAO,UAAK,eAAL,mBAAiB,cAAc,oBAAmB;AAAA,EAC3D;AAAA;AAAA;AAAA;AAAA;AAAA,EAMQ,uBAA6B;AACnC,SAAK,eAAe,EAAE,UAAU,SAAU,CAAA;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOQ,mCAAmC,SAA4C;AAC7E,YAAA,QAAQ,CAAC,UAAU;AACnB,YAAA,cAAc,CAAC,MAAM;AACtB,WAAA,gBAAgB,iCAAiC,WAAW;AACjE,WAAK,yBAAyB;AAAA,IAAA,CAC/B;AAAA,EACH;AAAA,EAEmB,SAAyB;AACnC,WAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,YAUC,CAAC,KAAK,qBACJ;AAAA;AAAA;AAAA;AAAA;AAAA,yBAKW,MAAM,KAAK,sBAAsB;AAAA,yBACjC,CAAC,KAAK,sBAAsB;AAAA;AAAA,kBAEnC,4BAA4B,KAAK,UAAU,OAAO,CAAC;AAAA,wCAEvD,OAAO;AAAA;AAAA;AAAA;AAAA,EAInB;AACF;AAxFa,uBACY,SAAyB;AAIzC,gBAAA;AAAA,EADN,SAAS,EAAE,WAAW,yBAAyB,SAAS,MAAM,MAAM,SAAS;AAAA,GAJnE,uBAKJ,WAAA,sBAAA,CAAA;AAEU,gBAAA;AAAA,EAAhB,MAAM;AAAA,GAPI,uBAOM,WAAA,0BAAA,CAAA;AAPN,yBAAN,gBAAA;AAAA,EADN,cAAc,mBAAmB;AAAA,GACrB,sBAAA;"}
260
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"map-container.js","sources":["../../../src/elements/map-container/map-container.ts"],"sourcesContent":["import { IntersectionController } from '@lit-labs/observers/intersection-controller.js';\nimport type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\n\nimport { SbbLanguageController } from '../core/controllers.js';\nimport { i18nMapContainerButtonLabel } from '../core/i18n.js';\n\nimport style from './map-container.scss?lit&inline';\n\nimport '../button/tertiary-button.js';\n\n/**\n * It can be used as a container for maps.\n *\n * @slot - Use the unnamed slot to add content to the sidebar.\n * @slot map - Used for slotting the map.\n * @cssprop [--sbb-map-container-margin-start=var(--sbb-header-height)] - The component\n * comes along with a height calculation that subtracts the height of the header.\n * For specific use cases, this variable can be used to modify the preset height.\n * @cssprop [--sbb-map-container-sidebar-width=zero-large:400px;wide-ultra:480px] - Can be used\n * to modify the width of the left sidebar.\n * @cssprop [--sbb-map-container-mobile-sticky-block-start=0] - If e.g. a header with a fixed height\n * is placed before the map-container, the map should be sticky respecting\n * this offset from the document's top. Only applied on mobile views.\n * Most commonly it can be set to `var(--sbb-header-height)`.\n */\n@customElement('sbb-map-container')\nexport class SbbMapContainerElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /** Flag to show/hide the scroll up button inside the sidebar on mobile. */\n  @property({ attribute: 'hide-scroll-up-button', reflect: true, type: Boolean })\n  public hideScrollUpButton = false;\n\n  @state() private _scrollUpButtonVisible = false;\n\n  private _language = new SbbLanguageController(this);\n  private _observer = new IntersectionController(this, {\n    target: null,\n    callback: (entries) => this._toggleButtonVisibilityOnIntersect(entries),\n  });\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('hideScrollUpButton')) {\n      const intersectorElement = this._intersector();\n\n      if (!this.hideScrollUpButton && intersectorElement) {\n        this._observer.observe(intersectorElement);\n      } else if (intersectorElement) {\n        this._observer.unobserve(intersectorElement);\n      }\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    if (!this.hideScrollUpButton) {\n      this._observer.observe(this._intersector()!);\n    }\n  }\n\n  private _intersector(): HTMLElement | null {\n    return this.shadowRoot?.querySelector('#intersector') ?? null;\n  }\n\n  /**\n   * Button click callback to trigger the scroll to container top\n   * @private\n   */\n  private _onScrollButtonClick(): void {\n    this.scrollIntoView({ behavior: 'smooth' });\n  }\n\n  /**\n   * Intersection callback. Toggles the visibility.\n   * @param entries\n   * @private\n   */\n  private _toggleButtonVisibilityOnIntersect(entries: IntersectionObserverEntry[]): void {\n    entries.forEach((entry) => {\n      const mapIsHidden = !entry.isIntersecting;\n      this.toggleAttribute('data-scroll-up-button-visible', mapIsHidden);\n      this._scrollUpButtonVisible = mapIsHidden;\n    });\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-map-container\">\n        <div class=\"sbb-map-container__map\">\n          <slot name=\"map\"></slot>\n        </div>\n        <div class=\"sbb-map-container__sidebar\">\n          <span id=\"intersector\"></span>\n\n          <slot></slot>\n\n          ${!this.hideScrollUpButton\n            ? html`<sbb-tertiary-button\n                class=\"sbb-map-container__sidebar-button\"\n                size=\"l\"\n                icon-name=\"location-pin-map-small\"\n                type=\"button\"\n                @click=${() => this._onScrollButtonClick()}\n                ?inert=${!this._scrollUpButtonVisible}\n              >\n                ${i18nMapContainerButtonLabel[this._language.current]}\n              </sbb-tertiary-button>`\n            : nothing}\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-map-container': SbbMapContainerElement;\n  }\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4Ba,IAAA,yBAAN,cAAqC,WAAW;AAAA,EAAhD,cAAA;AAAA,UAAA,GAAA,SAAA;AAKL,SAAO,qBAAqB;AAEnB,SAAQ,yBAAyB;AAElC,SAAA,YAAY,IAAI,sBAAsB,IAAI;AAC1C,SAAA,YAAY,IAAI,uBAAuB,MAAM;AAAA,MACnD,QAAQ;AAAA,MACR,UAAU,CAAC,YAAY,KAAK,mCAAmC,OAAO;AAAA,IAAA,CACvE;AAAA,EAAA;AAAA,EAEkB,WAAW,mBAA+C;AAC3E,UAAM,WAAW,iBAAiB;AAE9B,QAAA,kBAAkB,IAAI,oBAAoB,GAAG;AACzC,YAAA,qBAAqB,KAAK;AAE5B,UAAA,CAAC,KAAK,sBAAsB,oBAAoB;AAC7C,aAAA,UAAU,QAAQ,kBAAkB;AAAA,iBAChC,oBAAoB;AACxB,aAAA,UAAU,UAAU,kBAAkB;AAAA,MAC7C;AAAA,IACF;AAAA,EACF;AAAA,EAEmB,aAAa,mBAA+C;AAC7E,UAAM,aAAa,iBAAiB;AAChC,QAAA,CAAC,KAAK,oBAAoB;AAC5B,WAAK,UAAU,QAAQ,KAAK,aAAe,CAAA;AAAA,IAC7C;AAAA,EACF;AAAA,EAEQ,eAAmC;;AACzC,aAAO,UAAK,eAAL,mBAAiB,cAAc,oBAAmB;AAAA,EAC3D;AAAA;AAAA;AAAA;AAAA;AAAA,EAMQ,uBAA6B;AACnC,SAAK,eAAe,EAAE,UAAU,SAAU,CAAA;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOQ,mCAAmC,SAA4C;AAC7E,YAAA,QAAQ,CAAC,UAAU;AACnB,YAAA,cAAc,CAAC,MAAM;AACtB,WAAA,gBAAgB,iCAAiC,WAAW;AACjE,WAAK,yBAAyB;AAAA,IAAA,CAC/B;AAAA,EACH;AAAA,EAEmB,SAAyB;AACnC,WAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,YAUC,CAAC,KAAK,qBACJ;AAAA;AAAA;AAAA;AAAA;AAAA,yBAKW,MAAM,KAAK,sBAAsB;AAAA,yBACjC,CAAC,KAAK,sBAAsB;AAAA;AAAA,kBAEnC,4BAA4B,KAAK,UAAU,OAAO,CAAC;AAAA,wCAEvD,OAAO;AAAA;AAAA;AAAA;AAAA,EAInB;AACF;AAxFa,uBACY,SAAyB;AAIzC,gBAAA;AAAA,EADN,SAAS,EAAE,WAAW,yBAAyB,SAAS,MAAM,MAAM,SAAS;AAAA,GAJnE,uBAKJ,WAAA,sBAAA,CAAA;AAEU,gBAAA;AAAA,EAAhB,MAAM;AAAA,GAPI,uBAOM,WAAA,0BAAA,CAAA;AAPN,yBAAN,gBAAA;AAAA,EADN,cAAc,mBAAmB;AAAA,GACrB,sBAAA;"}
@@ -331,7 +331,7 @@ let SbbSelectionExpansionPanelElement = class extends SbbHydrationMixin(LitEleme
331
331
  </div>
332
332
  <div
333
333
  class="sbb-selection-expansion-panel__content--wrapper"
334
- .inert=${this._state !== "opened"}
334
+ ?inert=${this._state !== "opened"}
335
335
  @animationend=${(event) => this._onAnimationEnd(event)}
336
336
  >
337
337
  <div class="sbb-selection-expansion-panel__content">
@@ -369,4 +369,4 @@ SbbSelectionExpansionPanelElement = __decorateClass([
369
369
  export {
370
370
  SbbSelectionExpansionPanelElement
371
371
  };
372
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"selection-expansion-panel.js","sources":["../../../src/elements/selection-expansion-panel/selection-expansion-panel.ts"],"sourcesContent":["import { type CSSResultGroup, isServer, type PropertyValues, type TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\n\nimport type { SbbCheckboxGroupElement, SbbCheckboxPanelElement } from '../checkbox.js';\nimport { SbbConnectedAbortController, SbbLanguageController } from '../core/controllers.js';\nimport { slotState } from '../core/decorators.js';\nimport { EventEmitter } from '../core/eventing.js';\nimport { i18nCollapsed, i18nExpanded } from '../core/i18n.js';\nimport type { SbbOpenedClosedState, SbbStateChange } from '../core/interfaces.js';\nimport { SbbHydrationMixin } from '../core/mixins.js';\nimport type { SbbRadioButtonGroupElement, SbbRadioButtonPanelElement } from '../radio-button.js';\n\nimport style from './selection-expansion-panel.scss?lit&inline';\n\nimport '../divider.js';\n\n/**\n * It displays an expandable panel connected to a `sbb-checkbox` or to a `sbb-radio-button`.\n *\n * @slot - Use the unnamed slot to add `sbb-checkbox` or `sbb-radio-button` elements to the `sbb-selection-expansion-panel`.\n * @slot content - Use this slot to provide custom content for the panel (optional).\n * @event {CustomEvent<void>} willOpen - Emits whenever the content section starts the opening transition.\n * @event {CustomEvent<void>} didOpen - Emits whenever the content section is opened.\n * @event {CustomEvent<void>} willClose - Emits whenever the content section begins the closing transition.\n * @event {CustomEvent<void>} didClose - Emits whenever the content section is closed.\n */\n@customElement('sbb-selection-expansion-panel')\n@slotState()\nexport class SbbSelectionExpansionPanelElement extends SbbHydrationMixin(LitElement) {\n  // FIXME inheriting from SbbOpenCloseBaseElement requires: https://github.com/open-wc/custom-elements-manifest/issues/253\n  public static override styles: CSSResultGroup = style;\n  public static readonly events: Record<string, string> = {\n    willOpen: 'willOpen',\n    didOpen: 'didOpen',\n    willClose: 'willClose',\n    didClose: 'didClose',\n  } as const;\n\n  /** The background color of the panel. */\n  @property() public color: 'white' | 'milk' = 'white';\n\n  /** Whether the content section is always visible. */\n  @property({ attribute: 'force-open', type: Boolean }) public forceOpen = false;\n\n  /** Whether the unselected panel has a border. */\n  @property({ reflect: true, type: Boolean }) public borderless = false;\n\n  /** The state of the selection panel. */\n  @state()\n  private set _state(state: SbbOpenedClosedState) {\n    this.setAttribute('data-state', state);\n  }\n  private get _state(): SbbOpenedClosedState {\n    return this.getAttribute('data-state') as SbbOpenedClosedState;\n  }\n\n  /** Whether the selection panel is checked. */\n  private set _checked(checked: boolean) {\n    this.toggleAttribute('data-checked', checked);\n  }\n  private get _checked(): boolean {\n    return this.hasAttribute('data-checked');\n  }\n\n  /** Whether the selection panel is disabled. */\n  private set _disabled(disabled: boolean) {\n    this.toggleAttribute('data-disabled', disabled);\n  }\n\n  /** Emits whenever the content section starts the opening transition. */\n  private _willOpen: EventEmitter<void> = new EventEmitter(\n    this,\n    SbbSelectionExpansionPanelElement.events.willOpen,\n  );\n\n  /** Emits whenever the content section is opened. */\n  private _didOpen: EventEmitter<void> = new EventEmitter(\n    this,\n    SbbSelectionExpansionPanelElement.events.didOpen,\n  );\n\n  /** Emits whenever the content section begins the closing transition. */\n  private _willClose: EventEmitter<void> = new EventEmitter(\n    this,\n    SbbSelectionExpansionPanelElement.events.willClose,\n  );\n\n  /** Emits whenever the content section is closed. */\n  private _didClose: EventEmitter<void> = new EventEmitter(\n    this,\n    SbbSelectionExpansionPanelElement.events.didClose,\n  );\n\n  private _language = new SbbLanguageController(this);\n  private _abort = new SbbConnectedAbortController(this);\n  private _initialized: boolean = false;\n  private _sizeAttributeObserver = !isServer\n    ? new MutationObserver((mutationsList: MutationRecord[]) =>\n        this._onSizeAttributesChange(mutationsList),\n      )\n    : null;\n\n  /** Whether it has an expandable content */\n  private get _hasContent(): boolean {\n    // We cannot use the NamedSlots because it's too slow to initialize\n    return this.querySelectorAll?.('[slot=\"content\"]').length > 0;\n  }\n\n  private get _group(): SbbRadioButtonGroupElement | SbbCheckboxGroupElement | null {\n    return this.closest('sbb-radio-button-group, sbb-checkbox-group') as\n      | SbbRadioButtonGroupElement\n      | SbbCheckboxGroupElement;\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n\n    this.addEventListener('panelConnected', this._initFromInput.bind(this), {\n      signal: this._abort.signal,\n    });\n\n    this._state ||= 'closed';\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._sizeAttributeObserver?.disconnect();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('forceOpen')) {\n      this._updateState();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._initialized = true;\n  }\n\n  private _updateState(): void {\n    if (!this._hasContent) {\n      return;\n    }\n\n    if (this.forceOpen || this._checked) {\n      this._open(!this._initialized);\n    } else {\n      this._close();\n    }\n    this._updateExpandedLabel(this.forceOpen || this._checked);\n  }\n\n  private _open(skipAnimation = false): void {\n    if (this._state !== 'closed' && this._state !== 'closing') {\n      return;\n    }\n\n    this._state = 'opening';\n    this._willOpen.emit();\n\n    if (skipAnimation) {\n      this._state = 'opened';\n      this._didOpen.emit();\n    }\n  }\n\n  private _close(): void {\n    if (this._state !== 'opened' && this._state !== 'opening') {\n      return;\n    }\n\n    this._state = 'closing';\n    this._willClose.emit();\n  }\n\n  private _initFromInput(event: Event): void {\n    const input = event.target as SbbCheckboxPanelElement | SbbRadioButtonPanelElement;\n\n    this._checked = input.checked;\n    this._disabled = input.disabled;\n    this._sizeAttributeObserver?.disconnect();\n    // The size of the inner panel can change due direct change on the panel or due to change of the input-group size.\n    this._sizeAttributeObserver?.observe(input, { attributeFilter: ['size'] });\n    this._updateState();\n  }\n\n  /**\n   * Set the data-size in two cases:\n   * - if there's no group, so the size change comes directly from a change on the inner panel;\n   * - if there's a wrapper group and its size changes, syncing it with the panel size.\n   *\n   * On the other hand, if there's a wrapper group and the size changes on the inner panel, the data-size doesn't change.\n   */\n  private _onSizeAttributesChange(mutationsList: MutationRecord[]): void {\n    for (const mutation of mutationsList) {\n      if (mutation.attributeName === 'size') {\n        const group = this._group;\n        const size = (mutation.target as HTMLElement).getAttribute('size')!;\n        if (!group || group.size === size) {\n          this.setAttribute('data-size', size);\n        }\n      }\n    }\n  }\n\n  private _onInputStateChange(event: CustomEvent<SbbStateChange>): void {\n    if (event.detail.type === 'disabled') {\n      this._disabled = event.detail.disabled;\n      return;\n    } else if (event.detail.type !== 'checked') {\n      return;\n    }\n\n    this._checked = event.detail.checked;\n    this._updateState();\n  }\n\n  private _onAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open-opacity' && this._state === 'opening') {\n      this._state = 'opened';\n      this._didOpen.emit();\n    } else if (event.animationName === 'close' && this._state === 'closing') {\n      this._state = 'closed';\n      this._didClose.emit();\n    }\n  }\n\n  private async _updateExpandedLabel(open: boolean): Promise<void> {\n    await this.hydrationComplete;\n\n    const panelElement = this.querySelector<SbbRadioButtonPanelElement | SbbCheckboxPanelElement>(\n      'sbb-radio-button-panel, sbb-checkbox-panel',\n    );\n    if (!panelElement) {\n      return;\n    }\n\n    if (!this._hasContent) {\n      panelElement.expansionState = '';\n      return;\n    }\n\n    panelElement.expansionState = open\n      ? ', ' + i18nExpanded[this._language.current]\n      : ', ' + i18nCollapsed[this._language.current];\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-selection-expansion-panel\">\n        <div class=\"sbb-selection-expansion-panel__input\" @stateChange=${this._onInputStateChange}>\n          <slot></slot>\n        </div>\n        <div\n          class=\"sbb-selection-expansion-panel__content--wrapper\"\n          .inert=${this._state !== 'opened'}\n          @animationend=${(event: AnimationEvent) => this._onAnimationEnd(event)}\n        >\n          <div class=\"sbb-selection-expansion-panel__content\">\n            <sbb-divider></sbb-divider>\n            <slot name=\"content\"></slot>\n          </div>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-selection-expansion-panel': SbbSelectionExpansionPanelElement;\n  }\n}\n"],"names":["state"],"mappings":"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"}
372
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"selection-expansion-panel.js","sources":["../../../src/elements/selection-expansion-panel/selection-expansion-panel.ts"],"sourcesContent":["import { type CSSResultGroup, isServer, type PropertyValues, type TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\n\nimport type { SbbCheckboxGroupElement, SbbCheckboxPanelElement } from '../checkbox.js';\nimport { SbbConnectedAbortController, SbbLanguageController } from '../core/controllers.js';\nimport { slotState } from '../core/decorators.js';\nimport { EventEmitter } from '../core/eventing.js';\nimport { i18nCollapsed, i18nExpanded } from '../core/i18n.js';\nimport type { SbbOpenedClosedState, SbbStateChange } from '../core/interfaces.js';\nimport { SbbHydrationMixin } from '../core/mixins.js';\nimport type { SbbRadioButtonGroupElement, SbbRadioButtonPanelElement } from '../radio-button.js';\n\nimport style from './selection-expansion-panel.scss?lit&inline';\n\nimport '../divider.js';\n\n/**\n * It displays an expandable panel connected to a `sbb-checkbox` or to a `sbb-radio-button`.\n *\n * @slot - Use the unnamed slot to add `sbb-checkbox` or `sbb-radio-button` elements to the `sbb-selection-expansion-panel`.\n * @slot content - Use this slot to provide custom content for the panel (optional).\n * @event {CustomEvent<void>} willOpen - Emits whenever the content section starts the opening transition.\n * @event {CustomEvent<void>} didOpen - Emits whenever the content section is opened.\n * @event {CustomEvent<void>} willClose - Emits whenever the content section begins the closing transition.\n * @event {CustomEvent<void>} didClose - Emits whenever the content section is closed.\n */\n@customElement('sbb-selection-expansion-panel')\n@slotState()\nexport class SbbSelectionExpansionPanelElement extends SbbHydrationMixin(LitElement) {\n  // FIXME inheriting from SbbOpenCloseBaseElement requires: https://github.com/open-wc/custom-elements-manifest/issues/253\n  public static override styles: CSSResultGroup = style;\n  public static readonly events: Record<string, string> = {\n    willOpen: 'willOpen',\n    didOpen: 'didOpen',\n    willClose: 'willClose',\n    didClose: 'didClose',\n  } as const;\n\n  /** The background color of the panel. */\n  @property() public color: 'white' | 'milk' = 'white';\n\n  /** Whether the content section is always visible. */\n  @property({ attribute: 'force-open', type: Boolean }) public forceOpen = false;\n\n  /** Whether the unselected panel has a border. */\n  @property({ reflect: true, type: Boolean }) public borderless = false;\n\n  /** The state of the selection panel. */\n  @state()\n  private set _state(state: SbbOpenedClosedState) {\n    this.setAttribute('data-state', state);\n  }\n  private get _state(): SbbOpenedClosedState {\n    return this.getAttribute('data-state') as SbbOpenedClosedState;\n  }\n\n  /** Whether the selection panel is checked. */\n  private set _checked(checked: boolean) {\n    this.toggleAttribute('data-checked', checked);\n  }\n  private get _checked(): boolean {\n    return this.hasAttribute('data-checked');\n  }\n\n  /** Whether the selection panel is disabled. */\n  private set _disabled(disabled: boolean) {\n    this.toggleAttribute('data-disabled', disabled);\n  }\n\n  /** Emits whenever the content section starts the opening transition. */\n  private _willOpen: EventEmitter<void> = new EventEmitter(\n    this,\n    SbbSelectionExpansionPanelElement.events.willOpen,\n  );\n\n  /** Emits whenever the content section is opened. */\n  private _didOpen: EventEmitter<void> = new EventEmitter(\n    this,\n    SbbSelectionExpansionPanelElement.events.didOpen,\n  );\n\n  /** Emits whenever the content section begins the closing transition. */\n  private _willClose: EventEmitter<void> = new EventEmitter(\n    this,\n    SbbSelectionExpansionPanelElement.events.willClose,\n  );\n\n  /** Emits whenever the content section is closed. */\n  private _didClose: EventEmitter<void> = new EventEmitter(\n    this,\n    SbbSelectionExpansionPanelElement.events.didClose,\n  );\n\n  private _language = new SbbLanguageController(this);\n  private _abort = new SbbConnectedAbortController(this);\n  private _initialized: boolean = false;\n  private _sizeAttributeObserver = !isServer\n    ? new MutationObserver((mutationsList: MutationRecord[]) =>\n        this._onSizeAttributesChange(mutationsList),\n      )\n    : null;\n\n  /** Whether it has an expandable content */\n  private get _hasContent(): boolean {\n    // We cannot use the NamedSlots because it's too slow to initialize\n    return this.querySelectorAll?.('[slot=\"content\"]').length > 0;\n  }\n\n  private get _group(): SbbRadioButtonGroupElement | SbbCheckboxGroupElement | null {\n    return this.closest('sbb-radio-button-group, sbb-checkbox-group') as\n      | SbbRadioButtonGroupElement\n      | SbbCheckboxGroupElement;\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n\n    this.addEventListener('panelConnected', this._initFromInput.bind(this), {\n      signal: this._abort.signal,\n    });\n\n    this._state ||= 'closed';\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._sizeAttributeObserver?.disconnect();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('forceOpen')) {\n      this._updateState();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._initialized = true;\n  }\n\n  private _updateState(): void {\n    if (!this._hasContent) {\n      return;\n    }\n\n    if (this.forceOpen || this._checked) {\n      this._open(!this._initialized);\n    } else {\n      this._close();\n    }\n    this._updateExpandedLabel(this.forceOpen || this._checked);\n  }\n\n  private _open(skipAnimation = false): void {\n    if (this._state !== 'closed' && this._state !== 'closing') {\n      return;\n    }\n\n    this._state = 'opening';\n    this._willOpen.emit();\n\n    if (skipAnimation) {\n      this._state = 'opened';\n      this._didOpen.emit();\n    }\n  }\n\n  private _close(): void {\n    if (this._state !== 'opened' && this._state !== 'opening') {\n      return;\n    }\n\n    this._state = 'closing';\n    this._willClose.emit();\n  }\n\n  private _initFromInput(event: Event): void {\n    const input = event.target as SbbCheckboxPanelElement | SbbRadioButtonPanelElement;\n\n    this._checked = input.checked;\n    this._disabled = input.disabled;\n    this._sizeAttributeObserver?.disconnect();\n    // The size of the inner panel can change due direct change on the panel or due to change of the input-group size.\n    this._sizeAttributeObserver?.observe(input, { attributeFilter: ['size'] });\n    this._updateState();\n  }\n\n  /**\n   * Set the data-size in two cases:\n   * - if there's no group, so the size change comes directly from a change on the inner panel;\n   * - if there's a wrapper group and its size changes, syncing it with the panel size.\n   *\n   * On the other hand, if there's a wrapper group and the size changes on the inner panel, the data-size doesn't change.\n   */\n  private _onSizeAttributesChange(mutationsList: MutationRecord[]): void {\n    for (const mutation of mutationsList) {\n      if (mutation.attributeName === 'size') {\n        const group = this._group;\n        const size = (mutation.target as HTMLElement).getAttribute('size')!;\n        if (!group || group.size === size) {\n          this.setAttribute('data-size', size);\n        }\n      }\n    }\n  }\n\n  private _onInputStateChange(event: CustomEvent<SbbStateChange>): void {\n    if (event.detail.type === 'disabled') {\n      this._disabled = event.detail.disabled;\n      return;\n    } else if (event.detail.type !== 'checked') {\n      return;\n    }\n\n    this._checked = event.detail.checked;\n    this._updateState();\n  }\n\n  private _onAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open-opacity' && this._state === 'opening') {\n      this._state = 'opened';\n      this._didOpen.emit();\n    } else if (event.animationName === 'close' && this._state === 'closing') {\n      this._state = 'closed';\n      this._didClose.emit();\n    }\n  }\n\n  private async _updateExpandedLabel(open: boolean): Promise<void> {\n    await this.hydrationComplete;\n\n    const panelElement = this.querySelector<SbbRadioButtonPanelElement | SbbCheckboxPanelElement>(\n      'sbb-radio-button-panel, sbb-checkbox-panel',\n    );\n    if (!panelElement) {\n      return;\n    }\n\n    if (!this._hasContent) {\n      panelElement.expansionState = '';\n      return;\n    }\n\n    panelElement.expansionState = open\n      ? ', ' + i18nExpanded[this._language.current]\n      : ', ' + i18nCollapsed[this._language.current];\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-selection-expansion-panel\">\n        <div class=\"sbb-selection-expansion-panel__input\" @stateChange=${this._onInputStateChange}>\n          <slot></slot>\n        </div>\n        <div\n          class=\"sbb-selection-expansion-panel__content--wrapper\"\n          ?inert=${this._state !== 'opened'}\n          @animationend=${(event: AnimationEvent) => this._onAnimationEnd(event)}\n        >\n          <div class=\"sbb-selection-expansion-panel__content\">\n            <sbb-divider></sbb-divider>\n            <slot name=\"content\"></slot>\n          </div>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-selection-expansion-panel': SbbSelectionExpansionPanelElement;\n  }\n}\n"],"names":["state"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA6BO,IAAM,oCAAN,cAAgD,kBAAkB,UAAU,EAAE;AAAA,EAA9E,cAAA;AAAA,UAAA,GAAA,SAAA;AAWO,SAAO,QAA0B;AAGS,SAAO,YAAY;AAG7B,SAAO,aAAa;AAyBhE,SAAQ,YAAgC,IAAI;AAAA,MAC1C;AAAA,MACA,kCAAkC,OAAO;AAAA,IAAA;AAI3C,SAAQ,WAA+B,IAAI;AAAA,MACzC;AAAA,MACA,kCAAkC,OAAO;AAAA,IAAA;AAI3C,SAAQ,aAAiC,IAAI;AAAA,MAC3C;AAAA,MACA,kCAAkC,OAAO;AAAA,IAAA;AAI3C,SAAQ,YAAgC,IAAI;AAAA,MAC1C;AAAA,MACA,kCAAkC,OAAO;AAAA,IAAA;AAGnC,SAAA,YAAY,IAAI,sBAAsB,IAAI;AAC1C,SAAA,SAAS,IAAI,4BAA4B,IAAI;AACrD,SAAQ,eAAwB;AACxB,SAAA,yBAAyB,CAAC,WAC9B,IAAI;AAAA,MAAiB,CAAC,kBACpB,KAAK,wBAAwB,aAAa;AAAA,IAE5C,IAAA;AAAA,EAAA;AAAA,EAnDJ,IAAY,OAAOA,QAA6B;AACzC,SAAA,aAAa,cAAcA,MAAK;AAAA,EACvC;AAAA,EACA,IAAY,SAA+B;AAClC,WAAA,KAAK,aAAa,YAAY;AAAA,EACvC;AAAA;AAAA,EAGA,IAAY,SAAS,SAAkB;AAChC,SAAA,gBAAgB,gBAAgB,OAAO;AAAA,EAC9C;AAAA,EACA,IAAY,WAAoB;AACvB,WAAA,KAAK,aAAa,cAAc;AAAA,EACzC;AAAA;AAAA,EAGA,IAAY,UAAU,UAAmB;AAClC,SAAA,gBAAgB,iBAAiB,QAAQ;AAAA,EAChD;AAAA;AAAA,EAoCA,IAAY,cAAuB;;AAEjC,aAAO,UAAK,qBAAL,8BAAwB,oBAAoB,UAAS;AAAA,EAC9D;AAAA,EAEA,IAAY,SAAsE;AACzE,WAAA,KAAK,QAAQ,4CAA4C;AAAA,EAGlE;AAAA,EAEgB,oBAA0B;AACxC,UAAM,kBAAkB;AAExB,SAAK,iBAAiB,kBAAkB,KAAK,eAAe,KAAK,IAAI,GAAG;AAAA,MACtE,QAAQ,KAAK,OAAO;AAAA,IAAA,CACrB;AAED,SAAK,WAAL,KAAK,SAAW;AAAA,EAClB;AAAA,EAEgB,uBAA6B;;AAC3C,UAAM,qBAAqB;AAC3B,eAAK,2BAAL,mBAA6B;AAAA,EAC/B;AAAA,EAEmB,WAAW,mBAA+C;AAC3E,UAAM,WAAW,iBAAiB;AAE9B,QAAA,kBAAkB,IAAI,WAAW,GAAG;AACtC,WAAK,aAAa;AAAA,IACpB;AAAA,EACF;AAAA,EAEmB,aAAa,mBAA+C;AAC7E,UAAM,aAAa,iBAAiB;AAEpC,SAAK,eAAe;AAAA,EACtB;AAAA,EAEQ,eAAqB;AACvB,QAAA,CAAC,KAAK,aAAa;AACrB;AAAA,IACF;AAEI,QAAA,KAAK,aAAa,KAAK,UAAU;AAC9B,WAAA,MAAM,CAAC,KAAK,YAAY;AAAA,IAAA,OACxB;AACL,WAAK,OAAO;AAAA,IACd;AACA,SAAK,qBAAqB,KAAK,aAAa,KAAK,QAAQ;AAAA,EAC3D;AAAA,EAEQ,MAAM,gBAAgB,OAAa;AACzC,QAAI,KAAK,WAAW,YAAY,KAAK,WAAW,WAAW;AACzD;AAAA,IACF;AAEA,SAAK,SAAS;AACd,SAAK,UAAU;AAEf,QAAI,eAAe;AACjB,WAAK,SAAS;AACd,WAAK,SAAS;IAChB;AAAA,EACF;AAAA,EAEQ,SAAe;AACrB,QAAI,KAAK,WAAW,YAAY,KAAK,WAAW,WAAW;AACzD;AAAA,IACF;AAEA,SAAK,SAAS;AACd,SAAK,WAAW;EAClB;AAAA,EAEQ,eAAe,OAAoB;;AACzC,UAAM,QAAQ,MAAM;AAEpB,SAAK,WAAW,MAAM;AACtB,SAAK,YAAY,MAAM;AACvB,eAAK,2BAAL,mBAA6B;AAExB,eAAA,2BAAA,mBAAwB,QAAQ,OAAO,EAAE,iBAAiB,CAAC,MAAM;AACtE,SAAK,aAAa;AAAA,EACpB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASQ,wBAAwB,eAAuC;AACrE,eAAW,YAAY,eAAe;AAChC,UAAA,SAAS,kBAAkB,QAAQ;AACrC,cAAM,QAAQ,KAAK;AACnB,cAAM,OAAQ,SAAS,OAAuB,aAAa,MAAM;AACjE,YAAI,CAAC,SAAS,MAAM,SAAS,MAAM;AAC5B,eAAA,aAAa,aAAa,IAAI;AAAA,QACrC;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAAA,EAEQ,oBAAoB,OAA0C;AAChE,QAAA,MAAM,OAAO,SAAS,YAAY;AAC/B,WAAA,YAAY,MAAM,OAAO;AAC9B;AAAA,IACS,WAAA,MAAM,OAAO,SAAS,WAAW;AAC1C;AAAA,IACF;AAEK,SAAA,WAAW,MAAM,OAAO;AAC7B,SAAK,aAAa;AAAA,EACpB;AAAA,EAEQ,gBAAgB,OAA6B;AACnD,QAAI,MAAM,kBAAkB,kBAAkB,KAAK,WAAW,WAAW;AACvE,WAAK,SAAS;AACd,WAAK,SAAS;IAAK,WACV,MAAM,kBAAkB,WAAW,KAAK,WAAW,WAAW;AACvE,WAAK,SAAS;AACd,WAAK,UAAU;IACjB;AAAA,EACF;AAAA,EAEA,MAAc,qBAAqB,MAA8B;AAC/D,UAAM,KAAK;AAEX,UAAM,eAAe,KAAK;AAAA,MACxB;AAAA,IAAA;AAEF,QAAI,CAAC,cAAc;AACjB;AAAA,IACF;AAEI,QAAA,CAAC,KAAK,aAAa;AACrB,mBAAa,iBAAiB;AAC9B;AAAA,IACF;AAEA,iBAAa,iBAAiB,OAC1B,OAAO,aAAa,KAAK,UAAU,OAAO,IAC1C,OAAO,cAAc,KAAK,UAAU,OAAO;AAAA,EACjD;AAAA,EAEmB,SAAyB;AACnC,WAAA;AAAA;AAAA,yEAE8D,KAAK,mBAAmB;AAAA;AAAA;AAAA;AAAA;AAAA,mBAK9E,KAAK,WAAW,QAAQ;AAAA,0BACjB,CAAC,UAA0B,KAAK,gBAAgB,KAAK,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAS9E;AACF;AAlPa,kCAEY,SAAyB;AAFrC,kCAGY,SAAiC;AAAA,EACtD,UAAU;AAAA,EACV,SAAS;AAAA,EACT,WAAW;AAAA,EACX,UAAU;AACZ;AAGmB,gBAAA;AAAA,EAAlB,SAAS;AAAA,GAXC,kCAWQ,WAAA,SAAA,CAAA;AAG0C,gBAAA;AAAA,EAA5D,SAAS,EAAE,WAAW,cAAc,MAAM,SAAS;AAAA,GAdzC,kCAckD,WAAA,aAAA,CAAA;AAGV,gBAAA;AAAA,EAAlD,SAAS,EAAE,SAAS,MAAM,MAAM,SAAS;AAAA,GAjB/B,kCAiBwC,WAAA,cAAA,CAAA;AAIvC,gBAAA;AAAA,EADX,MAAM;AAAA,GApBI,kCAqBC,WAAA,UAAA,CAAA;AArBD,oCAAN,gBAAA;AAAA,EAFN,cAAc,+BAA+B;AAAA,EAC7C,UAAU;AAAA,GACE,iCAAA;"}
@@ -177,7 +177,7 @@ let SbbToggleOptionElement = class extends SbbIconNameMixin(LitElement) {
177
177
  id="sbb-toggle-option-id"
178
178
  aria-hidden="true"
179
179
  tabindex="-1"
180
- .inert=${this.checked}
180
+ ?inert=${this.checked}
181
181
  ?disabled=${this.disabled}
182
182
  .checked=${this.checked || nothing}
183
183
  .value=${this.value || nothing}
@@ -212,4 +212,4 @@ SbbToggleOptionElement = __decorateClass([
212
212
  export {
213
213
  SbbToggleOptionElement
214
214
  };
215
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"toggle-option.js","sources":["../../../../src/elements/toggle/toggle-option/toggle-option.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { SbbConnectedAbortController } from '../../core/controllers.js';\nimport { hostAttributes, slotState } from '../../core/decorators.js';\nimport { setOrRemoveAttribute } from '../../core/dom.js';\nimport { SbbIconNameMixin } from '../../icon.js';\nimport type { SbbToggleElement } from '../toggle.js';\n\nimport style from './toggle-option.scss?lit&inline';\n\n/**\n * It displays a toggle option within a `sbb-toggle`.\n *\n * @slot - Use the unnamed slot to add content to the label of the toggle option.\n * @slot icon - Slot used to render the `sbb-icon`.\n */\n@customElement('sbb-toggle-option')\n@hostAttributes({\n  role: 'radio',\n})\n@slotState()\nexport class SbbToggleOptionElement extends SbbIconNameMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n\n  /** Whether the toggle-option is checked. */\n  @property({ reflect: true, type: Boolean })\n  public checked = false;\n\n  /** Whether the toggle option is disabled. */\n  @property({ reflect: true, type: Boolean })\n  public disabled: boolean = false;\n\n  /** Value of toggle-option. */\n  @property()\n  public set value(value: string) {\n    this._value = `${value}`;\n  }\n  public get value(): string {\n    return this._value;\n  }\n  private _value: string = '';\n\n  private _toggle?: SbbToggleElement;\n  private _abort = new SbbConnectedAbortController(this);\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this._abort.signal;\n\n    // We need to listen input event on host as with keyboard navigation\n    // the Input Event is triggered from sbb-toggle.\n    this.addEventListener('input', () => this._handleInput(), { signal });\n    this.addEventListener('click', () => this.shadowRoot!.querySelector('label')?.click(), {\n      signal,\n    });\n    // We can use closest here, as we expect the parent sbb-toggle to be in light DOM.\n    this._toggle = this.closest?.('sbb-toggle') ?? undefined;\n    this._verifyTabindex();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('checked')) {\n      this.setAttribute('aria-checked', `${this.checked}`);\n      this._verifyTabindex();\n      if (this.checked) {\n        this._uncheckOtherOptions();\n      }\n    }\n    if (changedProperties.has('disabled')) {\n      this._handleDisabledChange();\n    }\n  }\n\n  private _uncheckOtherOptions(): void {\n    this._toggle?.options.filter((o) => o !== this).forEach((o) => (o.checked = false));\n    this._toggle?.updatePillPosition(false);\n  }\n\n  private _handleDisabledChange(): void {\n    // Enforce disabled state from parent.\n    if (!this._toggle) {\n      // Ignore illegal state. Our expectation  is that a sbb-toggle-option\n      // always has a parent sbb-toggle.\n    } else if (this._toggle.disabled && !this.disabled) {\n      this.disabled = true;\n    } else if (!this._toggle.disabled && this.disabled) {\n      this.disabled = false;\n    }\n    setOrRemoveAttribute(this, 'aria-disabled', this.disabled ? `true` : null);\n    this._verifyTabindex();\n  }\n\n  private _handleInput(): void {\n    if (this.disabled) {\n      return;\n    }\n    this.checked = true;\n    this._uncheckOtherOptions();\n  }\n\n  private _verifyTabindex(): void {\n    this.tabIndex = this.checked && !this.disabled ? 0 : -1;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <input\n        type=\"radio\"\n        id=\"sbb-toggle-option-id\"\n        aria-hidden=\"true\"\n        tabindex=\"-1\"\n        .inert=${this.checked}\n        ?disabled=${this.disabled}\n        .checked=${this.checked || nothing}\n        .value=${this.value || nothing}\n        @click=${(event: PointerEvent) => event.stopPropagation()}\n      />\n      <label class=\"sbb-toggle-option\" for=\"sbb-toggle-option-id\">\n        ${this.renderIconSlot()}\n        <span class=\"sbb-toggle-option__label\">\n          <slot></slot>\n        </span>\n      </label>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-toggle-option': SbbToggleOptionElement;\n  }\n}\n"],"names":["_a"],"mappings":"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"}
215
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"toggle-option.js","sources":["../../../../src/elements/toggle/toggle-option/toggle-option.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { SbbConnectedAbortController } from '../../core/controllers.js';\nimport { hostAttributes, slotState } from '../../core/decorators.js';\nimport { setOrRemoveAttribute } from '../../core/dom.js';\nimport { SbbIconNameMixin } from '../../icon.js';\nimport type { SbbToggleElement } from '../toggle.js';\n\nimport style from './toggle-option.scss?lit&inline';\n\n/**\n * It displays a toggle option within a `sbb-toggle`.\n *\n * @slot - Use the unnamed slot to add content to the label of the toggle option.\n * @slot icon - Slot used to render the `sbb-icon`.\n */\n@customElement('sbb-toggle-option')\n@hostAttributes({\n  role: 'radio',\n})\n@slotState()\nexport class SbbToggleOptionElement extends SbbIconNameMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n\n  /** Whether the toggle-option is checked. */\n  @property({ reflect: true, type: Boolean })\n  public checked = false;\n\n  /** Whether the toggle option is disabled. */\n  @property({ reflect: true, type: Boolean })\n  public disabled: boolean = false;\n\n  /** Value of toggle-option. */\n  @property()\n  public set value(value: string) {\n    this._value = `${value}`;\n  }\n  public get value(): string {\n    return this._value;\n  }\n  private _value: string = '';\n\n  private _toggle?: SbbToggleElement;\n  private _abort = new SbbConnectedAbortController(this);\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this._abort.signal;\n\n    // We need to listen input event on host as with keyboard navigation\n    // the Input Event is triggered from sbb-toggle.\n    this.addEventListener('input', () => this._handleInput(), { signal });\n    this.addEventListener('click', () => this.shadowRoot!.querySelector('label')?.click(), {\n      signal,\n    });\n    // We can use closest here, as we expect the parent sbb-toggle to be in light DOM.\n    this._toggle = this.closest?.('sbb-toggle') ?? undefined;\n    this._verifyTabindex();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('checked')) {\n      this.setAttribute('aria-checked', `${this.checked}`);\n      this._verifyTabindex();\n      if (this.checked) {\n        this._uncheckOtherOptions();\n      }\n    }\n    if (changedProperties.has('disabled')) {\n      this._handleDisabledChange();\n    }\n  }\n\n  private _uncheckOtherOptions(): void {\n    this._toggle?.options.filter((o) => o !== this).forEach((o) => (o.checked = false));\n    this._toggle?.updatePillPosition(false);\n  }\n\n  private _handleDisabledChange(): void {\n    // Enforce disabled state from parent.\n    if (!this._toggle) {\n      // Ignore illegal state. Our expectation  is that a sbb-toggle-option\n      // always has a parent sbb-toggle.\n    } else if (this._toggle.disabled && !this.disabled) {\n      this.disabled = true;\n    } else if (!this._toggle.disabled && this.disabled) {\n      this.disabled = false;\n    }\n    setOrRemoveAttribute(this, 'aria-disabled', this.disabled ? `true` : null);\n    this._verifyTabindex();\n  }\n\n  private _handleInput(): void {\n    if (this.disabled) {\n      return;\n    }\n    this.checked = true;\n    this._uncheckOtherOptions();\n  }\n\n  private _verifyTabindex(): void {\n    this.tabIndex = this.checked && !this.disabled ? 0 : -1;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <input\n        type=\"radio\"\n        id=\"sbb-toggle-option-id\"\n        aria-hidden=\"true\"\n        tabindex=\"-1\"\n        ?inert=${this.checked}\n        ?disabled=${this.disabled}\n        .checked=${this.checked || nothing}\n        .value=${this.value || nothing}\n        @click=${(event: PointerEvent) => event.stopPropagation()}\n      />\n      <label class=\"sbb-toggle-option\" for=\"sbb-toggle-option-id\">\n        ${this.renderIconSlot()}\n        <span class=\"sbb-toggle-option__label\">\n          <slot></slot>\n        </span>\n      </label>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-toggle-option': SbbToggleOptionElement;\n  }\n}\n"],"names":["_a"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuBO,IAAM,yBAAN,cAAqC,iBAAiB,UAAU,EAAE;AAAA,EAAlE,cAAA;AAAA,UAAA,GAAA,SAAA;AAKL,SAAO,UAAU;AAIjB,SAAO,WAAoB;AAU3B,SAAQ,SAAiB;AAGjB,SAAA,SAAS,IAAI,4BAA4B,IAAI;AAAA,EAAA;AAAA,EATrD,IAAW,MAAM,OAAe;AACzB,SAAA,SAAS,GAAG,KAAK;AAAA,EACxB;AAAA,EACA,IAAW,QAAgB;AACzB,WAAO,KAAK;AAAA,EACd;AAAA,EAMgB,oBAA0B;;AACxC,UAAM,kBAAkB;AAClB,UAAA,SAAS,KAAK,OAAO;AAItB,SAAA,iBAAiB,SAAS,MAAM,KAAK,gBAAgB,EAAE,QAAQ;AAC/D,SAAA,iBAAiB,SAAS;;AAAM,cAAAA,MAAA,KAAK,WAAY,cAAc,OAAO,MAAtC,gBAAAA,IAAyC;AAAA,OAAS;AAAA,MACrF;AAAA,IAAA,CACD;AAED,SAAK,YAAU,UAAK,YAAL,8BAAe,kBAAiB;AAC/C,SAAK,gBAAgB;AAAA,EACvB;AAAA,EAEmB,WAAW,mBAA+C;AAC3E,UAAM,WAAW,iBAAiB;AAE9B,QAAA,kBAAkB,IAAI,SAAS,GAAG;AACpC,WAAK,aAAa,gBAAgB,GAAG,KAAK,OAAO,EAAE;AACnD,WAAK,gBAAgB;AACrB,UAAI,KAAK,SAAS;AAChB,aAAK,qBAAqB;AAAA,MAC5B;AAAA,IACF;AACI,QAAA,kBAAkB,IAAI,UAAU,GAAG;AACrC,WAAK,sBAAsB;AAAA,IAC7B;AAAA,EACF;AAAA,EAEQ,uBAA6B;;AACnC,eAAK,YAAL,mBAAc,QAAQ,OAAO,CAAC,MAAM,MAAM,MAAM,QAAQ,CAAC,MAAO,EAAE,UAAU;AACvE,eAAA,YAAA,mBAAS,mBAAmB;AAAA,EACnC;AAAA,EAEQ,wBAA8B;AAEhC,QAAA,CAAC,KAAK,QAAS;AAAA,aAGR,KAAK,QAAQ,YAAY,CAAC,KAAK,UAAU;AAClD,WAAK,WAAW;AAAA,IAAA,WACP,CAAC,KAAK,QAAQ,YAAY,KAAK,UAAU;AAClD,WAAK,WAAW;AAAA,IAClB;AACA,yBAAqB,MAAM,iBAAiB,KAAK,WAAW,SAAS,IAAI;AACzE,SAAK,gBAAgB;AAAA,EACvB;AAAA,EAEQ,eAAqB;AAC3B,QAAI,KAAK,UAAU;AACjB;AAAA,IACF;AACA,SAAK,UAAU;AACf,SAAK,qBAAqB;AAAA,EAC5B;AAAA,EAEQ,kBAAwB;AAC9B,SAAK,WAAW,KAAK,WAAW,CAAC,KAAK,WAAW,IAAI;AAAA,EACvD;AAAA,EAEmB,SAAyB;AACnC,WAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,iBAMM,KAAK,OAAO;AAAA,oBACT,KAAK,QAAQ;AAAA,mBACd,KAAK,WAAW,OAAO;AAAA,iBACzB,KAAK,SAAS,OAAO;AAAA,iBACrB,CAAC,UAAwB,MAAM,iBAAiB;AAAA;AAAA;AAAA,UAGvD,KAAK,gBAAgB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAM7B;AACF;AA1Ga,uBACY,SAAyB;AAIzC,gBAAA;AAAA,EADN,SAAS,EAAE,SAAS,MAAM,MAAM,SAAS;AAAA,GAJ/B,uBAKJ,WAAA,WAAA,CAAA;AAIA,gBAAA;AAAA,EADN,SAAS,EAAE,SAAS,MAAM,MAAM,SAAS;AAAA,GAR/B,uBASJ,WAAA,YAAA,CAAA;AAII,gBAAA;AAAA,EADV,SAAS;AAAA,GAZC,uBAaA,WAAA,SAAA,CAAA;AAbA,yBAAN,gBAAA;AAAA,EALN,cAAc,mBAAmB;AAAA,EACjC,eAAe;AAAA,IACd,MAAM;AAAA,EAAA,CACP;AAAA,EACA,UAAU;AAAA,GACE,sBAAA;"}
package/map-container.js CHANGED
@@ -65,7 +65,7 @@ let o = class extends m {
65
65
  icon-name="location-pin-map-small"
66
66
  type="button"
67
67
  @click=${() => this._onScrollButtonClick()}
68
- .inert=${!this._scrollUpButtonVisible}
68
+ ?inert=${!this._scrollUpButtonVisible}
69
69
  >
70
70
  ${g[this._language.current]}
71
71
  </sbb-tertiary-button>`}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements",
3
- "version": "1.11.0",
3
+ "version": "1.11.2",
4
4
  "description": "Lyne Design System",
5
5
  "keywords": [
6
6
  "design system",
@@ -11,8 +11,8 @@
11
11
  "type": "module",
12
12
  "customElements": "custom-elements.json",
13
13
  "dependencies": {
14
- "@lit-labs/observers": "^3.0.0OBSERVERS",
15
- "lit": "^3.0.0"
14
+ "@lit-labs/observers": "^2.0.3",
15
+ "lit": "^3.2.0"
16
16
  },
17
17
  "publishConfig": {
18
18
  "access": "public"
@@ -130,7 +130,7 @@ let n = class extends y(c) {
130
130
  </div>
131
131
  <div
132
132
  class="sbb-selection-expansion-panel__content--wrapper"
133
- .inert=${this._state !== "opened"}
133
+ ?inert=${this._state !== "opened"}
134
134
  @animationend=${(e) => this._onAnimationEnd(e)}
135
135
  >
136
136
  <div class="sbb-selection-expansion-panel__content">
@@ -54,7 +54,7 @@ let s = class extends _(c) {
54
54
  id="sbb-toggle-option-id"
55
55
  aria-hidden="true"
56
56
  tabindex="-1"
57
- .inert=${this.checked}
57
+ ?inert=${this.checked}
58
58
  ?disabled=${this.disabled}
59
59
  .checked=${this.checked || d}
60
60
  .value=${this.value || d}