@sbb-esta/lyne-elements-dev 4.8.1-dev.1774268427 → 4.8.1-dev.1774270807

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"file":"radio-button-common.d.ts","sourceRoot":"","sources":["../../../../../src/elements/radio-button/common/radio-button-common.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AACzD,OAAO,EACL,KAAK,mBAAmB,EACxB,KAAK,WAAW,EAEjB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,6BAA6B,CAAC;AAE9E,OAAO,EAAE,OAAO,IAAI,sBAAsB,EAAE,MAAM,uCAAuC,CAAC;AAE1F,MAAM,MAAM,kBAAkB,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,CAAC;;AAElD,MAAM,CAAC,OAAO,CAAC,QAAQ,OAAO,oCAAqC,SAAQ,yCAE1E;IACC,IAAW,mBAAmB,IAAI,OAAO,CAAC;IAC1C,IAAW,mBAAmB,CAAC,OAAO,EADJ,OACI,EAAE;IACxC,IAAW,KAAK,IAAI,0BAA0B,GAAG,IAAI,CAAC;IAC/C,MAAM,IAAI,IAAI;CACtB;AAGD,eAAO,MAAM,gCAAgC,GAAI,CAAC,SAAS,WAAW,CAAC,UAAU,CAAC,EAChF,YAAY,CAAC,KACZ,mBAAmB,CAAC,oCAAoC,CAAC,GAAG,CA4F9D,CAAC"}
1
+ {"version":3,"file":"radio-button-common.d.ts","sourceRoot":"","sources":["../../../../../src/elements/radio-button/common/radio-button-common.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AACzD,OAAO,EACL,KAAK,mBAAmB,EACxB,KAAK,WAAW,EAEjB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,6BAA6B,CAAC;AAE9E,OAAO,EAAE,OAAO,IAAI,sBAAsB,EAAE,MAAM,uCAAuC,CAAC;AAE1F,MAAM,MAAM,kBAAkB,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,CAAC;;AAElD,MAAM,CAAC,OAAO,CAAC,QAAQ,OAAO,oCAAqC,SAAQ,yCAE1E;IACC,IAAW,mBAAmB,IAAI,OAAO,CAAC;IAC1C,IAAW,mBAAmB,CAAC,OAAO,EADJ,OACI,EAAE;IACxC,IAAW,KAAK,IAAI,0BAA0B,GAAG,IAAI,CAAC;IAC/C,MAAM,IAAI,IAAI;CACtB;AAGD,eAAO,MAAM,gCAAgC,GAAI,CAAC,SAAS,WAAW,CAAC,UAAU,CAAC,EAChF,YAAY,CAAC,KACZ,mBAAmB,CAAC,oCAAoC,CAAC,GAAG,CAqG9D,CAAC"}
@@ -1,2 +1,2 @@
1
- import { n as radio_button_common_default, t as SbbRadioButtonCommonElementMixin } from "../../radio-button-common-CsjMvmAn.js";
1
+ import { n as radio_button_common_default, t as SbbRadioButtonCommonElementMixin } from "../../radio-button-common-CCrvhOPQ.js";
2
2
  export { SbbRadioButtonCommonElementMixin, radio_button_common_default as radioButtonCommonStyle };
@@ -1,4 +1,4 @@
1
- import { n as radio_button_common_default, t as SbbRadioButtonCommonElementMixin } from "../radio-button-common-CsjMvmAn.js";
1
+ import { n as radio_button_common_default, t as SbbRadioButtonCommonElementMixin } from "../radio-button-common-CCrvhOPQ.js";
2
2
  //#region src/elements/radio-button/common.ts
3
3
  console.warn(`The entrypoint '@sbb-esta/elements/radio-button/common.js' has been deprecated.
4
4
  Use either '@sbb-esta/elements/radio-button.js' or '@sbb-esta/elements/radio-button.pure.js' instead.`);
@@ -1,3 +1,3 @@
1
- import "../radio-button-common-CsjMvmAn.js";
2
- import { t as SbbRadioButtonElement } from "../radio-button.component-BTnHGixs.js";
1
+ import "../radio-button-common-CCrvhOPQ.js";
2
+ import { t as SbbRadioButtonElement } from "../radio-button.component-DYD1hVIZ.js";
3
3
  export { SbbRadioButtonElement };
@@ -1,5 +1,5 @@
1
- import "../radio-button-common-CsjMvmAn.js";
2
- import { t as SbbRadioButtonElement } from "../radio-button.component-BTnHGixs.js";
1
+ import "../radio-button-common-CCrvhOPQ.js";
2
+ import { t as SbbRadioButtonElement } from "../radio-button.component-DYD1hVIZ.js";
3
3
  //#region src/elements/radio-button/radio-button.ts
4
4
  /** @entrypoint */
5
5
  SbbRadioButtonElement.define();
@@ -200,6 +200,12 @@ var SbbRadioButtonCommonElementMixin = (superClass) => {
200
200
  this.emitChangeEvents();
201
201
  }
202
202
  }
203
+ willUpdate(changedProperties) {
204
+ super.willUpdate(changedProperties);
205
+ if (changedProperties.has("value"))
206
+ /** @internal */
207
+ this.dispatchEvent(new Event("ɵradiobuttonvaluechange", { bubbles: true }));
208
+ }
203
209
  isDisabledExternally() {
204
210
  return this.group?.disabled ?? false;
205
211
  }
@@ -228,4 +234,4 @@ var SbbRadioButtonCommonElementMixin = (superClass) => {
228
234
  //#endregion
229
235
  export { radio_button_common_default as n, SbbRadioButtonCommonElementMixin as t };
230
236
 
231
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"radio-button-common-CsjMvmAn.js","names":[],"sources":["../../../src/elements/radio-button/common/radio-button-common.scss?lit&inline","../../../src/elements/radio-button/common/radio-button-common.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-radio-button-inner-circle-color: var(--sbb-radio-button-background-color);\n\n  // The border in unchecked state should fill the circle.\n  --sbb-radio-button-background-fake-border-width: calc(var(--sbb-radio-button-dimension) / 2);\n\n  // Align radio button to the first row of the label based on the line-height so that it's vertically\n  // aligned to the label and sticks to the top if the label breaks into multiple lines\n  --sbb-radio-button-icon-align: calc(\n    (1em * var(--sbb-typo-line-height-text) - var(--sbb-radio-button-dimension)) / 2\n  );\n}\n\n:host(:state(checked)) {\n  --sbb-radio-button-inner-circle-color: var(--sbb-color-primary);\n  --sbb-radio-button-background-fake-border-width: calc(\n    (var(--sbb-radio-button-dimension) - var(--sbb-radio-button-inner-circle-dimension)) / 2\n  );\n\n  @include sbb.if-forced-colors {\n    --sbb-radio-button-inner-circle-color: Highlight;\n    --sbb-radio-button-border-color: Highlight;\n  }\n}\n\n// Disabled definitions have to be after checked definitions\n:host(:disabled) {\n  --sbb-radio-button-label-color: light-dark(var(--sbb-color-granite), var(--sbb-color-aluminium));\n  --sbb-radio-button-background-color: var(--sbb-background-color-3);\n  --sbb-radio-button-border-style: dashed;\n  --sbb-radio-button-inner-circle-color: var(--sbb-radio-button-background-color);\n  --sbb-radio-button-cursor: var(--sbb-cursor-default);\n\n  @include sbb.if-forced-colors {\n    --sbb-radio-button-background-color: Canvas;\n    --sbb-radio-button-inner-circle-color: GrayText;\n    --sbb-radio-button-border-color: GrayText;\n    --sbb-radio-button-border-style: solid;\n  }\n}\n\n// Disabled definitions have to be after checked definitions\n:host(:disabled:state(checked)) {\n  --sbb-radio-button-inner-circle-color: var(--sbb-background-color-2-inverted);\n}\n\n:host([size='xs']) {\n  --sbb-radio-button-font-size: var(--sbb-text-font-size-xs);\n  --sbb-radio-button-dimension: var(--sbb-radio-button-dimension-xs);\n}\n\n:host([size='s']) {\n  --sbb-radio-button-font-size: var(--sbb-text-font-size-s);\n  --sbb-radio-button-dimension: var(--sbb-radio-button-dimension-s);\n}\n\n:host([size='m']) {\n  --sbb-radio-button-font-size: var(--sbb-text-font-size-m);\n  --sbb-radio-button-dimension: var(--sbb-radio-button-dimension-m);\n}\n\n.sbb-screen-reader-only {\n  @include sbb.screen-reader-only;\n}\n\n.sbb-radio-button {\n  font-size: var(--sbb-radio-button-font-size);\n  letter-spacing: var(--sbb-typo-letter-spacing-text);\n  display: block;\n  cursor: var(--sbb-radio-button-cursor);\n  user-select: none;\n  position: relative;\n  color: var(--sbb-radio-button-label-color);\n  -webkit-tap-highlight-color: transparent;\n}\n\n.sbb-radio-button__label-slot {\n  display: flex;\n  align-items: flex-start;\n  overflow: hidden;\n  min-height: calc(var(--sbb-radio-button-font-size) * var(--sbb-typo-line-height-text));\n\n  &::before,\n  &::after {\n    content: '';\n    flex-shrink: 0;\n    width: var(--sbb-radio-button-dimension);\n    height: var(--sbb-radio-button-dimension);\n    border-radius: 50%;\n    margin-block-start: var(--sbb-radio-button-icon-align);\n\n    transition: {\n      duration: var(--sbb-disable-animation-duration, var(--sbb-animation-duration-4x));\n      timing-function: ease;\n      property: background-color, border;\n    }\n\n    @include sbb.if-forced-colors {\n      transition: none;\n    }\n  }\n\n  // Unchecked style\n  &::before {\n    background: var(--sbb-radio-button-inner-circle-color);\n\n    // The border was used to generate the animation of the radio-button\n    // The border color acts as background color.\n    border: var(--sbb-radio-button-background-fake-border-width) solid\n      var(--sbb-radio-button-background-color);\n    margin-inline-end: var(--sbb-radio-button-label-gap);\n  }\n\n  &::after {\n    position: absolute;\n    border: var(--sbb-radio-button-border-width) var(--sbb-radio-button-border-style)\n      var(--sbb-radio-button-border-color);\n  }\n}\n","import { property } from 'lit/decorators.js';\n\nimport { SbbElement } from '../../core/base-elements.ts';\nimport {\n  type AbstractConstructor,\n  type Constructor,\n  SbbFormAssociatedRadioButtonMixin,\n} from '../../core/mixins.ts';\nimport type { SbbRadioButtonGroupElement } from '../../radio-button-group.ts';\n\nexport { default as radioButtonCommonStyle } from './radio-button-common.scss?lit&inline';\n\nexport type SbbRadioButtonSize = 'xs' | 's' | 'm';\n\nexport declare abstract class SbbRadioButtonCommonElementMixinType extends SbbFormAssociatedRadioButtonMixin(\n  SbbElement,\n) {\n  public get allowEmptySelection(): boolean;\n  public set allowEmptySelection(boolean);\n  public get group(): SbbRadioButtonGroupElement | null;\n  public select(): void;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbRadioButtonCommonElementMixin = <T extends Constructor<SbbElement>>(\n  superClass: T,\n): AbstractConstructor<SbbRadioButtonCommonElementMixinType> & T => {\n  abstract class SbbRadioButtonCommonElement\n    extends SbbFormAssociatedRadioButtonMixin(superClass)\n    implements Partial<SbbRadioButtonCommonElementMixinType>\n  {\n    public static readonly events = {\n      change: 'change',\n      input: 'input',\n    } as const;\n\n    /**\n     * Whether the radio can be deselected.\n     */\n    @property({ attribute: 'allow-empty-selection', type: Boolean })\n    public set allowEmptySelection(value: boolean) {\n      this._allowEmptySelection = Boolean(value);\n    }\n    public get allowEmptySelection(): boolean {\n      return this._allowEmptySelection || (this.group?.allowEmptySelection ?? false);\n    }\n    private _allowEmptySelection = false;\n\n    /**\n     * Reference to the connected radio button group.\n     */\n    public get group(): SbbRadioButtonGroupElement | null {\n      return this._group;\n    }\n    private _group: SbbRadioButtonGroupElement | null = null;\n\n    public constructor() {\n      super();\n      this.addEventListener?.('click', (e) => this._handleClick(e));\n      this.addEventListener?.('keydown', (e) => this._handleKeyDown(e));\n    }\n\n    public override connectedCallback(): void {\n      super.connectedCallback();\n      this._group = this.closest('sbb-radio-button-group') as SbbRadioButtonGroupElement;\n\n      // We need to call requestUpdate to update the reflected attributes\n      ['disabled', 'required', 'size'].forEach((p) => this.requestUpdate(p));\n    }\n\n    /**\n     * Set the radio-button as 'checked'; if 'allowEmptySelection', toggle the checked property.\n     * In both cases it emits the change events.\n     */\n    public select(): void {\n      if (this.disabled || this.formDisabled) {\n        return;\n      }\n\n      if (this.allowEmptySelection) {\n        this.checked = !this.checked;\n        this.emitChangeEvents();\n      } else if (!this.checked) {\n        this.checked = true;\n        this.emitChangeEvents();\n      }\n    }\n\n    protected override isDisabledExternally(): boolean {\n      return this.group?.disabled ?? false;\n    }\n\n    protected override isRequiredExternally(): boolean {\n      return this.group?.required ?? false;\n    }\n\n    private async _handleClick(event: Event): Promise<void> {\n      event.preventDefault();\n      this.select();\n\n      /**\n       * Since only a single radio of a group is focusable at any time, it is possible that the one clicked does not have 'tabindex=0'.\n       * To cover that, we await the next render (which will make the 'checked' radio focusable) and focus the clicked radio\n       */\n      await this.updateComplete; // Wait for 'tabindex' to be updated\n      this.focus();\n    }\n\n    private _handleKeyDown(evt: KeyboardEvent): void {\n      if (evt.code === 'Space') {\n        evt.preventDefault();\n        this.select();\n      }\n    }\n  }\n\n  return SbbRadioButtonCommonElement as unknown as AbstractConstructor<SbbRadioButtonCommonElementMixinType> &\n    T;\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACwBA,IAAa,oCACX,eACiE;AA0FjE,eAzF0C;oBAChC,kCAAkC,WAAW;;;eADxC,oCACL,YAA6C;;;2CAWpD,SAAS;KAAE,WAAW;KAAyB,MAAM;KAAS,CAAC,CAAA;AAChE,iBAAA,MAAA,MAAA,qCAAA;KAAA,MAAA;KAAA,MAAA;KAAA,QAAA;KAAA,SAAA;KAAA,QAAA;MAAA,MAAA,QAAA,yBAAA;MAAA,MAAA,KAAA,UAAA;AAAA,WAAW,sBAAmB;;MAAA;KAAA,UAAA;KAAA,EAAA,MAAA,2BAAA;;;;;;;;;AATP,SAAA,SAAS;KAC9B,QAAQ;KACR,OAAO;KACC;;;;;GAMV,IAAW,oBAAoB,OAAc;AAC3C,SAAK,uBAAuB,QAAQ,MAAM;;GAE5C,IAAW,sBAAmB;AAC5B,WAAO,KAAK,yBAAyB,KAAK,OAAO,uBAAuB;;;;;GAO1E,IAAW,QAAK;AACd,WAAO,KAAK;;GAId,cAAA;AACE,WAAO;AAXD,SAAA,wBAnBK,kBAAA,MAAA,2BAA2B,EAmBT;AAQvB,SAAA,SAA4C;AAIlD,SAAK,mBAAmB,UAAU,MAAM,KAAK,aAAa,EAAE,CAAC;AAC7D,SAAK,mBAAmB,YAAY,MAAM,KAAK,eAAe,EAAE,CAAC;;GAGnD,oBAAiB;AAC/B,UAAM,mBAAmB;AACzB,SAAK,SAAS,KAAK,QAAQ,yBAAuD;AAGlF;KAAC;KAAY;KAAY;KAAO,CAAC,SAAS,MAAM,KAAK,cAAc,EAAE,CAAC;;;;;;GAOjE,SAAM;AACX,QAAI,KAAK,YAAY,KAAK,aACxB;AAGF,QAAI,KAAK,qBAAqB;AAC5B,UAAK,UAAU,CAAC,KAAK;AACrB,UAAK,kBAAkB;eACd,CAAC,KAAK,SAAS;AACxB,UAAK,UAAU;AACf,UAAK,kBAAkB;;;GAIR,uBAAoB;AACrC,WAAO,KAAK,OAAO,YAAY;;GAGd,uBAAoB;AACrC,WAAO,KAAK,OAAO,YAAY;;GAGzB,MAAM,aAAa,OAAY;AACrC,UAAM,gBAAgB;AACtB,SAAK,QAAQ;;;;;AAMb,UAAM,KAAK;AACX,SAAK,OAAO;;GAGN,eAAe,KAAkB;AACvC,QAAI,IAAI,SAAS,SAAS;AACxB,SAAI,gBAAgB;AACpB,UAAK,QAAQ"}
237
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"radio-button-common-CCrvhOPQ.js","names":[],"sources":["../../../src/elements/radio-button/common/radio-button-common.scss?lit&inline","../../../src/elements/radio-button/common/radio-button-common.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-radio-button-inner-circle-color: var(--sbb-radio-button-background-color);\n\n  // The border in unchecked state should fill the circle.\n  --sbb-radio-button-background-fake-border-width: calc(var(--sbb-radio-button-dimension) / 2);\n\n  // Align radio button to the first row of the label based on the line-height so that it's vertically\n  // aligned to the label and sticks to the top if the label breaks into multiple lines\n  --sbb-radio-button-icon-align: calc(\n    (1em * var(--sbb-typo-line-height-text) - var(--sbb-radio-button-dimension)) / 2\n  );\n}\n\n:host(:state(checked)) {\n  --sbb-radio-button-inner-circle-color: var(--sbb-color-primary);\n  --sbb-radio-button-background-fake-border-width: calc(\n    (var(--sbb-radio-button-dimension) - var(--sbb-radio-button-inner-circle-dimension)) / 2\n  );\n\n  @include sbb.if-forced-colors {\n    --sbb-radio-button-inner-circle-color: Highlight;\n    --sbb-radio-button-border-color: Highlight;\n  }\n}\n\n// Disabled definitions have to be after checked definitions\n:host(:disabled) {\n  --sbb-radio-button-label-color: light-dark(var(--sbb-color-granite), var(--sbb-color-aluminium));\n  --sbb-radio-button-background-color: var(--sbb-background-color-3);\n  --sbb-radio-button-border-style: dashed;\n  --sbb-radio-button-inner-circle-color: var(--sbb-radio-button-background-color);\n  --sbb-radio-button-cursor: var(--sbb-cursor-default);\n\n  @include sbb.if-forced-colors {\n    --sbb-radio-button-background-color: Canvas;\n    --sbb-radio-button-inner-circle-color: GrayText;\n    --sbb-radio-button-border-color: GrayText;\n    --sbb-radio-button-border-style: solid;\n  }\n}\n\n// Disabled definitions have to be after checked definitions\n:host(:disabled:state(checked)) {\n  --sbb-radio-button-inner-circle-color: var(--sbb-background-color-2-inverted);\n}\n\n:host([size='xs']) {\n  --sbb-radio-button-font-size: var(--sbb-text-font-size-xs);\n  --sbb-radio-button-dimension: var(--sbb-radio-button-dimension-xs);\n}\n\n:host([size='s']) {\n  --sbb-radio-button-font-size: var(--sbb-text-font-size-s);\n  --sbb-radio-button-dimension: var(--sbb-radio-button-dimension-s);\n}\n\n:host([size='m']) {\n  --sbb-radio-button-font-size: var(--sbb-text-font-size-m);\n  --sbb-radio-button-dimension: var(--sbb-radio-button-dimension-m);\n}\n\n.sbb-screen-reader-only {\n  @include sbb.screen-reader-only;\n}\n\n.sbb-radio-button {\n  font-size: var(--sbb-radio-button-font-size);\n  letter-spacing: var(--sbb-typo-letter-spacing-text);\n  display: block;\n  cursor: var(--sbb-radio-button-cursor);\n  user-select: none;\n  position: relative;\n  color: var(--sbb-radio-button-label-color);\n  -webkit-tap-highlight-color: transparent;\n}\n\n.sbb-radio-button__label-slot {\n  display: flex;\n  align-items: flex-start;\n  overflow: hidden;\n  min-height: calc(var(--sbb-radio-button-font-size) * var(--sbb-typo-line-height-text));\n\n  &::before,\n  &::after {\n    content: '';\n    flex-shrink: 0;\n    width: var(--sbb-radio-button-dimension);\n    height: var(--sbb-radio-button-dimension);\n    border-radius: 50%;\n    margin-block-start: var(--sbb-radio-button-icon-align);\n\n    transition: {\n      duration: var(--sbb-disable-animation-duration, var(--sbb-animation-duration-4x));\n      timing-function: ease;\n      property: background-color, border;\n    }\n\n    @include sbb.if-forced-colors {\n      transition: none;\n    }\n  }\n\n  // Unchecked style\n  &::before {\n    background: var(--sbb-radio-button-inner-circle-color);\n\n    // The border was used to generate the animation of the radio-button\n    // The border color acts as background color.\n    border: var(--sbb-radio-button-background-fake-border-width) solid\n      var(--sbb-radio-button-background-color);\n    margin-inline-end: var(--sbb-radio-button-label-gap);\n  }\n\n  &::after {\n    position: absolute;\n    border: var(--sbb-radio-button-border-width) var(--sbb-radio-button-border-style)\n      var(--sbb-radio-button-border-color);\n  }\n}\n","import type { PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbElement } from '../../core/base-elements.ts';\nimport {\n  type AbstractConstructor,\n  type Constructor,\n  SbbFormAssociatedRadioButtonMixin,\n} from '../../core/mixins.ts';\nimport type { SbbRadioButtonGroupElement } from '../../radio-button-group.ts';\n\nexport { default as radioButtonCommonStyle } from './radio-button-common.scss?lit&inline';\n\nexport type SbbRadioButtonSize = 'xs' | 's' | 'm';\n\nexport declare abstract class SbbRadioButtonCommonElementMixinType extends SbbFormAssociatedRadioButtonMixin(\n  SbbElement,\n) {\n  public get allowEmptySelection(): boolean;\n  public set allowEmptySelection(boolean);\n  public get group(): SbbRadioButtonGroupElement | null;\n  public select(): void;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbRadioButtonCommonElementMixin = <T extends Constructor<SbbElement>>(\n  superClass: T,\n): AbstractConstructor<SbbRadioButtonCommonElementMixinType> & T => {\n  abstract class SbbRadioButtonCommonElement\n    extends SbbFormAssociatedRadioButtonMixin(superClass)\n    implements Partial<SbbRadioButtonCommonElementMixinType>\n  {\n    public static readonly events = {\n      change: 'change',\n      input: 'input',\n    } as const;\n\n    /**\n     * Whether the radio can be deselected.\n     */\n    @property({ attribute: 'allow-empty-selection', type: Boolean })\n    public set allowEmptySelection(value: boolean) {\n      this._allowEmptySelection = Boolean(value);\n    }\n    public get allowEmptySelection(): boolean {\n      return this._allowEmptySelection || (this.group?.allowEmptySelection ?? false);\n    }\n    private _allowEmptySelection = false;\n\n    /**\n     * Reference to the connected radio button group.\n     */\n    public get group(): SbbRadioButtonGroupElement | null {\n      return this._group;\n    }\n    private _group: SbbRadioButtonGroupElement | null = null;\n\n    public constructor() {\n      super();\n      this.addEventListener?.('click', (e) => this._handleClick(e));\n      this.addEventListener?.('keydown', (e) => this._handleKeyDown(e));\n    }\n\n    public override connectedCallback(): void {\n      super.connectedCallback();\n      this._group = this.closest('sbb-radio-button-group') as SbbRadioButtonGroupElement;\n\n      // We need to call requestUpdate to update the reflected attributes\n      ['disabled', 'required', 'size'].forEach((p) => this.requestUpdate(p));\n    }\n\n    /**\n     * Set the radio-button as 'checked'; if 'allowEmptySelection', toggle the checked property.\n     * In both cases it emits the change events.\n     */\n    public select(): void {\n      if (this.disabled || this.formDisabled) {\n        return;\n      }\n\n      if (this.allowEmptySelection) {\n        this.checked = !this.checked;\n        this.emitChangeEvents();\n      } else if (!this.checked) {\n        this.checked = true;\n        this.emitChangeEvents();\n      }\n    }\n\n    protected override willUpdate(changedProperties: PropertyValues<this>): void {\n      super.willUpdate(changedProperties);\n\n      if (changedProperties.has('value')) {\n        /** @internal */\n        this.dispatchEvent(new Event('ɵradiobuttonvaluechange', { bubbles: true }));\n      }\n    }\n\n    protected override isDisabledExternally(): boolean {\n      return this.group?.disabled ?? false;\n    }\n\n    protected override isRequiredExternally(): boolean {\n      return this.group?.required ?? false;\n    }\n\n    private async _handleClick(event: Event): Promise<void> {\n      event.preventDefault();\n      this.select();\n\n      /**\n       * Since only a single radio of a group is focusable at any time, it is possible that the one clicked does not have 'tabindex=0'.\n       * To cover that, we await the next render (which will make the 'checked' radio focusable) and focus the clicked radio\n       */\n      await this.updateComplete; // Wait for 'tabindex' to be updated\n      this.focus();\n    }\n\n    private _handleKeyDown(evt: KeyboardEvent): void {\n      if (evt.code === 'Space') {\n        evt.preventDefault();\n        this.select();\n      }\n    }\n  }\n\n  return SbbRadioButtonCommonElement as unknown as AbstractConstructor<SbbRadioButtonCommonElementMixinType> &\n    T;\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACyBA,IAAa,oCACX,eACiE;AAmGjE,eAlG0C;oBAChC,kCAAkC,WAAW;;;eADxC,oCACL,YAA6C;;;2CAWpD,SAAS;KAAE,WAAW;KAAyB,MAAM;KAAS,CAAC,CAAA;AAChE,iBAAA,MAAA,MAAA,qCAAA;KAAA,MAAA;KAAA,MAAA;KAAA,QAAA;KAAA,SAAA;KAAA,QAAA;MAAA,MAAA,QAAA,yBAAA;MAAA,MAAA,KAAA,UAAA;AAAA,WAAW,sBAAmB;;MAAA;KAAA,UAAA;KAAA,EAAA,MAAA,2BAAA;;;;;;;;;AATP,SAAA,SAAS;KAC9B,QAAQ;KACR,OAAO;KACC;;;;;GAMV,IAAW,oBAAoB,OAAc;AAC3C,SAAK,uBAAuB,QAAQ,MAAM;;GAE5C,IAAW,sBAAmB;AAC5B,WAAO,KAAK,yBAAyB,KAAK,OAAO,uBAAuB;;;;;GAO1E,IAAW,QAAK;AACd,WAAO,KAAK;;GAId,cAAA;AACE,WAAO;AAXD,SAAA,wBAnBK,kBAAA,MAAA,2BAA2B,EAmBT;AAQvB,SAAA,SAA4C;AAIlD,SAAK,mBAAmB,UAAU,MAAM,KAAK,aAAa,EAAE,CAAC;AAC7D,SAAK,mBAAmB,YAAY,MAAM,KAAK,eAAe,EAAE,CAAC;;GAGnD,oBAAiB;AAC/B,UAAM,mBAAmB;AACzB,SAAK,SAAS,KAAK,QAAQ,yBAAuD;AAGlF;KAAC;KAAY;KAAY;KAAO,CAAC,SAAS,MAAM,KAAK,cAAc,EAAE,CAAC;;;;;;GAOjE,SAAM;AACX,QAAI,KAAK,YAAY,KAAK,aACxB;AAGF,QAAI,KAAK,qBAAqB;AAC5B,UAAK,UAAU,CAAC,KAAK;AACrB,UAAK,kBAAkB;eACd,CAAC,KAAK,SAAS;AACxB,UAAK,UAAU;AACf,UAAK,kBAAkB;;;GAIR,WAAW,mBAAuC;AACnE,UAAM,WAAW,kBAAkB;AAEnC,QAAI,kBAAkB,IAAI,QAAQ;;AAEhC,SAAK,cAAc,IAAI,MAAM,2BAA2B,EAAE,SAAS,MAAM,CAAC,CAAC;;GAI5D,uBAAoB;AACrC,WAAO,KAAK,OAAO,YAAY;;GAGd,uBAAoB;AACrC,WAAO,KAAK,OAAO,YAAY;;GAGzB,MAAM,aAAa,OAAY;AACrC,UAAM,gBAAgB;AACtB,SAAK,QAAQ;;;;;AAMb,UAAM,KAAK;AACX,SAAK,OAAO;;GAGN,eAAe,KAAkB;AACvC,QAAI,IAAI,SAAS,SAAS;AACxB,SAAI,gBAAgB;AACpB,UAAK,QAAQ"}
@@ -1 +1 @@
1
- {"version":3,"file":"radio-button-group.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/radio-button-group/radio-button-group.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAG1C,OAAO,EAAE,4BAA4B,EAAE,MAAM,0BAA0B,CAAC;AAExE,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,2CAA2C,CAAC;AACvF,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AAI3E;;;;;;GAMG;AACH,qBAAa,0BAA0B,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,4BAA4B,CACtF,qBAAqB,CAAC,CAAC,CAAC,GAAG,0BAA0B,CAAC,CAAC,CAAC,CACzD;IACC,gBAAgC,WAAW,EAAE,MAAM,CAA4B;IAC/E,gBAAgC,IAAI,gBAAgB;IACpD,gBAAuB,MAAM;;;;MAIlB;IACX,SAAS,CAAC,QAAQ,CAAC,yBAAyB,8CAA8C;IAC1F,SAAS,CAAC,QAAQ,CAAC,oBAAoB,EAAE,MAAM,CAA4B;IAE3E;;OAEG;IACH,SAEgB,mBAAmB,EAAE,OAAO,CAAS;IAErD;;OAEG;IACH,IACW,KAAK,CAAC,GAAG,EAAE,CAAC,GAAG,IAAI,EAa7B;IACD,IAAW,KAAK,IAAI,CAAC,GAAG,IAAI,CAI3B;IACD;;OAEG;IACH,OAAO,CAAC,cAAc,CAAkB;IAExC,sIAAsI;IACtI,SAGgB,IAAI,EAAE,MAAM,CAAwC;IAEpE,uCAAuC;IACvC,IAAW,YAAY,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,GAAG,0BAA0B,CAAC,CAAC,CAAC,CAAC,EAAE,CAEtF;;cAOkB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAQzD,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAM9E,OAAO,CAAC,cAAc;IAoBtB;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAIzB;;;OAGG;IACH,OAAO,CAAC,iBAAiB;cAON,YAAY,IAAI,IAAI;CAMxC;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,wBAAwB,EAAE,0BAA0B,CAAC;KACtD;CACF"}
1
+ {"version":3,"file":"radio-button-group.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/radio-button-group/radio-button-group.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAG1C,OAAO,EAAE,4BAA4B,EAAE,MAAM,0BAA0B,CAAC;AAExE,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,2CAA2C,CAAC;AACvF,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AAI3E;;;;;;GAMG;AACH,qBAAa,0BAA0B,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,4BAA4B,CACtF,qBAAqB,CAAC,CAAC,CAAC,GAAG,0BAA0B,CAAC,CAAC,CAAC,CACzD;IACC,gBAAgC,WAAW,EAAE,MAAM,CAA4B;IAC/E,gBAAgC,IAAI,gBAAgB;IACpD,gBAAuB,MAAM;;;;MAIlB;IACX,SAAS,CAAC,QAAQ,CAAC,yBAAyB,8CAA8C;IAC1F,SAAS,CAAC,QAAQ,CAAC,oBAAoB,EAAE,MAAM,CAA4B;IAE3E;;OAEG;IACH,SAEgB,mBAAmB,EAAE,OAAO,CAAS;IAErD;;OAEG;IACH,IACW,KAAK,CAAC,GAAG,EAAE,CAAC,GAAG,IAAI,EAa7B;IACD,IAAW,KAAK,IAAI,CAAC,GAAG,IAAI,CAI3B;IACD;;OAEG;IACH,OAAO,CAAC,cAAc,CAAkB;IAExC,sIAAsI;IACtI,SAGgB,IAAI,EAAE,MAAM,CAAwC;IAEpE,uCAAuC;IACvC,IAAW,YAAY,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,GAAG,0BAA0B,CAAC,CAAC,CAAC,CAAC,EAAE,CAEtF;;cAQkB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAQzD,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAM9E,OAAO,CAAC,cAAc;IAoBtB;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAIzB;;;OAGG;IACH,OAAO,CAAC,iBAAiB;cAON,YAAY,IAAI,IAAI;CAMxC;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,wBAAwB,EAAE,0BAA0B,CAAC;KACtD;CACF"}
@@ -141,6 +141,7 @@ var SbbRadioButtonGroupElement = (() => {
141
141
  this.#name_accessor_storage = __runInitializers(this, _name_initializers, `sbb-radio-button-group-${++nextId}`);
142
142
  __runInitializers(this, _name_extraInitializers);
143
143
  this.addEventListener?.("change", (e) => this._onRadioChange(e));
144
+ this.addEventListener?.("ɵradiobuttonvaluechange", () => this._updateRadioState());
144
145
  }
145
146
  willUpdate(changedProperties) {
146
147
  super.willUpdate(changedProperties);
@@ -183,4 +184,4 @@ var SbbRadioButtonGroupElement = (() => {
183
184
  //#endregion
184
185
  export { SbbRadioButtonGroupElement };
185
186
 
186
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"radio-button-group.component.js","names":[],"sources":["../../../../src/elements/radio-button-group/radio-button-group.component.ts"],"sourcesContent":["import type { PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbSelectionGroupBaseElement } from '../core/base-elements.ts';\nimport { forceType } from '../core/decorators.ts';\nimport type { SbbRadioButtonElement } from '../radio-button/radio-button.component.ts';\nimport type { SbbRadioButtonPanelElement } from '../radio-button-panel.ts';\n\nlet nextId = 0;\n\n/**\n * It can be used as a container for radio button elements.\n *\n * @slot - Use the unnamed slot to add `sbb-radio-button`, `sbb-radio-button-panel`, `sbb-selection-action-panel` and `sbb-selection-expansion-panel` elements to the `sbb-radio-button-group`.\n * @slot error - Use this to provide a `sbb-error` to show an error message.\n * @overrideType value - (T = string) | null\n */\nexport class SbbRadioButtonGroupElement<T = string> extends SbbSelectionGroupBaseElement<\n  SbbRadioButtonElement<T> | SbbRadioButtonPanelElement<T>\n> {\n  public static override readonly elementName: string = 'sbb-radio-button-group';\n  public static override readonly role = 'radiogroup';\n  public static readonly events = {\n    didChange: 'didChange',\n    change: 'change',\n    input: 'input',\n  } as const;\n  protected readonly selectionElementSelectors = 'sbb-radio-button, sbb-radio-button-panel';\n  protected readonly panelElementSelector: string = 'sbb-radio-button-panel';\n\n  /**\n   * Whether the radios can be deselected.\n   */\n  @forceType()\n  @property({ attribute: 'allow-empty-selection', type: Boolean })\n  public accessor allowEmptySelection: boolean = false;\n\n  /**\n   * The value of the radio group.\n   */\n  @property()\n  public set value(val: T | null) {\n    this._fallbackValue = val;\n    if (!this.hasUpdated) {\n      return;\n    }\n    if (val == null) {\n      this.selectionElements.forEach((r) => (r.checked = false));\n      return;\n    }\n    const toCheck = this.selectionElements.find((r) => r.value === val);\n    if (toCheck) {\n      toCheck.checked = true;\n    }\n  }\n  public get value(): T | null {\n    return (\n      this.selectionElements.find((r) => r.checked && !r.disabled)?.value ?? this._fallbackValue\n    );\n  }\n  /**\n   * Used to preserve the `value` in case the radios are not yet 'loaded'\n   */\n  private _fallbackValue: T | null = null;\n\n  /** Name for the group. Will be propagated to the child radio buttons. Must be unique if multiple groups are used on the same page. */\n  @forceType()\n  @property()\n  // eslint-disable-next-line no-useless-assignment\n  public accessor name: string = `sbb-radio-button-group-${++nextId}`;\n\n  /** List of contained radio buttons. */\n  public get radioButtons(): (SbbRadioButtonElement<T> | SbbRadioButtonPanelElement<T>)[] {\n    return this.selectionElements;\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('change', (e: Event) => this._onRadioChange(e));\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('name')) {\n      this._updateRadiosName();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this.updateComplete.then(() => this._updateRadioState());\n  }\n\n  private _onRadioChange(event: Event): void {\n    const target = event.target! as SbbRadioButtonElement | SbbRadioButtonPanelElement;\n\n    // Only filter radio-buttons event\n    if (\n      (target.localName !== 'sbb-radio-button' && target.localName !== 'sbb-radio-button-panel') ||\n      target.group !== this\n    ) {\n      return;\n    }\n\n    this._fallbackValue = null; // Since the user interacted, the fallbackValue logic does not apply anymore\n\n    /**\n     * Deprecated. Mirrors change event for React. Will be removed once React properly supports change events.\n     * @deprecated\n     */\n    this.dispatchEvent(new Event('didChange', { bubbles: true }));\n  }\n\n  /**\n   * Proxy 'name' to child radio-buttons\n   */\n  private _updateRadiosName(): void {\n    this.selectionElements.forEach((r) => (r.name = this.name));\n  }\n\n  /**\n   * Re-trigger the setter and update the checked state of the radios.\n   * Mainly used to cover cases where the setter is called before the radios are loaded\n   */\n  private _updateRadioState(): void {\n    if (this._fallbackValue != null) {\n      // eslint-disable-next-line no-self-assign\n      this.value = this.value;\n    }\n  }\n\n  protected override onSlotChange(): void {\n    super.onSlotChange();\n\n    this._updateRadiosName();\n    this._updateRadioState();\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-radio-button-group': SbbRadioButtonGroupElement;\n  }\n}\n"],"mappings":"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"}
187
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"radio-button-group.component.js","names":[],"sources":["../../../../src/elements/radio-button-group/radio-button-group.component.ts"],"sourcesContent":["import type { PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbSelectionGroupBaseElement } from '../core/base-elements.ts';\nimport { forceType } from '../core/decorators.ts';\nimport type { SbbRadioButtonElement } from '../radio-button/radio-button.component.ts';\nimport type { SbbRadioButtonPanelElement } from '../radio-button-panel.ts';\n\nlet nextId = 0;\n\n/**\n * It can be used as a container for radio button elements.\n *\n * @slot - Use the unnamed slot to add `sbb-radio-button`, `sbb-radio-button-panel`, `sbb-selection-action-panel` and `sbb-selection-expansion-panel` elements to the `sbb-radio-button-group`.\n * @slot error - Use this to provide a `sbb-error` to show an error message.\n * @overrideType value - (T = string) | null\n */\nexport class SbbRadioButtonGroupElement<T = string> extends SbbSelectionGroupBaseElement<\n  SbbRadioButtonElement<T> | SbbRadioButtonPanelElement<T>\n> {\n  public static override readonly elementName: string = 'sbb-radio-button-group';\n  public static override readonly role = 'radiogroup';\n  public static readonly events = {\n    didChange: 'didChange',\n    change: 'change',\n    input: 'input',\n  } as const;\n  protected readonly selectionElementSelectors = 'sbb-radio-button, sbb-radio-button-panel';\n  protected readonly panelElementSelector: string = 'sbb-radio-button-panel';\n\n  /**\n   * Whether the radios can be deselected.\n   */\n  @forceType()\n  @property({ attribute: 'allow-empty-selection', type: Boolean })\n  public accessor allowEmptySelection: boolean = false;\n\n  /**\n   * The value of the radio group.\n   */\n  @property()\n  public set value(val: T | null) {\n    this._fallbackValue = val;\n    if (!this.hasUpdated) {\n      return;\n    }\n    if (val == null) {\n      this.selectionElements.forEach((r) => (r.checked = false));\n      return;\n    }\n    const toCheck = this.selectionElements.find((r) => r.value === val);\n    if (toCheck) {\n      toCheck.checked = true;\n    }\n  }\n  public get value(): T | null {\n    return (\n      this.selectionElements.find((r) => r.checked && !r.disabled)?.value ?? this._fallbackValue\n    );\n  }\n  /**\n   * Used to preserve the `value` in case the radios are not yet 'loaded'\n   */\n  private _fallbackValue: T | null = null;\n\n  /** Name for the group. Will be propagated to the child radio buttons. Must be unique if multiple groups are used on the same page. */\n  @forceType()\n  @property()\n  // eslint-disable-next-line no-useless-assignment\n  public accessor name: string = `sbb-radio-button-group-${++nextId}`;\n\n  /** List of contained radio buttons. */\n  public get radioButtons(): (SbbRadioButtonElement<T> | SbbRadioButtonPanelElement<T>)[] {\n    return this.selectionElements;\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('change', (e: Event) => this._onRadioChange(e));\n    this.addEventListener?.('ɵradiobuttonvaluechange', () => this._updateRadioState());\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('name')) {\n      this._updateRadiosName();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this.updateComplete.then(() => this._updateRadioState());\n  }\n\n  private _onRadioChange(event: Event): void {\n    const target = event.target! as SbbRadioButtonElement | SbbRadioButtonPanelElement;\n\n    // Only filter radio-buttons event\n    if (\n      (target.localName !== 'sbb-radio-button' && target.localName !== 'sbb-radio-button-panel') ||\n      target.group !== this\n    ) {\n      return;\n    }\n\n    this._fallbackValue = null; // Since the user interacted, the fallbackValue logic does not apply anymore\n\n    /**\n     * Deprecated. Mirrors change event for React. Will be removed once React properly supports change events.\n     * @deprecated\n     */\n    this.dispatchEvent(new Event('didChange', { bubbles: true }));\n  }\n\n  /**\n   * Proxy 'name' to child radio-buttons\n   */\n  private _updateRadiosName(): void {\n    this.selectionElements.forEach((r) => (r.name = this.name));\n  }\n\n  /**\n   * Re-trigger the setter and update the checked state of the radios.\n   * Mainly used to cover cases where the setter is called before the radios are loaded\n   */\n  private _updateRadioState(): void {\n    if (this._fallbackValue != null) {\n      // eslint-disable-next-line no-self-assign\n      this.value = this.value;\n    }\n  }\n\n  protected override onSlotChange(): void {\n    super.onSlotChange();\n\n    this._updateRadiosName();\n    this._updateRadioState();\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-radio-button-group': SbbRadioButtonGroupElement;\n  }\n}\n"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import { n as radio_button_common_default, t as SbbRadioButtonCommonElementMixin } from "./radio-button-common-CsjMvmAn.js";
1
+ import { n as radio_button_common_default, t as SbbRadioButtonCommonElementMixin } from "./radio-button-common-CCrvhOPQ.js";
2
2
  import { __esDecorate, __runInitializers } from "tslib";
3
3
  import { css, html } from "lit";
4
4
  import { property } from "lit/decorators.js";
@@ -134,4 +134,4 @@ var SbbRadioButtonElement = (() => {
134
134
  //#endregion
135
135
  export { SbbRadioButtonElement as t };
136
136
 
137
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW8tYnV0dG9uLmNvbXBvbmVudC1CVG5IR2l4cy5qcyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZWxlbWVudHMvcmFkaW8tYnV0dG9uL3JhZGlvLWJ1dHRvbi5zY3NzP2xpdCZpbmxpbmUiLCIuLi8uLi8uLi9zcmMvZWxlbWVudHMvcmFkaW8tYnV0dG9uL3JhZGlvLWJ1dHRvbi5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiQHVzZSAnLi4vY29yZS9zdHlsZXMnIGFzIHNiYjtcblxuOmhvc3Qge1xuICBkaXNwbGF5OiBibG9jaztcblxuICAvLyBVc2UgIWltcG9ydGFudCBoZXJlIHRvIG5vdCBpbnRlcmZlcmUgd2l0aCBGaXJlZm94IGZvY3VzIHJpbmcgZGVmaW5pdGlvblxuICAvLyB3aGljaCBhcHBlYXJzIGluIG5vcm1hbGl6ZSBDU1Mgb2Ygc2V2ZXJhbCBmcmFtZXdvcmtzLlxuICBvdXRsaW5lOiBub25lICFpbXBvcnRhbnQ7XG59XG5cbjpob3N0KDpub3QoOnN0YXRlKHNsb3R0ZWQpLCA6c3RhdGUoc2xvdHRlZC1pY29uKSwgOnN0YXRlKGhhcy1pY29uLW5hbWUpKSkge1xuICAtLXNiYi1yYWRpby1idXR0b24tbGFiZWwtZ2FwOiAwO1xufVxuXG4uc2JiLXJhZGlvLWJ1dHRvbiB7XG4gIDpob3N0KDpmb2N1cy12aXNpYmxlKSAmIHtcbiAgICBAaW5jbHVkZSBzYmIuZm9jdXMtb3V0bGluZTtcblxuICAgIGJvcmRlci1yYWRpdXM6IGNhbGModmFyKC0tc2JiLWJvcmRlci1yYWRpdXMtNHgpIC0gdmFyKC0tc2JiLWZvY3VzLW91dGxpbmUtb2Zmc2V0KSk7XG4gIH1cbn1cbiIsImltcG9ydCB0eXBlIHsgQ1NTUmVzdWx0R3JvdXAsIFRlbXBsYXRlUmVzdWx0IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGh0bWwgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgcHJvcGVydHkgfSBmcm9tICdsaXQvZGVjb3JhdG9ycy5qcyc7XG5cbmltcG9ydCB7IFNiYkVsZW1lbnQgfSBmcm9tICcuLi9jb3JlL2Jhc2UtZWxlbWVudHMudHMnO1xuaW1wb3J0IHsgZ2V0T3ZlcnJpZGUgfSBmcm9tICcuLi9jb3JlL2RlY29yYXRvcnMudHMnO1xuaW1wb3J0IHsgaXNMZWFuIH0gZnJvbSAnLi4vY29yZS9kb20udHMnO1xuaW1wb3J0IHsgYm94U2l6aW5nU3R5bGVzIH0gZnJvbSAnLi4vY29yZS9zdHlsZXMudHMnO1xuXG5pbXBvcnQge1xuICBTYmJSYWRpb0J1dHRvbkNvbW1vbkVsZW1lbnRNaXhpbixcbiAgcmFkaW9CdXR0b25Db21tb25TdHlsZSxcbiAgdHlwZSBTYmJSYWRpb0J1dHRvblNpemUsXG59IGZyb20gJy4vY29tbW9uL3JhZGlvLWJ1dHRvbi1jb21tb24udHMnO1xuaW1wb3J0IHJhZGlvQnV0dG9uU3R5bGUgZnJvbSAnLi9yYWRpby1idXR0b24uc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBJdCBkaXNwbGF5cyBhIHJhZGlvIGJ1dHRvbiBlbmhhbmNlZCB3aXRoIHRoZSBTQkIgRGVzaWduLlxuICpcbiAqIEBzbG90IC0gVXNlIHRoZSB1bm5hbWVkIHNsb3QgdG8gYWRkIGNvbnRlbnQgdG8gdGhlIHJhZGlvIGxhYmVsLlxuICogQGV2ZW50IHtFdmVudH0gY2hhbmdlIC0gVGhlIGNoYW5nZSBldmVudCBpcyBmaXJlZCB3aGVuIHRoZSB1c2VyIG1vZGlmaWVzIHRoZSBlbGVtZW50J3MgdmFsdWUuIFVubGlrZSB0aGUgaW5wdXQgZXZlbnQsIHRoZSBjaGFuZ2UgZXZlbnQgaXMgbm90IG5lY2Vzc2FyaWx5IGZpcmVkIGZvciBlYWNoIGFsdGVyYXRpb24gdG8gYW4gZWxlbWVudCdzIHZhbHVlLlxuICogQGV2ZW50IHtJbnB1dEV2ZW50fSBpbnB1dCAtIFRoZSBpbnB1dCBldmVudCBmaXJlcyB3aGVuIHRoZSB2YWx1ZSBoYXMgYmVlbiBjaGFuZ2VkIGFzIGEgZGlyZWN0IHJlc3VsdCBvZiBhIHVzZXIgYWN0aW9uLlxuICogQG92ZXJyaWRlVHlwZSB2YWx1ZSAtIChUID0gc3RyaW5nKSB8IG51bGxcbiAqL1xuZXhwb3J0IGNsYXNzIFNiYlJhZGlvQnV0dG9uRWxlbWVudDxUID0gc3RyaW5nPiBleHRlbmRzIFNiYlJhZGlvQnV0dG9uQ29tbW9uRWxlbWVudE1peGluKFxuICBTYmJFbGVtZW50LFxuKSB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgcmVhZG9ubHkgZWxlbWVudE5hbWU6IHN0cmluZyA9ICdzYmItcmFkaW8tYnV0dG9uJztcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gW1xuICAgIGJveFNpemluZ1N0eWxlcyxcbiAgICByYWRpb0J1dHRvbkNvbW1vblN0eWxlLFxuICAgIHJhZGlvQnV0dG9uU3R5bGUsXG4gIF07XG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgZXZlbnRzID0ge1xuICAgIGNoYW5nZTogJ2NoYW5nZScsXG4gICAgaW5wdXQ6ICdpbnB1dCcsXG4gIH0gYXMgY29uc3Q7XG5cbiAgLyoqXG4gICAqIFNpemUgdmFyaWFudCwgZWl0aGVyIHhzLCBzIG9yIG0uXG4gICAqIEBkZWZhdWx0ICdtJyAvICd4cycgKGxlYW4pXG4gICAqL1xuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIEBnZXRPdmVycmlkZSgoaSwgdikgPT4gaS5ncm91cD8uc2l6ZSA/PyB2KVxuICBwdWJsaWMgYWNjZXNzb3Igc2l6ZTogU2JiUmFkaW9CdXR0b25TaXplID0gaXNMZWFuKCkgPyAneHMnIDogJ20nO1xuXG4gIC8qKlxuICAgKiBUaGUgdmFsdWUgb2YgdGhlIGZvcm0gZWxlbWVudFxuICAgKi9cbiAgQHByb3BlcnR5KClcbiAgcHVibGljIGFjY2Vzc29yIHZhbHVlOiBUIHwgbnVsbCA9IG51bGw7XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgcmV0dXJuIGh0bWxgXG4gICAgICA8ZGl2IGNsYXNzPVwic2JiLXJhZGlvLWJ1dHRvblwiPlxuICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1yYWRpby1idXR0b25fX2xhYmVsLXNsb3RcIj5cbiAgICAgICAgICA8c2xvdD48L3Nsb3Q+XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgIDwvZGl2PlxuICAgIGA7XG4gIH1cbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi1yYWRpby1idXR0b24nOiBTYmJSYWRpb0J1dHRvbkVsZW1lbnQ7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lDd0JhLCtCQUFxQjttQkFBcUIsaUNBQ3JELFdBQ0Q7Ozs7Ozs7Y0FGWSw4QkFBMEMsWUFFdEQ7Ozt1QkFnQkUsU0FBUyxFQUFFLFNBQVMsTUFBTSxDQUFDLEVBQzNCLGFBQWEsR0FBRyxNQUFNLEVBQUUsT0FBTyxRQUFRLEVBQUUsQ0FBQTt3QkFNekMsVUFBVSxDQUFBO0FBTFgsZ0JBQUEsTUFBQSxNQUFBLGtCQUFBO0lBQUEsTUFBQTtJQUFBLE1BQUE7SUFBQSxRQUFBO0lBQUEsU0FBQTtJQUFBLFFBQUE7S0FBQSxNQUFBLFFBQUEsVUFBQTtLQUFBLE1BQUEsUUFBQSxJQUFnQjtLQUFJLE1BQUEsS0FBQSxVQUFBO0FBQUEsVUFBSixPQUFJOztLQUFBO0lBQUEsVUFBQTtJQUFBLEVBQUEsb0JBQUEsd0JBQUE7QUFNcEIsZ0JBQUEsTUFBQSxNQUFBLG1CQUFBO0lBQUEsTUFBQTtJQUFBLE1BQUE7SUFBQSxRQUFBO0lBQUEsU0FBQTtJQUFBLFFBQUE7S0FBQSxNQUFBLFFBQUEsV0FBQTtLQUFBLE1BQUEsUUFBQSxJQUFnQjtLQUFLLE1BQUEsS0FBQSxVQUFBO0FBQUEsVUFBTCxRQUFLOztLQUFBO0lBQUEsVUFBQTtJQUFBLEVBQUEscUJBQUEseUJBQUE7Ozs7Ozs7OztBQXZCVyxRQUFBLGNBQXNCOzs7QUFDL0IsUUFBQSxTQUF5QjtJQUM5QztJQUNBO0lBQ0E7SUFDRDs7O0FBQ3NCLFFBQUEsU0FBUztJQUM5QixRQUFRO0lBQ1IsT0FBTztJQUNDOztFQVFWLHlCQUFBLGtCQUFBLE1BQUEsb0JBQTJDLFFBQVEsR0FBRyxPQUFPLElBQUc7Ozs7O0VBQWhFLElBQWdCLE9BQUk7QUFBQSxVQUFBLE1BQUE7O0VBQXBCLElBQWdCLEtBQUksT0FBQTtBQUFBLFNBQUEsd0JBQUE7O0VBTXBCLDJCQUFBLGtCQUFBLE1BQUEsd0JBQUEsRUFBQSxrQkFBQSxNQUFBLHFCQUFrQyxLQUFJOzs7O0VBQXRDLElBQWdCLFFBQUs7QUFBQSxVQUFBLE1BQUE7O0VBQXJCLElBQWdCLE1BQUssT0FBQTtBQUFBLFNBQUEseUJBQUE7O0VBRUYsU0FBTTtBQUN2QixVQUFPLElBQUkifQ==
137
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW8tYnV0dG9uLmNvbXBvbmVudC1EWUQxaFZJWi5qcyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZWxlbWVudHMvcmFkaW8tYnV0dG9uL3JhZGlvLWJ1dHRvbi5zY3NzP2xpdCZpbmxpbmUiLCIuLi8uLi8uLi9zcmMvZWxlbWVudHMvcmFkaW8tYnV0dG9uL3JhZGlvLWJ1dHRvbi5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiQHVzZSAnLi4vY29yZS9zdHlsZXMnIGFzIHNiYjtcblxuOmhvc3Qge1xuICBkaXNwbGF5OiBibG9jaztcblxuICAvLyBVc2UgIWltcG9ydGFudCBoZXJlIHRvIG5vdCBpbnRlcmZlcmUgd2l0aCBGaXJlZm94IGZvY3VzIHJpbmcgZGVmaW5pdGlvblxuICAvLyB3aGljaCBhcHBlYXJzIGluIG5vcm1hbGl6ZSBDU1Mgb2Ygc2V2ZXJhbCBmcmFtZXdvcmtzLlxuICBvdXRsaW5lOiBub25lICFpbXBvcnRhbnQ7XG59XG5cbjpob3N0KDpub3QoOnN0YXRlKHNsb3R0ZWQpLCA6c3RhdGUoc2xvdHRlZC1pY29uKSwgOnN0YXRlKGhhcy1pY29uLW5hbWUpKSkge1xuICAtLXNiYi1yYWRpby1idXR0b24tbGFiZWwtZ2FwOiAwO1xufVxuXG4uc2JiLXJhZGlvLWJ1dHRvbiB7XG4gIDpob3N0KDpmb2N1cy12aXNpYmxlKSAmIHtcbiAgICBAaW5jbHVkZSBzYmIuZm9jdXMtb3V0bGluZTtcblxuICAgIGJvcmRlci1yYWRpdXM6IGNhbGModmFyKC0tc2JiLWJvcmRlci1yYWRpdXMtNHgpIC0gdmFyKC0tc2JiLWZvY3VzLW91dGxpbmUtb2Zmc2V0KSk7XG4gIH1cbn1cbiIsImltcG9ydCB0eXBlIHsgQ1NTUmVzdWx0R3JvdXAsIFRlbXBsYXRlUmVzdWx0IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGh0bWwgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgcHJvcGVydHkgfSBmcm9tICdsaXQvZGVjb3JhdG9ycy5qcyc7XG5cbmltcG9ydCB7IFNiYkVsZW1lbnQgfSBmcm9tICcuLi9jb3JlL2Jhc2UtZWxlbWVudHMudHMnO1xuaW1wb3J0IHsgZ2V0T3ZlcnJpZGUgfSBmcm9tICcuLi9jb3JlL2RlY29yYXRvcnMudHMnO1xuaW1wb3J0IHsgaXNMZWFuIH0gZnJvbSAnLi4vY29yZS9kb20udHMnO1xuaW1wb3J0IHsgYm94U2l6aW5nU3R5bGVzIH0gZnJvbSAnLi4vY29yZS9zdHlsZXMudHMnO1xuXG5pbXBvcnQge1xuICBTYmJSYWRpb0J1dHRvbkNvbW1vbkVsZW1lbnRNaXhpbixcbiAgcmFkaW9CdXR0b25Db21tb25TdHlsZSxcbiAgdHlwZSBTYmJSYWRpb0J1dHRvblNpemUsXG59IGZyb20gJy4vY29tbW9uL3JhZGlvLWJ1dHRvbi1jb21tb24udHMnO1xuaW1wb3J0IHJhZGlvQnV0dG9uU3R5bGUgZnJvbSAnLi9yYWRpby1idXR0b24uc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBJdCBkaXNwbGF5cyBhIHJhZGlvIGJ1dHRvbiBlbmhhbmNlZCB3aXRoIHRoZSBTQkIgRGVzaWduLlxuICpcbiAqIEBzbG90IC0gVXNlIHRoZSB1bm5hbWVkIHNsb3QgdG8gYWRkIGNvbnRlbnQgdG8gdGhlIHJhZGlvIGxhYmVsLlxuICogQGV2ZW50IHtFdmVudH0gY2hhbmdlIC0gVGhlIGNoYW5nZSBldmVudCBpcyBmaXJlZCB3aGVuIHRoZSB1c2VyIG1vZGlmaWVzIHRoZSBlbGVtZW50J3MgdmFsdWUuIFVubGlrZSB0aGUgaW5wdXQgZXZlbnQsIHRoZSBjaGFuZ2UgZXZlbnQgaXMgbm90IG5lY2Vzc2FyaWx5IGZpcmVkIGZvciBlYWNoIGFsdGVyYXRpb24gdG8gYW4gZWxlbWVudCdzIHZhbHVlLlxuICogQGV2ZW50IHtJbnB1dEV2ZW50fSBpbnB1dCAtIFRoZSBpbnB1dCBldmVudCBmaXJlcyB3aGVuIHRoZSB2YWx1ZSBoYXMgYmVlbiBjaGFuZ2VkIGFzIGEgZGlyZWN0IHJlc3VsdCBvZiBhIHVzZXIgYWN0aW9uLlxuICogQG92ZXJyaWRlVHlwZSB2YWx1ZSAtIChUID0gc3RyaW5nKSB8IG51bGxcbiAqL1xuZXhwb3J0IGNsYXNzIFNiYlJhZGlvQnV0dG9uRWxlbWVudDxUID0gc3RyaW5nPiBleHRlbmRzIFNiYlJhZGlvQnV0dG9uQ29tbW9uRWxlbWVudE1peGluKFxuICBTYmJFbGVtZW50LFxuKSB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgcmVhZG9ubHkgZWxlbWVudE5hbWU6IHN0cmluZyA9ICdzYmItcmFkaW8tYnV0dG9uJztcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gW1xuICAgIGJveFNpemluZ1N0eWxlcyxcbiAgICByYWRpb0J1dHRvbkNvbW1vblN0eWxlLFxuICAgIHJhZGlvQnV0dG9uU3R5bGUsXG4gIF07XG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgZXZlbnRzID0ge1xuICAgIGNoYW5nZTogJ2NoYW5nZScsXG4gICAgaW5wdXQ6ICdpbnB1dCcsXG4gIH0gYXMgY29uc3Q7XG5cbiAgLyoqXG4gICAqIFNpemUgdmFyaWFudCwgZWl0aGVyIHhzLCBzIG9yIG0uXG4gICAqIEBkZWZhdWx0ICdtJyAvICd4cycgKGxlYW4pXG4gICAqL1xuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIEBnZXRPdmVycmlkZSgoaSwgdikgPT4gaS5ncm91cD8uc2l6ZSA/PyB2KVxuICBwdWJsaWMgYWNjZXNzb3Igc2l6ZTogU2JiUmFkaW9CdXR0b25TaXplID0gaXNMZWFuKCkgPyAneHMnIDogJ20nO1xuXG4gIC8qKlxuICAgKiBUaGUgdmFsdWUgb2YgdGhlIGZvcm0gZWxlbWVudFxuICAgKi9cbiAgQHByb3BlcnR5KClcbiAgcHVibGljIGFjY2Vzc29yIHZhbHVlOiBUIHwgbnVsbCA9IG51bGw7XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgcmV0dXJuIGh0bWxgXG4gICAgICA8ZGl2IGNsYXNzPVwic2JiLXJhZGlvLWJ1dHRvblwiPlxuICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1yYWRpby1idXR0b25fX2xhYmVsLXNsb3RcIj5cbiAgICAgICAgICA8c2xvdD48L3Nsb3Q+XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgIDwvZGl2PlxuICAgIGA7XG4gIH1cbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi1yYWRpby1idXR0b24nOiBTYmJSYWRpb0J1dHRvbkVsZW1lbnQ7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lDd0JhLCtCQUFxQjttQkFBcUIsaUNBQ3JELFdBQ0Q7Ozs7Ozs7Y0FGWSw4QkFBMEMsWUFFdEQ7Ozt1QkFnQkUsU0FBUyxFQUFFLFNBQVMsTUFBTSxDQUFDLEVBQzNCLGFBQWEsR0FBRyxNQUFNLEVBQUUsT0FBTyxRQUFRLEVBQUUsQ0FBQTt3QkFNekMsVUFBVSxDQUFBO0FBTFgsZ0JBQUEsTUFBQSxNQUFBLGtCQUFBO0lBQUEsTUFBQTtJQUFBLE1BQUE7SUFBQSxRQUFBO0lBQUEsU0FBQTtJQUFBLFFBQUE7S0FBQSxNQUFBLFFBQUEsVUFBQTtLQUFBLE1BQUEsUUFBQSxJQUFnQjtLQUFJLE1BQUEsS0FBQSxVQUFBO0FBQUEsVUFBSixPQUFJOztLQUFBO0lBQUEsVUFBQTtJQUFBLEVBQUEsb0JBQUEsd0JBQUE7QUFNcEIsZ0JBQUEsTUFBQSxNQUFBLG1CQUFBO0lBQUEsTUFBQTtJQUFBLE1BQUE7SUFBQSxRQUFBO0lBQUEsU0FBQTtJQUFBLFFBQUE7S0FBQSxNQUFBLFFBQUEsV0FBQTtLQUFBLE1BQUEsUUFBQSxJQUFnQjtLQUFLLE1BQUEsS0FBQSxVQUFBO0FBQUEsVUFBTCxRQUFLOztLQUFBO0lBQUEsVUFBQTtJQUFBLEVBQUEscUJBQUEseUJBQUE7Ozs7Ozs7OztBQXZCVyxRQUFBLGNBQXNCOzs7QUFDL0IsUUFBQSxTQUF5QjtJQUM5QztJQUNBO0lBQ0E7SUFDRDs7O0FBQ3NCLFFBQUEsU0FBUztJQUM5QixRQUFRO0lBQ1IsT0FBTztJQUNDOztFQVFWLHlCQUFBLGtCQUFBLE1BQUEsb0JBQTJDLFFBQVEsR0FBRyxPQUFPLElBQUc7Ozs7O0VBQWhFLElBQWdCLE9BQUk7QUFBQSxVQUFBLE1BQUE7O0VBQXBCLElBQWdCLEtBQUksT0FBQTtBQUFBLFNBQUEsd0JBQUE7O0VBTXBCLDJCQUFBLGtCQUFBLE1BQUEsd0JBQUEsRUFBQSxrQkFBQSxNQUFBLHFCQUFrQyxLQUFJOzs7O0VBQXRDLElBQWdCLFFBQUs7QUFBQSxVQUFBLE1BQUE7O0VBQXJCLElBQWdCLE1BQUssT0FBQTtBQUFBLFNBQUEseUJBQUE7O0VBRUYsU0FBTTtBQUN2QixVQUFPLElBQUkifQ==
@@ -2,8 +2,8 @@ import { SbbRadioButtonGroupElement } from "./radio-button-group/radio-button-gr
2
2
  import "./radio-button-group.pure.js";
3
3
  import { SbbRadioButtonPanelElement } from "./radio-button-panel/radio-button-panel.component.js";
4
4
  import "./radio-button-panel.pure.js";
5
- import { n as radio_button_common_default, t as SbbRadioButtonCommonElementMixin } from "./radio-button-common-CsjMvmAn.js";
6
- import { t as SbbRadioButtonElement } from "./radio-button.component-BTnHGixs.js";
5
+ import { n as radio_button_common_default, t as SbbRadioButtonCommonElementMixin } from "./radio-button-common-CCrvhOPQ.js";
6
+ import { t as SbbRadioButtonElement } from "./radio-button.component-DYD1hVIZ.js";
7
7
  import "./radio-button.pure.js";
8
8
  //#region src/elements/radio-button.ts
9
9
  /** @entrypoint */
@@ -1,3 +1,3 @@
1
- import { n as radio_button_common_default, t as SbbRadioButtonCommonElementMixin } from "./radio-button-common-CsjMvmAn.js";
2
- import { t as SbbRadioButtonElement } from "./radio-button.component-BTnHGixs.js";
1
+ import { n as radio_button_common_default, t as SbbRadioButtonCommonElementMixin } from "./radio-button-common-CCrvhOPQ.js";
2
+ import { t as SbbRadioButtonElement } from "./radio-button.component-DYD1hVIZ.js";
3
3
  export { SbbRadioButtonCommonElementMixin, SbbRadioButtonElement, radio_button_common_default as radioButtonCommonStyle };
package/package.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-dev",
3
- "version": "4.8.1-dev.1774268427",
3
+ "version": "4.8.1-dev.1774270807",
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/e24f6c255bc7cea07dcb4482dd6436f41f61c147"
9
+ "https://github.com/sbb-design-systems/lyne-components/commit/600dc27e36fd41e13c778fab662c373247d76f07"
10
10
  ],
11
11
  "type": "module",
12
12
  "exports": {
@@ -1,2 +1,2 @@
1
- import { n as e, t } from "../../radio-button-common-DH6R3gcn.js";
1
+ import { n as e, t } from "../../radio-button-common-Ch3i83Qb.js";
2
2
  export { t as SbbRadioButtonCommonElementMixin, e as radioButtonCommonStyle };
@@ -1,4 +1,4 @@
1
- import { n as e, t } from "../radio-button-common-DH6R3gcn.js";
1
+ import { n as e, t } from "../radio-button-common-Ch3i83Qb.js";
2
2
  //#region src/elements/radio-button/common.ts
3
3
  console.warn("The entrypoint '@sbb-esta/elements/radio-button/common.js' has been deprecated.\nUse either '@sbb-esta/elements/radio-button.js' or '@sbb-esta/elements/radio-button.pure.js' instead.");
4
4
  //#endregion
@@ -1,3 +1,3 @@
1
- import "../radio-button-common-DH6R3gcn.js";
2
- import { t as e } from "../radio-button.component-C32GSr_0.js";
1
+ import "../radio-button-common-Ch3i83Qb.js";
2
+ import { t as e } from "../radio-button.component-BGIJJyFd.js";
3
3
  export { e as SbbRadioButtonElement };
@@ -1,5 +1,5 @@
1
- import "../radio-button-common-DH6R3gcn.js";
2
- import { t as e } from "../radio-button.component-C32GSr_0.js";
1
+ import "../radio-button-common-Ch3i83Qb.js";
2
+ import { t as e } from "../radio-button.component-BGIJJyFd.js";
3
3
  e.define(), console.warn("The entrypoint '@sbb-esta/elements/radio-button/radio-button.js' has been deprecated.\nUse either '@sbb-esta/elements/radio-button.js' or '@sbb-esta/elements/radio-button.pure.js' instead.");
4
4
  //#endregion
5
5
  export { e as SbbRadioButtonElement };
@@ -59,6 +59,9 @@ var a = n`:host{--sbb-radio-button-inner-circle-color: var(--sbb-radio-button-ba
59
59
  select() {
60
60
  this.disabled || this.formDisabled || (this.allowEmptySelection ? (this.checked = !this.checked, this.emitChangeEvents()) : this.checked || (this.checked = !0, this.emitChangeEvents()));
61
61
  }
62
+ willUpdate(e) {
63
+ super.willUpdate(e), e.has("value") && this.dispatchEvent(new Event("ɵradiobuttonvaluechange", { bubbles: !0 }));
64
+ }
62
65
  isDisabledExternally() {
63
66
  return this.group?.disabled ?? !1;
64
67
  }
@@ -99,7 +99,7 @@ var a = 0, o = (() => {
99
99
  return this.selectionElements;
100
100
  }
101
101
  constructor() {
102
- super(), this.selectionElementSelectors = (t(this, s), "sbb-radio-button, sbb-radio-button-panel"), this.panelElementSelector = "sbb-radio-button-panel", this.#e = t(this, l, !1), this._fallbackValue = (t(this, u), null), this.#t = t(this, p, `sbb-radio-button-group-${++a}`), t(this, m), this.addEventListener?.("change", (e) => this._onRadioChange(e));
102
+ super(), this.selectionElementSelectors = (t(this, s), "sbb-radio-button, sbb-radio-button-panel"), this.panelElementSelector = "sbb-radio-button-panel", this.#e = t(this, l, !1), this._fallbackValue = (t(this, u), null), this.#t = t(this, p, `sbb-radio-button-group-${++a}`), t(this, m), this.addEventListener?.("change", (e) => this._onRadioChange(e)), this.addEventListener?.("ɵradiobuttonvaluechange", () => this._updateRadioState());
103
103
  }
104
104
  willUpdate(e) {
105
105
  super.willUpdate(e), e.has("name") && this._updateRadiosName();
@@ -1,4 +1,4 @@
1
- import { n as e, t } from "./radio-button-common-DH6R3gcn.js";
1
+ import { n as e, t } from "./radio-button-common-Ch3i83Qb.js";
2
2
  import { __esDecorate as n, __runInitializers as r } from "tslib";
3
3
  import { css as i, html as a } from "lit";
4
4
  import { property as o } from "lit/decorators.js";
package/radio-button.js CHANGED
@@ -2,8 +2,8 @@ import { SbbRadioButtonGroupElement as e } from "./radio-button-group/radio-butt
2
2
  import "./radio-button-group.pure.js";
3
3
  import { SbbRadioButtonPanelElement as t } from "./radio-button-panel/radio-button-panel.component.js";
4
4
  import "./radio-button-panel.pure.js";
5
- import { n, t as r } from "./radio-button-common-DH6R3gcn.js";
6
- import { t as i } from "./radio-button.component-C32GSr_0.js";
5
+ import { n, t as r } from "./radio-button-common-Ch3i83Qb.js";
6
+ import { t as i } from "./radio-button.component-BGIJJyFd.js";
7
7
  import "./radio-button.pure.js";
8
8
  i.define(), e.define(), t.define();
9
9
  //#endregion
@@ -1,3 +1,3 @@
1
- import { n as e, t } from "./radio-button-common-DH6R3gcn.js";
2
- import { t as n } from "./radio-button.component-C32GSr_0.js";
1
+ import { n as e, t } from "./radio-button-common-Ch3i83Qb.js";
2
+ import { t as n } from "./radio-button.component-BGIJJyFd.js";
3
3
  export { t as SbbRadioButtonCommonElementMixin, n as SbbRadioButtonElement, e as radioButtonCommonStyle };