@sbb-esta/lyne-elements-dev 4.9.0-dev.1774933669 → 4.9.0-dev.1775022513

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.
@@ -46,7 +46,10 @@ export declare class SbbFormFieldElement extends SbbFormFieldElement_base {
46
46
  * `reserve` does reserve one row for an error message.
47
47
  */
48
48
  accessor errorSpace: 'none' | 'reserve';
49
- /** Indicates whether the input is optional. */
49
+ /**
50
+ * Indicates whether the input is optional.
51
+ * @deprecated Set the (optional) label text manually. Will be removed with next major version.
52
+ */
50
53
  accessor optional: boolean;
51
54
  /**
52
55
  * Size variant, either l, m or s.
@@ -1 +1 @@
1
- {"version":3,"file":"form-field.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/form-field/form-field/form-field.component.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"form-field.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/form-field/form-field/form-field.component.ts"],"names":[],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import { n as SbbFormFieldElement, t as SbbFormFieldControlEvent } from "../../form-field.component-BNIh6zGF.js";
1
+ import { n as SbbFormFieldElement, t as SbbFormFieldControlEvent } from "../../form-field.component-BTv2B0dZ.js";
2
2
  export { SbbFormFieldControlEvent, SbbFormFieldElement };
@@ -1,4 +1,4 @@
1
- import { n as SbbFormFieldElement, t as SbbFormFieldControlEvent } from "../form-field.component-BNIh6zGF.js";
1
+ import { n as SbbFormFieldElement, t as SbbFormFieldControlEvent } from "../form-field.component-BTv2B0dZ.js";
2
2
  //#region src/elements/form-field/form-field.ts
3
3
  /** @entrypoint */
4
4
  SbbFormFieldElement.define();
@@ -629,7 +629,10 @@ var SbbFormFieldElement = (() => {
629
629
  this.#errorSpace_accessor_storage = value;
630
630
  }
631
631
  #optional_accessor_storage;
632
- /** Indicates whether the input is optional. */
632
+ /**
633
+ * Indicates whether the input is optional.
634
+ * @deprecated Set the (optional) label text manually. Will be removed with next major version.
635
+ */
633
636
  get optional() {
634
637
  return this.#optional_accessor_storage;
635
638
  }
@@ -1006,4 +1009,4 @@ var SbbFormFieldElement = (() => {
1006
1009
  //#endregion
1007
1010
  export { SbbFormFieldElement as n, SbbFormFieldControlEvent as t };
1008
1011
 
1009
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"form-field.component-BNIh6zGF.js","names":[],"sources":["../../../src/elements/form-field/form-field/form-field.scss?lit&inline","../../../src/elements/form-field/form-field/form-field.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-form-field-error-divider-width: var(--sbb-spacing-fixed-1x);\n  --sbb-form-field-error-padding-block-start: var(--sbb-form-field-error-divider-width);\n  --sbb-form-field-select-inline-padding-end: calc(\n    var(--sbb-icon-svg-width) + var(--sbb-form-field-gap)\n  );\n  --sbb-form-field-label-size: calc(\n    var(--sbb-form-field-label-text-size) * var(--sbb-typo-line-height-text)\n  );\n  --sbb-form-field-text-line-height: calc(\n    var(--sbb-form-field-input-text-size) * var(--sbb-typo-line-height-text)\n  );\n  --sbb-form-field-margin-block-start: calc(\n    (\n        var(--sbb-form-field-min-height) - var(--sbb-form-field-label-size) - var(\n            --sbb-form-field-text-line-height\n          ) +\n          var(--_sbb-form-field-label-to-input-overlapping)\n      ) /\n      2\n  );\n\n  // Lock sbb-icon size\n  --sbb-icon-svg-width: var(--sbb-form-field-icon-size);\n  --sbb-icon-svg-height: var(--sbb-form-field-icon-size);\n\n  // As the form field has always a white background, we have to fix the focus outline color\n  // to default color for cases where the form field is used in a negative context.\n  --sbb-focus-outline-color: light-dark(\n    var(--sbb-focus-outline-color-default),\n    var(--sbb-focus-outline-color-dark)\n  );\n\n  display: inline-block;\n  color: var(--sbb-form-field-color);\n}\n\n:host(:where(:not([width='collapse']))) {\n  min-width: #{sbb.px-to-rem-build(150)};\n  width: min(#{sbb.px-to-rem-build(300)}, 100%);\n}\n\n:host([negative]) {\n  color: var(--sbb-color-3-negative);\n\n  --sbb-form-field-background-color: var(--sbb-background-color-1-negative);\n  --sbb-form-field-border-color: var(--sbb-border-color-5);\n  --sbb-form-field-label-color: var(--sbb-color-5);\n  --sbb-form-field-prefix-color: var(--sbb-color-5);\n  --sbb-form-field-text-color: var(--sbb-color-3-negative);\n  --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);\n  --sbb-form-field-arrow-color: var(--sbb-color-3-negative);\n\n  @include sbb.if-forced-colors {\n    --sbb-form-field-border-color: ButtonBorder;\n  }\n}\n\n:host([size='s']) {\n  --sbb-form-field-min-height: var(--sbb-size-element-xs);\n  --sbb-form-field-padding-inline: var(--sbb-spacing-fixed-2x);\n  --sbb-form-field-input-text-size: var(--sbb-text-font-size-s);\n  --sbb-form-field-label-text-size: var(--sbb-text-font-size-xxs);\n\n  // Values found by try and error\n  --_sbb-form-field-label-to-input-overlapping: #{sbb.px-to-rem-build(10)};\n  --_sbb-form-field-floating-label-transform: #{sbb.px-to-rem-build(5.5)};\n  --_sbb-form-field-spacer-margin-block-end: #{sbb.px-to-rem-build(-8.5)};\n\n  @include sbb.mq($from: large) {\n    // Values found by try and error\n    --_sbb-form-field-label-to-input-overlapping: #{sbb.px-to-rem-build(11)};\n    --_sbb-form-field-floating-label-transform: #{sbb.px-to-rem-build(5)};\n    --_sbb-form-field-spacer-margin-block-end: #{sbb.px-to-rem-build(-8)};\n  }\n}\n\n:host([size='m']) {\n  --sbb-form-field-min-height: var(--sbb-size-element-m);\n  --sbb-form-field-padding-inline: var(--sbb-spacing-fixed-3x);\n  --sbb-form-field-input-text-size: var(--sbb-text-font-size-m);\n  --sbb-form-field-label-text-size: var(--sbb-text-font-size-xs);\n  --_sbb-form-field-label-to-input-overlapping: var(--sbb-spacing-fixed-1x);\n  --_sbb-form-field-floating-label-transform: #{sbb.px-to-rem-build(8.5)};\n  --_sbb-form-field-spacer-margin-block-end: calc(\n    -1 * var(--_sbb-form-field-label-to-input-overlapping)\n  );\n\n  @include sbb.mq($from: large) {\n    --_sbb-form-field-floating-label-transform: #{sbb.px-to-rem-build(10.5)};\n  }\n}\n\n:host([size='l']) {\n  --sbb-form-field-min-height: var(--sbb-size-element-l);\n  --sbb-form-field-padding-inline: var(--sbb-spacing-responsive-xxxs);\n}\n\n:host([error-space='reserve']) {\n  --sbb-form-field-error-min-height: calc(\n    var(--sbb-typo-line-height-text) * var(--sbb-text-font-size-xs)\n  );\n  --sbb-form-field-error-padding-block-start-override: var(--sbb-form-field-error-divider-width);\n}\n\n:host(:where(:state(readonly), :state(disabled))) {\n  --sbb-form-field-background-color: var(--sbb-background-color-3);\n  --sbb-form-field-border-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-smoke));\n  --sbb-form-field-arrow-color: light-dark(var(--sbb-color-granite), var(--sbb-color-storm));\n\n  @include sbb.if-forced-colors {\n    --sbb-form-field-border-color: ButtonBorder;\n  }\n}\n\n:host(:where(:state(readonly), :state(disabled))[negative]) {\n  --sbb-form-field-background-color: var(--sbb-background-color-3-negative);\n  --sbb-form-field-border-color: var(--sbb-border-color-5);\n  --sbb-form-field-arrow-color: var(--sbb-border-color-5);\n}\n\n:host(:where(:state(disabled))) {\n  --sbb-form-field-label-color: light-dark(var(--sbb-color-granite), var(--sbb-color-smoke));\n  --sbb-form-field-prefix-color: light-dark(var(--sbb-color-granite), var(--sbb-color-storm));\n  --sbb-form-field-border-style: dashed;\n\n  @include sbb.if-forced-colors {\n    --sbb-form-field-label-color: GrayText !important;\n    --sbb-form-field-prefix-color: GrayText !important;\n    --sbb-form-field-text-color: GrayText !important;\n    --sbb-form-field-border-color: GrayText !important;\n  }\n}\n\n// :where is to align specificity\n:host(:where(:state(disabled))[negative]) {\n  --sbb-form-field-text-color: var(--sbb-color-5);\n  --sbb-form-field-label-color: var(--sbb-color-5);\n  --sbb-form-field-prefix-color: var(--sbb-color-5);\n}\n\n// :where is to align specificity\n:host(:where(:state(readonly)):not([negative])) {\n  --sbb-form-field-label-color: light-dark(var(--sbb-color-granite), var(--sbb-color-smoke));\n  --sbb-form-field-prefix-color: light-dark(var(--sbb-color-granite), var(--sbb-color-storm));\n}\n\n// :where is to align specificity\n:host(:where(:state(focus))) {\n  --sbb-form-field-border-color: var(--sbb-border-color-3);\n  --sbb-form-field-prefix-color: var(--sbb-color-3);\n  --sbb-form-field-border-width: var(--sbb-border-width-2x);\n}\n\n// :where is to align specificity\n:host(:where(:state(focus))[negative]) {\n  --sbb-form-field-border-color: var(--sbb-border-color-3-negative);\n  --sbb-form-field-prefix-color: var(--sbb-color-3-negative);\n}\n\n// We must not use :where here, as it needs the added specificity to properly work\n:host(:state(focus)) {\n  @include sbb.if-forced-colors {\n    --sbb-form-field-border-color: Highlight;\n    --sbb-form-field-prefix-color: Highlight;\n  }\n}\n\n// :where is to align specificity\n:host(:not(:where(:state(has-error)))) {\n  --sbb-form-field-error-padding-block-start: 0;\n}\n\n:host([floating-label]) {\n  --sbb-select-placeholder-color: transparent;\n\n  @include sbb.if-forced-colors {\n    --sbb-select-placeholder-color: Canvas;\n  }\n}\n\n:host(:is(:not(:state(slotted-label)), [hidden-label])) {\n  --sbb-form-field-label-size: 0rem;\n  --_sbb-form-field-label-to-input-overlapping: 0rem;\n}\n\n// Should be after other definitions to override overflow\n// :where is to align specificity\n:host(:where(:state(input-type-sbb-slider))) {\n  --sbb-form-field-overflow: visible;\n}\n\n.sbb-form-field__space-wrapper {\n  display: flex;\n  flex-direction: column;\n  height: 100%;\n\n  @include sbb.zero-width-space;\n}\n\n.sbb-form-field__wrapper {\n  display: flex;\n  flex: 1;\n  gap: var(--sbb-form-field-gap);\n  padding-inline: var(--sbb-form-field-padding-inline);\n  border-radius: var(--sbb-form-field-border-radius);\n  min-height: var(--sbb-form-field-min-height);\n  max-height: var(--sbb-form-field-max-height);\n  background-color: var(--sbb-form-field-background-color);\n  position: relative;\n\n  // Use ::before to avoid content shifting when border width changes.\n  &::before {\n    content: '';\n    display: block;\n    position: absolute;\n    inset: 0;\n    border: var(--sbb-form-field-border-width) var(--sbb-form-field-border-style)\n      var(--sbb-form-field-border-color);\n    border-radius: var(--sbb-form-field-border-radius);\n    pointer-events: none;\n  }\n\n  // :where is to align specificity\n  :host(:where(:state(focus):state(focus-origin-keyboard))) & {\n    @include sbb.focus-outline;\n\n    outline-offset: var(--sbb-form-field-outline-offset, var(--sbb-focus-outline-offset));\n  }\n\n  // In high contrast, there is no borderless variant\n  @media (forced-colors: none) {\n    :host(:is([borderless], :state(input-type-sbb-slider))) & {\n      &::before {\n        border-color: transparent;\n      }\n    }\n\n    :host(:where(:state(focus), :state(disabled))[borderless]) & {\n      &::after {\n        content: '';\n        position: absolute;\n        border-block-end: var(--sbb-border-width-1x) var(--sbb-form-field-border-style)\n          var(--sbb-form-field-border-color);\n        inset-inline: var(--sbb-form-field-padding-inline);\n        inset-block-end: 0;\n        z-index: var(--sbb-form-field-focus-underline-z-index, initial);\n      }\n    }\n  }\n}\n\n::slotted(*[slot='prefix']) {\n  color: var(--sbb-form-field-prefix-color);\n}\n\n// Ensure slotted inline elements are vertically centered\n::slotted(*[slot='prefix']),\n::slotted(*[slot='suffix']) {\n  display: flex;\n  min-width: var(--sbb-icon-svg-width);\n  margin-block-start: calc((var(--sbb-form-field-min-height) - var(--sbb-size-icon-ui-small)) / 2);\n}\n\n::slotted(sbb-form-field-clear) {\n  :host(:where(:state(empty), :state(disabled), :state(readonly))) & {\n    display: none;\n  }\n}\n\n// As the calendar should be shown below the form field border, we have to stretch the toggle's height.\n// TODO: Maybe move this to the datepicker-toggle component.\n::slotted(sbb-datepicker-toggle) {\n  padding-block-end: calc((var(--sbb-form-field-min-height) - var(--sbb-size-icon-ui-small)) / 2);\n}\n\n@include sbb.if-forced-colors {\n  // Align with prefix color\n  ::slotted(*[slot='suffix']) {\n    color: var(--sbb-form-field-prefix-color);\n  }\n}\n\n.sbb-form-field__select-input-icon {\n  @include sbb.absolute-center-y;\n\n  position: absolute;\n  inset-inline-end: 0;\n  margin-block-start: calc(-1 * var(--sbb-form-field-margin-block-start) / 2);\n  pointer-events: none;\n  color: var(--sbb-form-field-arrow-color);\n}\n\n.sbb-form-field__input-container {\n  display: flex;\n  flex-direction: column;\n  flex: 1 1 auto;\n  position: relative;\n  margin-block-start: var(--sbb-form-field-margin-block-start);\n\n  // Prevents overflowing parent\n  min-width: 0;\n}\n\n.sbb-form-field__label-spacer {\n  display: flex;\n  height: calc(var(--sbb-form-field-label-text-size) * var(--sbb-typo-line-height-text));\n\n  // Moves label down and input up to meet positioning requirements\n  margin-block-end: var(--_sbb-form-field-spacer-margin-block-end);\n}\n\n// To avoid doubled payload, we group the rules.\n:is(.sbb-form-field__label, .sbb-form-field__label-spacer) {\n  :host(:not(:state(slotted-label))) & {\n    display: none;\n  }\n\n  :host([hidden-label]) & {\n    @include sbb.screen-reader-only;\n  }\n}\n\n.sbb-form-field__label {\n  display: flex;\n  max-width: 100%;\n  cursor: var(--sbb-cursor-default);\n  position: absolute;\n  inset-block-start: 0;\n  color: var(--sbb-form-field-label-color);\n  font-size: var(--sbb-form-field-label-text-size);\n  letter-spacing: var(--sbb-typo-letter-spacing-text);\n\n  :host(:where(:state(input-type-select), :state(input-type-sbb-select))) & {\n    padding-inline-end: var(--sbb-form-field-select-inline-padding-end);\n  }\n\n  :host([floating-label]) & {\n    transform-origin: 0 0;\n    pointer-events: none; // We shouldn't catch mouse events (let them through).\n    backface-visibility: hidden;\n    will-change: transform, font-size;\n\n    transition: {\n      duration: var(--sbb-disable-animation-duration, var(--sbb-animation-duration-2x));\n      timing-function: var(--sbb-animation-easing);\n      property: transform, font-size;\n    }\n  }\n\n  // If floating-label is activated and there is no focus in it (except for select) and no popup is open\n  // and input is empty then apply the label transition.\n  // If it is empty and readonly, always apply transition\n  // :where is to align specificity\n  :host(\n      [floating-label]:is(\n          :not(\n            :where(:state(focus)):not(:where(:state(input-type-sbb-select))),\n            :where(:state(has-popup-open))\n          ),\n          :where(:state(readonly))\n        ):where(:state(empty))\n    )\n    & {\n    font-size: var(--sbb-form-field-input-text-size);\n    transform: translateY(var(--_sbb-form-field-floating-label-transform));\n  }\n\n  // :where is to align specificity\n  :host(:where(:state(input-type-textarea))) & {\n    @include sbb.if-forced-colors {\n      // The background of the textarea is set to Canvas and therefore hides the label behind.\n      // By setting the z-index to 1, we move the label in front of the textarea.\n      z-index: 1;\n    }\n  }\n}\n\n.sbb-form-field__label-ellipsis {\n  @include sbb.ellipsis;\n}\n\n.sbb-form-field__input {\n  display: flex;\n  flex: 1;\n  align-items: start;\n\n  :host(\n      [size='s']:is(\n        :state(input-type-input),\n        :state(input-type-select),\n        :state(input-type-sbb-select),\n        :state(input-type-sbb-date-input),\n        :state(input-type-sbb-time-input)\n      )\n    )\n    & {\n    // In size s, the natural height of the text input is too small.\n    // To not reserve too much space, we decrease the height.\n    margin-block-end: #{sbb.px-to-rem-build(-2)};\n  }\n}\n\n.sbb-form-field__error {\n  display: flex;\n  min-height: var(--sbb-form-field-error-min-height);\n  flex-direction: column;\n  margin-block-start: var(\n    --sbb-form-field-error-padding-block-start-override,\n    var(--sbb-form-field-error-padding-block-start)\n  );\n}\n","import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { property, state } from 'lit/decorators.js';\n\nimport type { SbbAutocompleteBaseElement } from '../../autocomplete.ts';\nimport type { SbbChipGroupElement } from '../../chip.ts';\nimport { sbbInputModalityDetector } from '../../core/a11y.ts';\nimport { SbbElement } from '../../core/base-elements.ts';\nimport { SbbLanguageController } from '../../core/controllers.ts';\nimport { forceType } from '../../core/decorators.ts';\nimport { isLean } from '../../core/dom.ts';\nimport { i18nOptional } from '../../core/i18n.ts';\nimport {\n  appendAriaElements,\n  removeAriaElements,\n  type SbbFormAssociatedInputMixinType,\n  SbbNegativeMixin,\n} from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbSelectElement } from '../../select.ts';\n\nimport style from './form-field.scss?lit&inline';\n\nimport '../../icon.ts';\n\nlet nextId = 0;\n\nconst patchedInputs = new WeakMap<HTMLInputElement, PropertyDescriptor>();\nconst nativeInputElements = ['input', 'textarea', 'select'];\n\n/** An interface which allows a control to work inside a `SbbFormField`. */\nexport interface SbbFormFieldElementControl {\n  /** The id of the form field control. */\n  readonly id: string;\n  /** Whether the control is empty. */\n  readonly empty: boolean;\n  /** Whether the control is readonly. */\n  readonly readOnly?: boolean;\n  /** Whether the control is disabled. */\n  readonly disabled: boolean;\n\n  /**\n   * Handles a click on the control's container.\n   * If not implemented, focus() of the element is called.\n   */\n  onContainerClick?(event: MouseEvent): void;\n}\n\nexport class SbbFormFieldControlEvent extends Event {\n  private _control: SbbFormFieldElementControl | null;\n\n  public get control(): SbbFormFieldElementControl | null {\n    return this._control;\n  }\n\n  public constructor(control: SbbFormFieldElementControl | null) {\n    super('formfieldcontrol');\n    this._control = control;\n  }\n}\n\n/**\n * It wraps an input element adding label, errors, icon, etc.\n *\n * @slot - Use this slot to render an input/select or a supported non-native element.\n * @slot label - Use this slot to render a label.\n * @slot prefix - Use this slot to render an icon on the left side of the input.\n * @slot suffix - Use this slot to render an icon on the right side of the input.\n * @slot error - Use this slot to render an error.\n *\n * @cssprop [--sbb-form-field-outline-offset] - To override the focus outline offset,\n * @cssprop [--sbb-form-field-focus-underline-z-index] - To override the z-index of the focus underline effect,\n */\nexport class SbbFormFieldElement extends SbbNegativeMixin(SbbElement) {\n  public static override readonly elementName: string = 'sbb-form-field';\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n\n  // List of elements that should not focus input on click\n  private readonly _excludedFocusElements = ['button', 'sbb-popover', 'sbb-option', 'sbb-chip'];\n\n  private readonly _floatingLabelSupportedInputElements = [\n    'input',\n    'select',\n    'textarea',\n    'sbb-select',\n  ];\n\n  private readonly _floatingLabelSupportedInputTypes = [\n    'email',\n    'number',\n    'password',\n    'search',\n    'tel',\n    'text',\n    'url',\n  ];\n\n  /**\n   * Whether to reserve space for an error message.\n   * `none` does not reserve any space.\n   * `reserve` does reserve one row for an error message.\n   */\n  @property({ attribute: 'error-space', reflect: true })\n  public accessor errorSpace: 'none' | 'reserve' = 'none';\n\n  /** Indicates whether the input is optional. */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor optional: boolean = false;\n\n  /**\n   * Size variant, either l, m or s.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 'l' | 'm' | 's' = isLean() ? 's' : 'm';\n\n  /** Whether to display the form field without a border. */\n  @forceType()\n  @property({ reflect: true, type: Boolean })\n  public accessor borderless: boolean = false;\n\n  /** Defines the width of the component:\n   * - `default`: the component has defined width and min-width;\n   * - `collapse`: the component adapts itself to its inner input content. */\n  @property({ reflect: true }) public accessor width: 'default' | 'collapse' = 'default';\n\n  /** Whether to visually hide the label. If hidden, screen readers will still read it. */\n  @forceType()\n  @property({ attribute: 'hidden-label', reflect: true, type: Boolean })\n  public accessor hiddenLabel: boolean = false;\n\n  /** Whether the label should float. If activated, the placeholder of the input is hidden. */\n  @forceType()\n  @property({ attribute: 'floating-label', reflect: true, type: Boolean })\n  public accessor floatingLabel: boolean = false;\n\n  /** It is used internally to get the `error` slot. */\n  @state() private accessor _errorElements: Element[] = [];\n\n  /** Reference to the slotted input element. */\n  @state() private accessor _input: HTMLInputElement | HTMLSelectElement | HTMLElement | null =\n    null;\n\n  /** Reference to the slotted label elements. */\n  @state() private accessor _label!: HTMLLabelElement;\n\n  /** Returns the input element. */\n  public get inputElement(): HTMLInputElement | HTMLSelectElement | HTMLElement | null {\n    return this._input;\n  }\n\n  /** Reference to the slotted label. */\n  public get label(): HTMLLabelElement | null {\n    return this._label;\n  }\n\n  private _language = new SbbLanguageController(this);\n\n  /**\n   * Listens to the changes on `readonly` and `disabled` attributes of `<input>`.\n   */\n  private _formFieldAttributeObserver = !isServer\n    ? new MutationObserver((mutations: MutationRecord[]) => {\n        if (mutations.some((m) => m.type === 'attributes') && this._input) {\n          this._readInputState();\n          this._registerInputFormListener();\n          this._checkAndUpdateInputEmpty();\n        }\n      })\n    : null;\n\n  private _inputFormAbortController = new AbortController();\n  private _control: SbbFormFieldElementControl | null = null;\n\n  public constructor() {\n    super();\n    this.addEventListener?.(\n      'focusin',\n      (event) => {\n        if (\n          event.target === this.inputElement ||\n          event.target === (this.inputElement as SbbSelectElement | undefined)?.inputElement\n        ) {\n          this.internals.states.add('focus');\n          this.internals.states.add(`focus-origin-${sbbInputModalityDetector.mostRecentModality}`);\n        }\n      },\n      { passive: true },\n    );\n    this.addEventListener?.(\n      'focusout',\n      (event) => {\n        if (\n          event.target === this.inputElement ||\n          event.target === (this.inputElement as SbbSelectElement | undefined)?.inputElement\n        ) {\n          this._checkAndUpdateInputEmpty();\n          this.internals.states.delete('focus');\n          for (const state of this.internals.states) {\n            if (state.startsWith('focus-origin-')) {\n              this.internals.states.delete(state);\n            }\n          }\n        }\n      },\n      { passive: true },\n    );\n    this.addEventListener('input', () => this._checkAndUpdateInputEmpty());\n    this.addEventListener('displayvaluechange', () => this._checkAndUpdateInputEmpty());\n    // We want to prevent the native browser validation message popover\n    // to be shown. This also prevents a bug in WebKit, which would not\n    // allow host as the validity anchor: https://bugs.webkit.org/show_bug.cgi?id=269832\n    // This is duplicated from the form associated mixin for the native\n    // input controls (e.g. <input> or <select>).\n    this.addEventListener('invalid', (e) => e.preventDefault(), { capture: true });\n    this.addEventListener('formfieldcontrol', (e: SbbFormFieldControlEvent) => {\n      this._control = e.control;\n      if (this._connectInputElement() === 'unchanged') {\n        this._assignErrorMessageElements();\n        this._readInputState();\n        this._checkAndUpdateInputEmpty();\n      }\n    });\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this._assignSlots();\n    this._connectInputElement();\n    this._syncNegative();\n    this._syncSize();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('negative')) {\n      this._syncNegative();\n    }\n    if (changedProperties.has('size')) {\n      this._syncSize();\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._formFieldAttributeObserver?.disconnect();\n    this._inputFormAbortController.abort();\n    if (this._input?.localName === 'input') {\n      this._unpatchInputValue();\n    }\n  }\n\n  private _handleWrapperClick(event: MouseEvent): void {\n    if (this._isElementFocusExcluded(event)) {\n      return;\n    }\n\n    if (this._control?.onContainerClick) {\n      this._control?.onContainerClick(event);\n    } else if ((event.target as Element).localName !== 'label') {\n      if (\n        this._input?.localName === 'sbb-select' &&\n        (event.target as HTMLElement).localName !== 'sbb-select'\n      ) {\n        this._input.click();\n      }\n      this._input?.focus();\n    }\n  }\n\n  private _isElementFocusExcluded(event: Event): boolean {\n    return event\n      .composedPath()\n      .some(\n        (el) =>\n          (el instanceof window.HTMLElement &&\n            (el.getAttribute('tabindex') === '0' || el.hasAttribute('contenteditable'))) ||\n          this._excludedFocusElements.includes((el as HTMLElement).localName),\n      );\n  }\n\n  private _onSlotLabelChange(): void {\n    const labels = Array.from(this.querySelectorAll('label'));\n    if (import.meta.env.DEV && labels.length > 1) {\n      console.warn(\n        `Detected more than one label in sbb-form-field#${this.id}. Only one label is supported.`,\n      );\n    }\n    this._label = labels[0];\n    this._syncLabelInputReferences();\n  }\n\n  /**\n   * It is used internally to assign the attributes of `<input>` to `_id` and `_input` and to observe the native readonly and disabled attributes.\n   */\n  private _onSlotInputChange(): void {\n    this._assignSlots();\n    this._connectInputElement();\n  }\n\n  private _assignSlots(): void {\n    this.querySelectorAll('label:not([slot])').forEach((e) => e.setAttribute('slot', 'label'));\n    this.querySelectorAll('sbb-error:not([slot])').forEach((e) => e.setAttribute('slot', 'error'));\n  }\n\n  private _connectInputElement(): 'changed' | 'no-input' | 'unchanged' {\n    let newInput: HTMLElement | null;\n    if (this._control?.id) {\n      newInput = (this.getRootNode() as Document | ShadowRoot).getElementById(this._control.id);\n    } else {\n      // Find the slotted input element, even if it's nested (e.g. chip group)\n      const inputCandidates = Array.from(\n        this.querySelectorAll<HTMLElement>('*:not([slot],sbb-chip-group)'),\n      );\n      newInput =\n        (inputCandidates.find((e) => this._isInputElement(e)) || inputCandidates[0]) ?? null;\n    }\n\n    if (newInput === this._input) {\n      return 'unchanged';\n    } else if (this._input) {\n      this.internals.states.delete(`input-type-${this._input.localName}`);\n      if (this._input.localName === 'input') {\n        this._unpatchInputValue();\n      }\n    }\n\n    if (!newInput) {\n      this._input = null;\n      return 'no-input';\n    }\n\n    this._input = newInput;\n    this._registerInputFormListener();\n    this._assignErrorMessageElements();\n    this._readInputState();\n    this._checkAndUpdateInputEmpty();\n\n    if (this._input.localName === 'textarea') {\n      this._input.setAttribute('rows', this._input.getAttribute('rows') || '3');\n    } else if (this._input.localName === 'input') {\n      this._patchInputValue();\n    } else if (\n      (this._input.localName === 'select' || this._input.localName === 'sbb-select') &&\n      !this.hasUpdated\n    ) {\n      // Due to SSR the dropdown icon for selects cannot be rendered in the first render pass.\n      // Due to this we schedule a re-render to render the icon.\n      this.hydrationComplete.then(() => this.requestUpdate());\n    }\n\n    this._formFieldAttributeObserver?.disconnect();\n    this._formFieldAttributeObserver?.observe(this._input, {\n      attributes: true,\n      attributeFilter: ['readonly', 'disabled', 'form', 'class', 'data-expanded'],\n    });\n    this.internals.states.add(`input-type-${this._input.localName}`);\n    this._syncLabelInputReferences();\n    return 'changed';\n  }\n\n  private _syncLabelInputReferences(): void {\n    if (!this._input || !this._label) {\n      return;\n    }\n\n    if (\n      nativeInputElements.includes(this._input.localName) ||\n      (customElements.get(this._input.localName) as { formAssociated: boolean } | undefined)\n        ?.formAssociated\n    ) {\n      // For native input elements we use the `for` attribute on the label to reference the input\n      // via id reference.\n      this._input.id ||= `sbb-form-field-input-${nextId++}`;\n      this._label.htmlFor = this._input.id;\n    } else {\n      // For non-native input elements, that do not support references via the label for attribute,\n      // we use aria-labelledby on the input element to reference the label element via id.\n      // TODO: Migrate to ariaLabelledByElements when available:\n      // https://developer.mozilla.org/en-US/docs/Web/API/Element/ariaLabelledByElements\n      this._label.id ||= `sbb-form-field-label-${nextId++}`;\n      const labelledby =\n        this._input\n          .getAttribute('aria-labelledby')\n          ?.split(' ')\n          .filter((l) => !!l && l !== this._label!.id) ?? [];\n      this._input.setAttribute('aria-labelledby', [...labelledby, this._label.id].join(' '));\n    }\n  }\n\n  private _isInputElement(input: Element): boolean {\n    return (\n      nativeInputElements.includes(input.localName) ||\n      !!(customElements.get(input.localName) as { formAssociated: boolean } | undefined)\n        ?.formAssociated\n    );\n  }\n\n  private _readInputState(): void {\n    this.toggleState('readonly', this._control?.readOnly ?? this._input!.hasAttribute('readonly'));\n    this.toggleState('disabled', this._control?.disabled ?? this._input!.hasAttribute('disabled'));\n    this.toggleState('has-popup-open', this._input!.hasAttribute('data-expanded'));\n  }\n\n  private _registerInputFormListener(): void {\n    this._inputFormAbortController.abort();\n    const { signal } = (this._inputFormAbortController = new AbortController());\n\n    const form =\n      (this._input as HTMLInputElement | HTMLSelectElement | undefined)?.form ??\n      this._input?.closest('form');\n    // Timeout needed to have value updated\n    const resetHandler = (): unknown => setTimeout(() => this.reset());\n    form?.addEventListener('reset', resetHandler, { signal });\n  }\n\n  // We need to patch the value property of the HTMLInputElement in order\n  // to be able to reset the floating label in the empty state.\n  private _patchInputValue(): void {\n    const inputElement = this._input as HTMLInputElement;\n    if (!inputElement || patchedInputs.has(inputElement)) {\n      return;\n    }\n\n    const originalDescriptor = Object.getOwnPropertyDescriptor(\n      Object.getPrototypeOf(inputElement),\n      'value',\n    );\n\n    if (!originalDescriptor || !originalDescriptor.set || !originalDescriptor.get) {\n      return;\n    }\n\n    patchedInputs.set(inputElement, originalDescriptor);\n\n    const { get: getter, set: setter } = originalDescriptor;\n    const checkAndUpdateInputEmpty = (): void => this._checkAndUpdateInputEmpty();\n\n    Object.defineProperty(inputElement, 'value', {\n      ...originalDescriptor,\n      get() {\n        return getter.call(this);\n      },\n      set(newValue) {\n        setter.call(this, newValue);\n        checkAndUpdateInputEmpty();\n      },\n    });\n  }\n\n  private _unpatchInputValue(): void {\n    const inputElement = this._input as HTMLInputElement;\n    const originalDescriptor = patchedInputs.get(inputElement);\n    if (originalDescriptor) {\n      Object.defineProperty(inputElement, 'value', originalDescriptor);\n      patchedInputs.delete(inputElement);\n    }\n  }\n\n  private _checkAndUpdateInputEmpty(): void {\n    this.toggleState(\n      'empty',\n      this._control?.empty ??\n        (((this._floatingLabelSupportedInputElements.includes(this._input?.localName as string) ||\n          (this._input?.constructor as undefined | typeof SbbFormAssociatedInputMixinType)\n            ?.formFieldAssociated) ??\n          false) &&\n          this._isInputEmpty()),\n    );\n  }\n\n  private _isInputEmpty(): boolean {\n    const chipGroupElem: SbbChipGroupElement | null = this.querySelector('sbb-chip-group');\n    if (chipGroupElem) {\n      return (\n        this._isInputValueEmpty() &&\n        (Array.isArray(chipGroupElem.value)\n          ? chipGroupElem.value.length === 0\n          : !chipGroupElem.querySelector('sbb-chip'))\n      );\n    } else if (this._input instanceof HTMLInputElement) {\n      return (\n        this._floatingLabelSupportedInputTypes.includes(this._input.type) &&\n        this._isInputValueEmpty()\n      );\n    } else if (this._input instanceof HTMLSelectElement) {\n      return this._input.selectedOptions?.item(0)?.label?.trim() === '';\n    } else if (this._input?.localName === 'sbb-select') {\n      return (this._input as SbbSelectElement).getDisplayValue?.()?.trim() === '';\n    } else {\n      return this._isInputValueEmpty();\n    }\n  }\n\n  private _isInputValueEmpty(): boolean {\n    const value = (this._input as { value: string }).value;\n    return ['', undefined, null].includes(value) || (Array.isArray(value) && value.length === 0);\n  }\n\n  /**\n   * It is used internally to set the aria-describedby attribute for the slotted input referencing available <sbb-error> instances.\n   */\n  private _onSlotErrorChange(event: Event): void {\n    const errorElements = (event.target as HTMLSlotElement).assignedElements();\n    if (this._input && this._input.ariaDescribedByElements?.length) {\n      this._input.ariaDescribedByElements = removeAriaElements(\n        this._input.ariaDescribedByElements,\n        ...(this._errorElements ?? []),\n      );\n    }\n\n    this._errorElements = errorElements;\n    for (const el of this._errorElements) {\n      // Instead of defining a container with an aria-live region as expected, we had to change\n      // setting it for every slotted element to properly work in all browsers and screen reader combinations.\n      el.role ||= 'status';\n    }\n\n    this._assignErrorMessageElements();\n    this.toggleState('has-error', !!this._errorElements.length);\n    this._syncNegative();\n  }\n\n  private _assignErrorMessageElements(): void {\n    if (this._input) {\n      this._input.ariaDescribedByElements = appendAriaElements(\n        this._input.ariaDescribedByElements,\n        ...this._errorElements,\n      );\n    }\n  }\n\n  /** Manually reset the form field. Currently, this only resets the floating label. */\n  public reset(): void {\n    this._checkAndUpdateInputEmpty();\n  }\n\n  /** Manually clears the input value. It only works for inputs, selects are not supported. */\n  public clear(): void {\n    if ((this._input?.localName as string) !== 'input') {\n      return;\n    }\n    (this._input as { value: string }).value = '';\n    this._checkAndUpdateInputEmpty();\n  }\n\n  private _syncNegative(): void {\n    this.querySelectorAll?.(\n      'sbb-error,sbb-mini-button,sbb-mini-button-link,sbb-form-field-clear,sbb-datepicker-next-day,sbb-datepicker-previous-day,sbb-datepicker-toggle,sbb-select,sbb-autocomplete,sbb-autocomplete-grid,sbb-chip-group',\n    ).forEach((element) => element.toggleAttribute('negative', this.negative));\n  }\n\n  private _syncSize(): void {\n    this.querySelectorAll?.<SbbAutocompleteBaseElement | SbbSelectElement>(\n      'sbb-autocomplete,sbb-autocomplete-grid,sbb-select',\n    ).forEach((element) => (element.size = this.size === 's' ? 's' : 'm'));\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-form-field__space-wrapper\">\n        ${/* Queried by id from the autocomplete/select to be used as the anchor element */ ''}\n        <div @click=${this._handleWrapperClick} class=\"sbb-form-field__wrapper\" id=\"overlay-anchor\">\n          <slot name=\"prefix\" @slotchange=${this._syncNegative}></slot>\n          <div class=\"sbb-form-field__input-container\">\n            <span class=\"sbb-form-field__label-spacer\" aria-hidden=\"true\"></span>\n            <span class=\"sbb-form-field__label\">\n              <span class=\"sbb-form-field__label-ellipsis\">\n                <slot name=\"label\" @slotchange=${this._onSlotLabelChange}></slot>\n                ${this.optional\n                  ? html` <span aria-hidden=\"true\"> ${i18nOptional[this._language.current]} </span>`\n                  : nothing}\n              </span>\n            </span>\n            <div class=\"sbb-form-field__input\">\n              <slot @slotchange=${this._onSlotInputChange}></slot>\n            </div>\n            ${this.hasUpdated && ['select', 'sbb-select'].includes(this._input?.localName as string)\n              ? html`<sbb-icon\n                  name=\"chevron-small-down-small\"\n                  class=\"sbb-form-field__select-input-icon\"\n                ></sbb-icon>`\n              : nothing}\n          </div>\n          <slot name=\"suffix\" @slotchange=${this._syncNegative}></slot>\n        </div>\n\n        <div class=\"sbb-form-field__error\">\n          <slot name=\"error\" @slotchange=${this._onSlotErrorChange}></slot>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-form-field': SbbFormFieldElement;\n  }\n\n  interface HTMLElementEventMap {\n    formfieldcontrol: SbbFormFieldControlEvent;\n  }\n}\n"],"mappings":"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"}
1012
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"form-field.component-BTv2B0dZ.js","names":[],"sources":["../../../src/elements/form-field/form-field/form-field.scss?lit&inline","../../../src/elements/form-field/form-field/form-field.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-form-field-error-divider-width: var(--sbb-spacing-fixed-1x);\n  --sbb-form-field-error-padding-block-start: var(--sbb-form-field-error-divider-width);\n  --sbb-form-field-select-inline-padding-end: calc(\n    var(--sbb-icon-svg-width) + var(--sbb-form-field-gap)\n  );\n  --sbb-form-field-label-size: calc(\n    var(--sbb-form-field-label-text-size) * var(--sbb-typo-line-height-text)\n  );\n  --sbb-form-field-text-line-height: calc(\n    var(--sbb-form-field-input-text-size) * var(--sbb-typo-line-height-text)\n  );\n  --sbb-form-field-margin-block-start: calc(\n    (\n        var(--sbb-form-field-min-height) - var(--sbb-form-field-label-size) - var(\n            --sbb-form-field-text-line-height\n          ) +\n          var(--_sbb-form-field-label-to-input-overlapping)\n      ) /\n      2\n  );\n\n  // Lock sbb-icon size\n  --sbb-icon-svg-width: var(--sbb-form-field-icon-size);\n  --sbb-icon-svg-height: var(--sbb-form-field-icon-size);\n\n  // As the form field has always a white background, we have to fix the focus outline color\n  // to default color for cases where the form field is used in a negative context.\n  --sbb-focus-outline-color: light-dark(\n    var(--sbb-focus-outline-color-default),\n    var(--sbb-focus-outline-color-dark)\n  );\n\n  display: inline-block;\n  color: var(--sbb-form-field-color);\n}\n\n:host(:where(:not([width='collapse']))) {\n  min-width: #{sbb.px-to-rem-build(150)};\n  width: min(#{sbb.px-to-rem-build(300)}, 100%);\n}\n\n:host([negative]) {\n  color: var(--sbb-color-3-negative);\n\n  --sbb-form-field-background-color: var(--sbb-background-color-1-negative);\n  --sbb-form-field-border-color: var(--sbb-border-color-5);\n  --sbb-form-field-label-color: var(--sbb-color-5);\n  --sbb-form-field-prefix-color: var(--sbb-color-5);\n  --sbb-form-field-text-color: var(--sbb-color-3-negative);\n  --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);\n  --sbb-form-field-arrow-color: var(--sbb-color-3-negative);\n\n  @include sbb.if-forced-colors {\n    --sbb-form-field-border-color: ButtonBorder;\n  }\n}\n\n:host([size='s']) {\n  --sbb-form-field-min-height: var(--sbb-size-element-xs);\n  --sbb-form-field-padding-inline: var(--sbb-spacing-fixed-2x);\n  --sbb-form-field-input-text-size: var(--sbb-text-font-size-s);\n  --sbb-form-field-label-text-size: var(--sbb-text-font-size-xxs);\n\n  // Values found by try and error\n  --_sbb-form-field-label-to-input-overlapping: #{sbb.px-to-rem-build(10)};\n  --_sbb-form-field-floating-label-transform: #{sbb.px-to-rem-build(5.5)};\n  --_sbb-form-field-spacer-margin-block-end: #{sbb.px-to-rem-build(-8.5)};\n\n  @include sbb.mq($from: large) {\n    // Values found by try and error\n    --_sbb-form-field-label-to-input-overlapping: #{sbb.px-to-rem-build(11)};\n    --_sbb-form-field-floating-label-transform: #{sbb.px-to-rem-build(5)};\n    --_sbb-form-field-spacer-margin-block-end: #{sbb.px-to-rem-build(-8)};\n  }\n}\n\n:host([size='m']) {\n  --sbb-form-field-min-height: var(--sbb-size-element-m);\n  --sbb-form-field-padding-inline: var(--sbb-spacing-fixed-3x);\n  --sbb-form-field-input-text-size: var(--sbb-text-font-size-m);\n  --sbb-form-field-label-text-size: var(--sbb-text-font-size-xs);\n  --_sbb-form-field-label-to-input-overlapping: var(--sbb-spacing-fixed-1x);\n  --_sbb-form-field-floating-label-transform: #{sbb.px-to-rem-build(8.5)};\n  --_sbb-form-field-spacer-margin-block-end: calc(\n    -1 * var(--_sbb-form-field-label-to-input-overlapping)\n  );\n\n  @include sbb.mq($from: large) {\n    --_sbb-form-field-floating-label-transform: #{sbb.px-to-rem-build(10.5)};\n  }\n}\n\n:host([size='l']) {\n  --sbb-form-field-min-height: var(--sbb-size-element-l);\n  --sbb-form-field-padding-inline: var(--sbb-spacing-responsive-xxxs);\n}\n\n:host([error-space='reserve']) {\n  --sbb-form-field-error-min-height: calc(\n    var(--sbb-typo-line-height-text) * var(--sbb-text-font-size-xs)\n  );\n  --sbb-form-field-error-padding-block-start-override: var(--sbb-form-field-error-divider-width);\n}\n\n:host(:where(:state(readonly), :state(disabled))) {\n  --sbb-form-field-background-color: var(--sbb-background-color-3);\n  --sbb-form-field-border-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-smoke));\n  --sbb-form-field-arrow-color: light-dark(var(--sbb-color-granite), var(--sbb-color-storm));\n\n  @include sbb.if-forced-colors {\n    --sbb-form-field-border-color: ButtonBorder;\n  }\n}\n\n:host(:where(:state(readonly), :state(disabled))[negative]) {\n  --sbb-form-field-background-color: var(--sbb-background-color-3-negative);\n  --sbb-form-field-border-color: var(--sbb-border-color-5);\n  --sbb-form-field-arrow-color: var(--sbb-border-color-5);\n}\n\n:host(:where(:state(disabled))) {\n  --sbb-form-field-label-color: light-dark(var(--sbb-color-granite), var(--sbb-color-smoke));\n  --sbb-form-field-prefix-color: light-dark(var(--sbb-color-granite), var(--sbb-color-storm));\n  --sbb-form-field-border-style: dashed;\n\n  @include sbb.if-forced-colors {\n    --sbb-form-field-label-color: GrayText !important;\n    --sbb-form-field-prefix-color: GrayText !important;\n    --sbb-form-field-text-color: GrayText !important;\n    --sbb-form-field-border-color: GrayText !important;\n  }\n}\n\n// :where is to align specificity\n:host(:where(:state(disabled))[negative]) {\n  --sbb-form-field-text-color: var(--sbb-color-5);\n  --sbb-form-field-label-color: var(--sbb-color-5);\n  --sbb-form-field-prefix-color: var(--sbb-color-5);\n}\n\n// :where is to align specificity\n:host(:where(:state(readonly)):not([negative])) {\n  --sbb-form-field-label-color: light-dark(var(--sbb-color-granite), var(--sbb-color-smoke));\n  --sbb-form-field-prefix-color: light-dark(var(--sbb-color-granite), var(--sbb-color-storm));\n}\n\n// :where is to align specificity\n:host(:where(:state(focus))) {\n  --sbb-form-field-border-color: var(--sbb-border-color-3);\n  --sbb-form-field-prefix-color: var(--sbb-color-3);\n  --sbb-form-field-border-width: var(--sbb-border-width-2x);\n}\n\n// :where is to align specificity\n:host(:where(:state(focus))[negative]) {\n  --sbb-form-field-border-color: var(--sbb-border-color-3-negative);\n  --sbb-form-field-prefix-color: var(--sbb-color-3-negative);\n}\n\n// We must not use :where here, as it needs the added specificity to properly work\n:host(:state(focus)) {\n  @include sbb.if-forced-colors {\n    --sbb-form-field-border-color: Highlight;\n    --sbb-form-field-prefix-color: Highlight;\n  }\n}\n\n// :where is to align specificity\n:host(:not(:where(:state(has-error)))) {\n  --sbb-form-field-error-padding-block-start: 0;\n}\n\n:host([floating-label]) {\n  --sbb-select-placeholder-color: transparent;\n\n  @include sbb.if-forced-colors {\n    --sbb-select-placeholder-color: Canvas;\n  }\n}\n\n:host(:is(:not(:state(slotted-label)), [hidden-label])) {\n  --sbb-form-field-label-size: 0rem;\n  --_sbb-form-field-label-to-input-overlapping: 0rem;\n}\n\n// Should be after other definitions to override overflow\n// :where is to align specificity\n:host(:where(:state(input-type-sbb-slider))) {\n  --sbb-form-field-overflow: visible;\n}\n\n.sbb-form-field__space-wrapper {\n  display: flex;\n  flex-direction: column;\n  height: 100%;\n\n  @include sbb.zero-width-space;\n}\n\n.sbb-form-field__wrapper {\n  display: flex;\n  flex: 1;\n  gap: var(--sbb-form-field-gap);\n  padding-inline: var(--sbb-form-field-padding-inline);\n  border-radius: var(--sbb-form-field-border-radius);\n  min-height: var(--sbb-form-field-min-height);\n  max-height: var(--sbb-form-field-max-height);\n  background-color: var(--sbb-form-field-background-color);\n  position: relative;\n\n  // Use ::before to avoid content shifting when border width changes.\n  &::before {\n    content: '';\n    display: block;\n    position: absolute;\n    inset: 0;\n    border: var(--sbb-form-field-border-width) var(--sbb-form-field-border-style)\n      var(--sbb-form-field-border-color);\n    border-radius: var(--sbb-form-field-border-radius);\n    pointer-events: none;\n  }\n\n  // :where is to align specificity\n  :host(:where(:state(focus):state(focus-origin-keyboard))) & {\n    @include sbb.focus-outline;\n\n    outline-offset: var(--sbb-form-field-outline-offset, var(--sbb-focus-outline-offset));\n  }\n\n  // In high contrast, there is no borderless variant\n  @media (forced-colors: none) {\n    :host(:is([borderless], :state(input-type-sbb-slider))) & {\n      &::before {\n        border-color: transparent;\n      }\n    }\n\n    :host(:where(:state(focus), :state(disabled))[borderless]) & {\n      &::after {\n        content: '';\n        position: absolute;\n        border-block-end: var(--sbb-border-width-1x) var(--sbb-form-field-border-style)\n          var(--sbb-form-field-border-color);\n        inset-inline: var(--sbb-form-field-padding-inline);\n        inset-block-end: 0;\n        z-index: var(--sbb-form-field-focus-underline-z-index, initial);\n      }\n    }\n  }\n}\n\n::slotted(*[slot='prefix']) {\n  color: var(--sbb-form-field-prefix-color);\n}\n\n// Ensure slotted inline elements are vertically centered\n::slotted(*[slot='prefix']),\n::slotted(*[slot='suffix']) {\n  display: flex;\n  min-width: var(--sbb-icon-svg-width);\n  margin-block-start: calc((var(--sbb-form-field-min-height) - var(--sbb-size-icon-ui-small)) / 2);\n}\n\n::slotted(sbb-form-field-clear) {\n  :host(:where(:state(empty), :state(disabled), :state(readonly))) & {\n    display: none;\n  }\n}\n\n// As the calendar should be shown below the form field border, we have to stretch the toggle's height.\n// TODO: Maybe move this to the datepicker-toggle component.\n::slotted(sbb-datepicker-toggle) {\n  padding-block-end: calc((var(--sbb-form-field-min-height) - var(--sbb-size-icon-ui-small)) / 2);\n}\n\n@include sbb.if-forced-colors {\n  // Align with prefix color\n  ::slotted(*[slot='suffix']) {\n    color: var(--sbb-form-field-prefix-color);\n  }\n}\n\n.sbb-form-field__select-input-icon {\n  @include sbb.absolute-center-y;\n\n  position: absolute;\n  inset-inline-end: 0;\n  margin-block-start: calc(-1 * var(--sbb-form-field-margin-block-start) / 2);\n  pointer-events: none;\n  color: var(--sbb-form-field-arrow-color);\n}\n\n.sbb-form-field__input-container {\n  display: flex;\n  flex-direction: column;\n  flex: 1 1 auto;\n  position: relative;\n  margin-block-start: var(--sbb-form-field-margin-block-start);\n\n  // Prevents overflowing parent\n  min-width: 0;\n}\n\n.sbb-form-field__label-spacer {\n  display: flex;\n  height: calc(var(--sbb-form-field-label-text-size) * var(--sbb-typo-line-height-text));\n\n  // Moves label down and input up to meet positioning requirements\n  margin-block-end: var(--_sbb-form-field-spacer-margin-block-end);\n}\n\n// To avoid doubled payload, we group the rules.\n:is(.sbb-form-field__label, .sbb-form-field__label-spacer) {\n  :host(:not(:state(slotted-label))) & {\n    display: none;\n  }\n\n  :host([hidden-label]) & {\n    @include sbb.screen-reader-only;\n  }\n}\n\n.sbb-form-field__label {\n  display: flex;\n  max-width: 100%;\n  cursor: var(--sbb-cursor-default);\n  position: absolute;\n  inset-block-start: 0;\n  color: var(--sbb-form-field-label-color);\n  font-size: var(--sbb-form-field-label-text-size);\n  letter-spacing: var(--sbb-typo-letter-spacing-text);\n\n  :host(:where(:state(input-type-select), :state(input-type-sbb-select))) & {\n    padding-inline-end: var(--sbb-form-field-select-inline-padding-end);\n  }\n\n  :host([floating-label]) & {\n    transform-origin: 0 0;\n    pointer-events: none; // We shouldn't catch mouse events (let them through).\n    backface-visibility: hidden;\n    will-change: transform, font-size;\n\n    transition: {\n      duration: var(--sbb-disable-animation-duration, var(--sbb-animation-duration-2x));\n      timing-function: var(--sbb-animation-easing);\n      property: transform, font-size;\n    }\n  }\n\n  // If floating-label is activated and there is no focus in it (except for select) and no popup is open\n  // and input is empty then apply the label transition.\n  // If it is empty and readonly, always apply transition\n  // :where is to align specificity\n  :host(\n      [floating-label]:is(\n          :not(\n            :where(:state(focus)):not(:where(:state(input-type-sbb-select))),\n            :where(:state(has-popup-open))\n          ),\n          :where(:state(readonly))\n        ):where(:state(empty))\n    )\n    & {\n    font-size: var(--sbb-form-field-input-text-size);\n    transform: translateY(var(--_sbb-form-field-floating-label-transform));\n  }\n\n  // :where is to align specificity\n  :host(:where(:state(input-type-textarea))) & {\n    @include sbb.if-forced-colors {\n      // The background of the textarea is set to Canvas and therefore hides the label behind.\n      // By setting the z-index to 1, we move the label in front of the textarea.\n      z-index: 1;\n    }\n  }\n}\n\n.sbb-form-field__label-ellipsis {\n  @include sbb.ellipsis;\n}\n\n.sbb-form-field__input {\n  display: flex;\n  flex: 1;\n  align-items: start;\n\n  :host(\n      [size='s']:is(\n        :state(input-type-input),\n        :state(input-type-select),\n        :state(input-type-sbb-select),\n        :state(input-type-sbb-date-input),\n        :state(input-type-sbb-time-input)\n      )\n    )\n    & {\n    // In size s, the natural height of the text input is too small.\n    // To not reserve too much space, we decrease the height.\n    margin-block-end: #{sbb.px-to-rem-build(-2)};\n  }\n}\n\n.sbb-form-field__error {\n  display: flex;\n  min-height: var(--sbb-form-field-error-min-height);\n  flex-direction: column;\n  margin-block-start: var(\n    --sbb-form-field-error-padding-block-start-override,\n    var(--sbb-form-field-error-padding-block-start)\n  );\n}\n","import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { property, state } from 'lit/decorators.js';\n\nimport type { SbbAutocompleteBaseElement } from '../../autocomplete.ts';\nimport type { SbbChipGroupElement } from '../../chip.ts';\nimport { sbbInputModalityDetector } from '../../core/a11y.ts';\nimport { SbbElement } from '../../core/base-elements.ts';\nimport { SbbLanguageController } from '../../core/controllers.ts';\nimport { forceType } from '../../core/decorators.ts';\nimport { isLean } from '../../core/dom.ts';\nimport { i18nOptional } from '../../core/i18n.ts';\nimport {\n  appendAriaElements,\n  removeAriaElements,\n  type SbbFormAssociatedInputMixinType,\n  SbbNegativeMixin,\n} from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbSelectElement } from '../../select.ts';\n\nimport style from './form-field.scss?lit&inline';\n\nimport '../../icon.ts';\n\nlet nextId = 0;\n\nconst patchedInputs = new WeakMap<HTMLInputElement, PropertyDescriptor>();\nconst nativeInputElements = ['input', 'textarea', 'select'];\n\n/** An interface which allows a control to work inside a `SbbFormField`. */\nexport interface SbbFormFieldElementControl {\n  /** The id of the form field control. */\n  readonly id: string;\n  /** Whether the control is empty. */\n  readonly empty: boolean;\n  /** Whether the control is readonly. */\n  readonly readOnly?: boolean;\n  /** Whether the control is disabled. */\n  readonly disabled: boolean;\n\n  /**\n   * Handles a click on the control's container.\n   * If not implemented, focus() of the element is called.\n   */\n  onContainerClick?(event: MouseEvent): void;\n}\n\nexport class SbbFormFieldControlEvent extends Event {\n  private _control: SbbFormFieldElementControl | null;\n\n  public get control(): SbbFormFieldElementControl | null {\n    return this._control;\n  }\n\n  public constructor(control: SbbFormFieldElementControl | null) {\n    super('formfieldcontrol');\n    this._control = control;\n  }\n}\n\n/**\n * It wraps an input element adding label, errors, icon, etc.\n *\n * @slot - Use this slot to render an input/select or a supported non-native element.\n * @slot label - Use this slot to render a label.\n * @slot prefix - Use this slot to render an icon on the left side of the input.\n * @slot suffix - Use this slot to render an icon on the right side of the input.\n * @slot error - Use this slot to render an error.\n *\n * @cssprop [--sbb-form-field-outline-offset] - To override the focus outline offset,\n * @cssprop [--sbb-form-field-focus-underline-z-index] - To override the z-index of the focus underline effect,\n */\nexport class SbbFormFieldElement extends SbbNegativeMixin(SbbElement) {\n  public static override readonly elementName: string = 'sbb-form-field';\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n\n  // List of elements that should not focus input on click\n  private readonly _excludedFocusElements = ['button', 'sbb-popover', 'sbb-option', 'sbb-chip'];\n\n  private readonly _floatingLabelSupportedInputElements = [\n    'input',\n    'select',\n    'textarea',\n    'sbb-select',\n  ];\n\n  private readonly _floatingLabelSupportedInputTypes = [\n    'email',\n    'number',\n    'password',\n    'search',\n    'tel',\n    'text',\n    'url',\n  ];\n\n  /**\n   * Whether to reserve space for an error message.\n   * `none` does not reserve any space.\n   * `reserve` does reserve one row for an error message.\n   */\n  @property({ attribute: 'error-space', reflect: true })\n  public accessor errorSpace: 'none' | 'reserve' = 'none';\n\n  /**\n   * Indicates whether the input is optional.\n   * @deprecated Set the (optional) label text manually. Will be removed with next major version.\n   */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor optional: boolean = false;\n\n  /**\n   * Size variant, either l, m or s.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 'l' | 'm' | 's' = isLean() ? 's' : 'm';\n\n  /** Whether to display the form field without a border. */\n  @forceType()\n  @property({ reflect: true, type: Boolean })\n  public accessor borderless: boolean = false;\n\n  /** Defines the width of the component:\n   * - `default`: the component has defined width and min-width;\n   * - `collapse`: the component adapts itself to its inner input content. */\n  @property({ reflect: true }) public accessor width: 'default' | 'collapse' = 'default';\n\n  /** Whether to visually hide the label. If hidden, screen readers will still read it. */\n  @forceType()\n  @property({ attribute: 'hidden-label', reflect: true, type: Boolean })\n  public accessor hiddenLabel: boolean = false;\n\n  /** Whether the label should float. If activated, the placeholder of the input is hidden. */\n  @forceType()\n  @property({ attribute: 'floating-label', reflect: true, type: Boolean })\n  public accessor floatingLabel: boolean = false;\n\n  /** It is used internally to get the `error` slot. */\n  @state() private accessor _errorElements: Element[] = [];\n\n  /** Reference to the slotted input element. */\n  @state() private accessor _input: HTMLInputElement | HTMLSelectElement | HTMLElement | null =\n    null;\n\n  /** Reference to the slotted label elements. */\n  @state() private accessor _label!: HTMLLabelElement;\n\n  /** Returns the input element. */\n  public get inputElement(): HTMLInputElement | HTMLSelectElement | HTMLElement | null {\n    return this._input;\n  }\n\n  /** Reference to the slotted label. */\n  public get label(): HTMLLabelElement | null {\n    return this._label;\n  }\n\n  private _language = new SbbLanguageController(this);\n\n  /**\n   * Listens to the changes on `readonly` and `disabled` attributes of `<input>`.\n   */\n  private _formFieldAttributeObserver = !isServer\n    ? new MutationObserver((mutations: MutationRecord[]) => {\n        if (mutations.some((m) => m.type === 'attributes') && this._input) {\n          this._readInputState();\n          this._registerInputFormListener();\n          this._checkAndUpdateInputEmpty();\n        }\n      })\n    : null;\n\n  private _inputFormAbortController = new AbortController();\n  private _control: SbbFormFieldElementControl | null = null;\n\n  public constructor() {\n    super();\n    this.addEventListener?.(\n      'focusin',\n      (event) => {\n        if (\n          event.target === this.inputElement ||\n          event.target === (this.inputElement as SbbSelectElement | undefined)?.inputElement\n        ) {\n          this.internals.states.add('focus');\n          this.internals.states.add(`focus-origin-${sbbInputModalityDetector.mostRecentModality}`);\n        }\n      },\n      { passive: true },\n    );\n    this.addEventListener?.(\n      'focusout',\n      (event) => {\n        if (\n          event.target === this.inputElement ||\n          event.target === (this.inputElement as SbbSelectElement | undefined)?.inputElement\n        ) {\n          this._checkAndUpdateInputEmpty();\n          this.internals.states.delete('focus');\n          for (const state of this.internals.states) {\n            if (state.startsWith('focus-origin-')) {\n              this.internals.states.delete(state);\n            }\n          }\n        }\n      },\n      { passive: true },\n    );\n    this.addEventListener('input', () => this._checkAndUpdateInputEmpty());\n    this.addEventListener('displayvaluechange', () => this._checkAndUpdateInputEmpty());\n    // We want to prevent the native browser validation message popover\n    // to be shown. This also prevents a bug in WebKit, which would not\n    // allow host as the validity anchor: https://bugs.webkit.org/show_bug.cgi?id=269832\n    // This is duplicated from the form associated mixin for the native\n    // input controls (e.g. <input> or <select>).\n    this.addEventListener('invalid', (e) => e.preventDefault(), { capture: true });\n    this.addEventListener('formfieldcontrol', (e: SbbFormFieldControlEvent) => {\n      this._control = e.control;\n      if (this._connectInputElement() === 'unchanged') {\n        this._assignErrorMessageElements();\n        this._readInputState();\n        this._checkAndUpdateInputEmpty();\n      }\n    });\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this._assignSlots();\n    this._connectInputElement();\n    this._syncNegative();\n    this._syncSize();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('negative')) {\n      this._syncNegative();\n    }\n    if (changedProperties.has('size')) {\n      this._syncSize();\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._formFieldAttributeObserver?.disconnect();\n    this._inputFormAbortController.abort();\n    if (this._input?.localName === 'input') {\n      this._unpatchInputValue();\n    }\n  }\n\n  private _handleWrapperClick(event: MouseEvent): void {\n    if (this._isElementFocusExcluded(event)) {\n      return;\n    }\n\n    if (this._control?.onContainerClick) {\n      this._control?.onContainerClick(event);\n    } else if ((event.target as Element).localName !== 'label') {\n      if (\n        this._input?.localName === 'sbb-select' &&\n        (event.target as HTMLElement).localName !== 'sbb-select'\n      ) {\n        this._input.click();\n      }\n      this._input?.focus();\n    }\n  }\n\n  private _isElementFocusExcluded(event: Event): boolean {\n    return event\n      .composedPath()\n      .some(\n        (el) =>\n          (el instanceof window.HTMLElement &&\n            (el.getAttribute('tabindex') === '0' || el.hasAttribute('contenteditable'))) ||\n          this._excludedFocusElements.includes((el as HTMLElement).localName),\n      );\n  }\n\n  private _onSlotLabelChange(): void {\n    const labels = Array.from(this.querySelectorAll('label'));\n    if (import.meta.env.DEV && labels.length > 1) {\n      console.warn(\n        `Detected more than one label in sbb-form-field#${this.id}. Only one label is supported.`,\n      );\n    }\n    this._label = labels[0];\n    this._syncLabelInputReferences();\n  }\n\n  /**\n   * It is used internally to assign the attributes of `<input>` to `_id` and `_input` and to observe the native readonly and disabled attributes.\n   */\n  private _onSlotInputChange(): void {\n    this._assignSlots();\n    this._connectInputElement();\n  }\n\n  private _assignSlots(): void {\n    this.querySelectorAll('label:not([slot])').forEach((e) => e.setAttribute('slot', 'label'));\n    this.querySelectorAll('sbb-error:not([slot])').forEach((e) => e.setAttribute('slot', 'error'));\n  }\n\n  private _connectInputElement(): 'changed' | 'no-input' | 'unchanged' {\n    let newInput: HTMLElement | null;\n    if (this._control?.id) {\n      newInput = (this.getRootNode() as Document | ShadowRoot).getElementById(this._control.id);\n    } else {\n      // Find the slotted input element, even if it's nested (e.g. chip group)\n      const inputCandidates = Array.from(\n        this.querySelectorAll<HTMLElement>('*:not([slot],sbb-chip-group)'),\n      );\n      newInput =\n        (inputCandidates.find((e) => this._isInputElement(e)) || inputCandidates[0]) ?? null;\n    }\n\n    if (newInput === this._input) {\n      return 'unchanged';\n    } else if (this._input) {\n      this.internals.states.delete(`input-type-${this._input.localName}`);\n      if (this._input.localName === 'input') {\n        this._unpatchInputValue();\n      }\n    }\n\n    if (!newInput) {\n      this._input = null;\n      return 'no-input';\n    }\n\n    this._input = newInput;\n    this._registerInputFormListener();\n    this._assignErrorMessageElements();\n    this._readInputState();\n    this._checkAndUpdateInputEmpty();\n\n    if (this._input.localName === 'textarea') {\n      this._input.setAttribute('rows', this._input.getAttribute('rows') || '3');\n    } else if (this._input.localName === 'input') {\n      this._patchInputValue();\n    } else if (\n      (this._input.localName === 'select' || this._input.localName === 'sbb-select') &&\n      !this.hasUpdated\n    ) {\n      // Due to SSR the dropdown icon for selects cannot be rendered in the first render pass.\n      // Due to this we schedule a re-render to render the icon.\n      this.hydrationComplete.then(() => this.requestUpdate());\n    }\n\n    this._formFieldAttributeObserver?.disconnect();\n    this._formFieldAttributeObserver?.observe(this._input, {\n      attributes: true,\n      attributeFilter: ['readonly', 'disabled', 'form', 'class', 'data-expanded'],\n    });\n    this.internals.states.add(`input-type-${this._input.localName}`);\n    this._syncLabelInputReferences();\n    return 'changed';\n  }\n\n  private _syncLabelInputReferences(): void {\n    if (!this._input || !this._label) {\n      return;\n    }\n\n    if (\n      nativeInputElements.includes(this._input.localName) ||\n      (customElements.get(this._input.localName) as { formAssociated: boolean } | undefined)\n        ?.formAssociated\n    ) {\n      // For native input elements we use the `for` attribute on the label to reference the input\n      // via id reference.\n      this._input.id ||= `sbb-form-field-input-${nextId++}`;\n      this._label.htmlFor = this._input.id;\n    } else {\n      // For non-native input elements, that do not support references via the label for attribute,\n      // we use aria-labelledby on the input element to reference the label element via id.\n      // TODO: Migrate to ariaLabelledByElements when available:\n      // https://developer.mozilla.org/en-US/docs/Web/API/Element/ariaLabelledByElements\n      this._label.id ||= `sbb-form-field-label-${nextId++}`;\n      const labelledby =\n        this._input\n          .getAttribute('aria-labelledby')\n          ?.split(' ')\n          .filter((l) => !!l && l !== this._label!.id) ?? [];\n      this._input.setAttribute('aria-labelledby', [...labelledby, this._label.id].join(' '));\n    }\n  }\n\n  private _isInputElement(input: Element): boolean {\n    return (\n      nativeInputElements.includes(input.localName) ||\n      !!(customElements.get(input.localName) as { formAssociated: boolean } | undefined)\n        ?.formAssociated\n    );\n  }\n\n  private _readInputState(): void {\n    this.toggleState('readonly', this._control?.readOnly ?? this._input!.hasAttribute('readonly'));\n    this.toggleState('disabled', this._control?.disabled ?? this._input!.hasAttribute('disabled'));\n    this.toggleState('has-popup-open', this._input!.hasAttribute('data-expanded'));\n  }\n\n  private _registerInputFormListener(): void {\n    this._inputFormAbortController.abort();\n    const { signal } = (this._inputFormAbortController = new AbortController());\n\n    const form =\n      (this._input as HTMLInputElement | HTMLSelectElement | undefined)?.form ??\n      this._input?.closest('form');\n    // Timeout needed to have value updated\n    const resetHandler = (): unknown => setTimeout(() => this.reset());\n    form?.addEventListener('reset', resetHandler, { signal });\n  }\n\n  // We need to patch the value property of the HTMLInputElement in order\n  // to be able to reset the floating label in the empty state.\n  private _patchInputValue(): void {\n    const inputElement = this._input as HTMLInputElement;\n    if (!inputElement || patchedInputs.has(inputElement)) {\n      return;\n    }\n\n    const originalDescriptor = Object.getOwnPropertyDescriptor(\n      Object.getPrototypeOf(inputElement),\n      'value',\n    );\n\n    if (!originalDescriptor || !originalDescriptor.set || !originalDescriptor.get) {\n      return;\n    }\n\n    patchedInputs.set(inputElement, originalDescriptor);\n\n    const { get: getter, set: setter } = originalDescriptor;\n    const checkAndUpdateInputEmpty = (): void => this._checkAndUpdateInputEmpty();\n\n    Object.defineProperty(inputElement, 'value', {\n      ...originalDescriptor,\n      get() {\n        return getter.call(this);\n      },\n      set(newValue) {\n        setter.call(this, newValue);\n        checkAndUpdateInputEmpty();\n      },\n    });\n  }\n\n  private _unpatchInputValue(): void {\n    const inputElement = this._input as HTMLInputElement;\n    const originalDescriptor = patchedInputs.get(inputElement);\n    if (originalDescriptor) {\n      Object.defineProperty(inputElement, 'value', originalDescriptor);\n      patchedInputs.delete(inputElement);\n    }\n  }\n\n  private _checkAndUpdateInputEmpty(): void {\n    this.toggleState(\n      'empty',\n      this._control?.empty ??\n        (((this._floatingLabelSupportedInputElements.includes(this._input?.localName as string) ||\n          (this._input?.constructor as undefined | typeof SbbFormAssociatedInputMixinType)\n            ?.formFieldAssociated) ??\n          false) &&\n          this._isInputEmpty()),\n    );\n  }\n\n  private _isInputEmpty(): boolean {\n    const chipGroupElem: SbbChipGroupElement | null = this.querySelector('sbb-chip-group');\n    if (chipGroupElem) {\n      return (\n        this._isInputValueEmpty() &&\n        (Array.isArray(chipGroupElem.value)\n          ? chipGroupElem.value.length === 0\n          : !chipGroupElem.querySelector('sbb-chip'))\n      );\n    } else if (this._input instanceof HTMLInputElement) {\n      return (\n        this._floatingLabelSupportedInputTypes.includes(this._input.type) &&\n        this._isInputValueEmpty()\n      );\n    } else if (this._input instanceof HTMLSelectElement) {\n      return this._input.selectedOptions?.item(0)?.label?.trim() === '';\n    } else if (this._input?.localName === 'sbb-select') {\n      return (this._input as SbbSelectElement).getDisplayValue?.()?.trim() === '';\n    } else {\n      return this._isInputValueEmpty();\n    }\n  }\n\n  private _isInputValueEmpty(): boolean {\n    const value = (this._input as { value: string }).value;\n    return ['', undefined, null].includes(value) || (Array.isArray(value) && value.length === 0);\n  }\n\n  /**\n   * It is used internally to set the aria-describedby attribute for the slotted input referencing available <sbb-error> instances.\n   */\n  private _onSlotErrorChange(event: Event): void {\n    const errorElements = (event.target as HTMLSlotElement).assignedElements();\n    if (this._input && this._input.ariaDescribedByElements?.length) {\n      this._input.ariaDescribedByElements = removeAriaElements(\n        this._input.ariaDescribedByElements,\n        ...(this._errorElements ?? []),\n      );\n    }\n\n    this._errorElements = errorElements;\n    for (const el of this._errorElements) {\n      // Instead of defining a container with an aria-live region as expected, we had to change\n      // setting it for every slotted element to properly work in all browsers and screen reader combinations.\n      el.role ||= 'status';\n    }\n\n    this._assignErrorMessageElements();\n    this.toggleState('has-error', !!this._errorElements.length);\n    this._syncNegative();\n  }\n\n  private _assignErrorMessageElements(): void {\n    if (this._input) {\n      this._input.ariaDescribedByElements = appendAriaElements(\n        this._input.ariaDescribedByElements,\n        ...this._errorElements,\n      );\n    }\n  }\n\n  /** Manually reset the form field. Currently, this only resets the floating label. */\n  public reset(): void {\n    this._checkAndUpdateInputEmpty();\n  }\n\n  /** Manually clears the input value. It only works for inputs, selects are not supported. */\n  public clear(): void {\n    if ((this._input?.localName as string) !== 'input') {\n      return;\n    }\n    (this._input as { value: string }).value = '';\n    this._checkAndUpdateInputEmpty();\n  }\n\n  private _syncNegative(): void {\n    this.querySelectorAll?.(\n      'sbb-error,sbb-mini-button,sbb-mini-button-link,sbb-form-field-clear,sbb-datepicker-next-day,sbb-datepicker-previous-day,sbb-datepicker-toggle,sbb-select,sbb-autocomplete,sbb-autocomplete-grid,sbb-chip-group',\n    ).forEach((element) => element.toggleAttribute('negative', this.negative));\n  }\n\n  private _syncSize(): void {\n    this.querySelectorAll?.<SbbAutocompleteBaseElement | SbbSelectElement>(\n      'sbb-autocomplete,sbb-autocomplete-grid,sbb-select',\n    ).forEach((element) => (element.size = this.size === 's' ? 's' : 'm'));\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-form-field__space-wrapper\">\n        ${/* Queried by id from the autocomplete/select to be used as the anchor element */ ''}\n        <div @click=${this._handleWrapperClick} class=\"sbb-form-field__wrapper\" id=\"overlay-anchor\">\n          <slot name=\"prefix\" @slotchange=${this._syncNegative}></slot>\n          <div class=\"sbb-form-field__input-container\">\n            <span class=\"sbb-form-field__label-spacer\" aria-hidden=\"true\"></span>\n            <span class=\"sbb-form-field__label\">\n              <span class=\"sbb-form-field__label-ellipsis\">\n                <slot name=\"label\" @slotchange=${this._onSlotLabelChange}></slot>\n                ${this.optional\n                  ? html` <span aria-hidden=\"true\"> ${i18nOptional[this._language.current]} </span>`\n                  : nothing}\n              </span>\n            </span>\n            <div class=\"sbb-form-field__input\">\n              <slot @slotchange=${this._onSlotInputChange}></slot>\n            </div>\n            ${this.hasUpdated && ['select', 'sbb-select'].includes(this._input?.localName as string)\n              ? html`<sbb-icon\n                  name=\"chevron-small-down-small\"\n                  class=\"sbb-form-field__select-input-icon\"\n                ></sbb-icon>`\n              : nothing}\n          </div>\n          <slot name=\"suffix\" @slotchange=${this._syncNegative}></slot>\n        </div>\n\n        <div class=\"sbb-form-field__error\">\n          <slot name=\"error\" @slotchange=${this._onSlotErrorChange}></slot>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-form-field': SbbFormFieldElement;\n  }\n\n  interface HTMLElementEventMap {\n    formfieldcontrol: SbbFormFieldControlEvent;\n  }\n}\n"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { t as SbbErrorElement } from "./error.component-H90REHso.js";
2
2
  import { SbbFormFieldClearElement } from "./form-field/form-field-clear/form-field-clear.component.js";
3
- import { n as SbbFormFieldElement, t as SbbFormFieldControlEvent } from "./form-field.component-BNIh6zGF.js";
3
+ import { n as SbbFormFieldElement, t as SbbFormFieldControlEvent } from "./form-field.component-BTv2B0dZ.js";
4
4
  import "./form-field.pure.js";
5
5
  //#region src/elements/form-field.ts
6
6
  /** @entrypoint */
@@ -1,4 +1,4 @@
1
1
  import { t as SbbErrorElement } from "./error.component-H90REHso.js";
2
2
  import { SbbFormFieldClearElement } from "./form-field/form-field-clear/form-field-clear.component.js";
3
- import { n as SbbFormFieldElement, t as SbbFormFieldControlEvent } from "./form-field.component-BNIh6zGF.js";
3
+ import { n as SbbFormFieldElement, t as SbbFormFieldControlEvent } from "./form-field.component-BTv2B0dZ.js";
4
4
  export { SbbErrorElement, SbbFormFieldClearElement, SbbFormFieldControlEvent, SbbFormFieldElement };
@@ -2225,6 +2225,32 @@ sbb-flip-card-summary > [slot=image] :is(sbb-image, img):not(.sbb-figure-overlap
2225
2225
  }
2226
2226
  }
2227
2227
 
2228
+ :root.sbb-form-field-required-highlight :is(sbb-form-field, sbb-timetable-form-field):is(:state(empty),[state--empty]):not(:is(:state(readonly),[state--readonly]),
2229
+ :is(:state(disabled),[state--disabled])):has(:where(input, select, textarea, sbb-select, sbb-date-input, sbb-time-input)[required]), :is(sbb-form-field, sbb-timetable-form-field):is(:state(empty),[state--empty]):not(:is(:state(readonly),[state--readonly]),
2230
+ :is(:state(disabled),[state--disabled])).sbb-form-field-required-highlight {
2231
+ --sbb-form-field-background-color: color-mix(in srgb, var(--sbb-color-peach) 5%, var(--sbb-background-color-1));
2232
+ --sbb-form-field-background-color: light-dark(
2233
+ color-mix(in srgb, var(--sbb-color-peach) 5%, var(--sbb-background-color-1)),
2234
+ color-mix(in srgb, var(--sbb-color-peach) 10%, var(--sbb-background-color-1))
2235
+ );
2236
+ }
2237
+ :root.sbb-form-field-required-highlight :is(sbb-form-field, sbb-timetable-form-field):is(:state(empty),[state--empty]):not(:is(:state(readonly),[state--readonly]),
2238
+ :is(:state(disabled),[state--disabled])):has(:where(input, select, textarea, sbb-select, sbb-date-input, sbb-time-input)[required])[negative], :is(sbb-form-field, sbb-timetable-form-field):is(:state(empty),[state--empty]):not(:is(:state(readonly),[state--readonly]),
2239
+ :is(:state(disabled),[state--disabled])).sbb-form-field-required-highlight[negative] {
2240
+ --sbb-form-field-background-color: color-mix(
2241
+ in srgb,
2242
+ var(--sbb-color-peach) 10%,
2243
+ var(--sbb-background-color-1-negative)
2244
+ );
2245
+ }
2246
+
2247
+ @media (forced-colors: active) {
2248
+ :root.sbb-form-field-required-highlight :is(sbb-form-field, sbb-timetable-form-field):not(:is(:state(readonly),[state--readonly]), :is(:state(disabled),[state--disabled])):has(:where(input, select, textarea, sbb-select, sbb-date-input, sbb-time-input)[required]) label::after, :is(sbb-form-field, sbb-timetable-form-field):not(:is(:state(readonly),[state--readonly]), :is(:state(disabled),[state--disabled])).sbb-form-field-required-highlight label::after {
2249
+ content: " *";
2250
+ color: Highlight;
2251
+ }
2252
+ }
2253
+
2228
2254
  sbb-header + :where(sbb-sidebar-container, sbb-icon-sidebar-container) {
2229
2255
  margin-block-start: var(--sbb-header-height);
2230
2256
  }
package/package.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-dev",
3
- "version": "4.9.0-dev.1774933669",
3
+ "version": "4.9.0-dev.1775022513",
4
4
  "description": "Lyne Design System",
5
5
  "keywords": [
6
6
  "design system",
7
7
  "web components",
8
8
  "lit",
9
- "https://github.com/sbb-design-systems/lyne-components/commit/5fa2d38a7728585dde1293821975f10f9534332b"
9
+ "https://github.com/sbb-design-systems/lyne-components/commit/fd3ebcfef5d28b757b789bccca709a6820f607f1"
10
10
  ],
11
11
  "type": "module",
12
12
  "exports": {
package/safety-theme.css CHANGED
@@ -2225,6 +2225,32 @@ sbb-flip-card-summary > [slot=image] :is(sbb-image, img):not(.sbb-figure-overlap
2225
2225
  }
2226
2226
  }
2227
2227
 
2228
+ :root.sbb-form-field-required-highlight :is(sbb-form-field, sbb-timetable-form-field):is(:state(empty),[state--empty]):not(:is(:state(readonly),[state--readonly]),
2229
+ :is(:state(disabled),[state--disabled])):has(:where(input, select, textarea, sbb-select, sbb-date-input, sbb-time-input)[required]), :is(sbb-form-field, sbb-timetable-form-field):is(:state(empty),[state--empty]):not(:is(:state(readonly),[state--readonly]),
2230
+ :is(:state(disabled),[state--disabled])).sbb-form-field-required-highlight {
2231
+ --sbb-form-field-background-color: color-mix(in srgb, var(--sbb-color-peach) 5%, var(--sbb-background-color-1));
2232
+ --sbb-form-field-background-color: light-dark(
2233
+ color-mix(in srgb, var(--sbb-color-peach) 5%, var(--sbb-background-color-1)),
2234
+ color-mix(in srgb, var(--sbb-color-peach) 10%, var(--sbb-background-color-1))
2235
+ );
2236
+ }
2237
+ :root.sbb-form-field-required-highlight :is(sbb-form-field, sbb-timetable-form-field):is(:state(empty),[state--empty]):not(:is(:state(readonly),[state--readonly]),
2238
+ :is(:state(disabled),[state--disabled])):has(:where(input, select, textarea, sbb-select, sbb-date-input, sbb-time-input)[required])[negative], :is(sbb-form-field, sbb-timetable-form-field):is(:state(empty),[state--empty]):not(:is(:state(readonly),[state--readonly]),
2239
+ :is(:state(disabled),[state--disabled])).sbb-form-field-required-highlight[negative] {
2240
+ --sbb-form-field-background-color: color-mix(
2241
+ in srgb,
2242
+ var(--sbb-color-peach) 10%,
2243
+ var(--sbb-background-color-1-negative)
2244
+ );
2245
+ }
2246
+
2247
+ @media (forced-colors: active) {
2248
+ :root.sbb-form-field-required-highlight :is(sbb-form-field, sbb-timetable-form-field):not(:is(:state(readonly),[state--readonly]), :is(:state(disabled),[state--disabled])):has(:where(input, select, textarea, sbb-select, sbb-date-input, sbb-time-input)[required]) label::after, :is(sbb-form-field, sbb-timetable-form-field):not(:is(:state(readonly),[state--readonly]), :is(:state(disabled),[state--disabled])).sbb-form-field-required-highlight label::after {
2249
+ content: " *";
2250
+ color: Highlight;
2251
+ }
2252
+ }
2253
+
2228
2254
  sbb-header + :where(sbb-sidebar-container, sbb-icon-sidebar-container) {
2229
2255
  margin-block-start: var(--sbb-header-height);
2230
2256
  }
@@ -2225,6 +2225,32 @@ sbb-flip-card-summary > [slot=image] :is(sbb-image, img):not(.sbb-figure-overlap
2225
2225
  }
2226
2226
  }
2227
2227
 
2228
+ :root.sbb-form-field-required-highlight :is(sbb-form-field, sbb-timetable-form-field):is(:state(empty),[state--empty]):not(:is(:state(readonly),[state--readonly]),
2229
+ :is(:state(disabled),[state--disabled])):has(:where(input, select, textarea, sbb-select, sbb-date-input, sbb-time-input)[required]), :is(sbb-form-field, sbb-timetable-form-field):is(:state(empty),[state--empty]):not(:is(:state(readonly),[state--readonly]),
2230
+ :is(:state(disabled),[state--disabled])).sbb-form-field-required-highlight {
2231
+ --sbb-form-field-background-color: color-mix(in srgb, var(--sbb-color-peach) 5%, var(--sbb-background-color-1));
2232
+ --sbb-form-field-background-color: light-dark(
2233
+ color-mix(in srgb, var(--sbb-color-peach) 5%, var(--sbb-background-color-1)),
2234
+ color-mix(in srgb, var(--sbb-color-peach) 10%, var(--sbb-background-color-1))
2235
+ );
2236
+ }
2237
+ :root.sbb-form-field-required-highlight :is(sbb-form-field, sbb-timetable-form-field):is(:state(empty),[state--empty]):not(:is(:state(readonly),[state--readonly]),
2238
+ :is(:state(disabled),[state--disabled])):has(:where(input, select, textarea, sbb-select, sbb-date-input, sbb-time-input)[required])[negative], :is(sbb-form-field, sbb-timetable-form-field):is(:state(empty),[state--empty]):not(:is(:state(readonly),[state--readonly]),
2239
+ :is(:state(disabled),[state--disabled])).sbb-form-field-required-highlight[negative] {
2240
+ --sbb-form-field-background-color: color-mix(
2241
+ in srgb,
2242
+ var(--sbb-color-peach) 10%,
2243
+ var(--sbb-background-color-1-negative)
2244
+ );
2245
+ }
2246
+
2247
+ @media (forced-colors: active) {
2248
+ :root.sbb-form-field-required-highlight :is(sbb-form-field, sbb-timetable-form-field):not(:is(:state(readonly),[state--readonly]), :is(:state(disabled),[state--disabled])):has(:where(input, select, textarea, sbb-select, sbb-date-input, sbb-time-input)[required]) label::after, :is(sbb-form-field, sbb-timetable-form-field):not(:is(:state(readonly),[state--readonly]), :is(:state(disabled),[state--disabled])).sbb-form-field-required-highlight label::after {
2249
+ content: " *";
2250
+ color: Highlight;
2251
+ }
2252
+ }
2253
+
2228
2254
  sbb-header + :where(sbb-sidebar-container, sbb-icon-sidebar-container) {
2229
2255
  margin-block-start: var(--sbb-header-height);
2230
2256
  }