@sbb-esta/lyne-elements 2.0.2 → 2.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (26) hide show
  1. package/core/mixins/form-associated-mixin.d.ts +2 -4
  2. package/core/mixins/form-associated-mixin.d.ts.map +1 -1
  3. package/core/mixins/form-associated-radio-button-mixin.d.ts +3 -3
  4. package/core/mixins/form-associated-radio-button-mixin.d.ts.map +1 -1
  5. package/core/mixins.js +276 -276
  6. package/custom-elements.json +164 -126
  7. package/development/core/mixins/form-associated-mixin.d.ts +2 -4
  8. package/development/core/mixins/form-associated-mixin.d.ts.map +1 -1
  9. package/development/core/mixins/form-associated-radio-button-mixin.d.ts +3 -3
  10. package/development/core/mixins/form-associated-radio-button-mixin.d.ts.map +1 -1
  11. package/development/core/mixins.js +45 -49
  12. package/development/radio-button/common/radio-button-common.d.ts +0 -2
  13. package/development/radio-button/common/radio-button-common.d.ts.map +1 -1
  14. package/development/radio-button/common.js +2 -18
  15. package/development/radio-button/radio-button-group.js +2 -2
  16. package/development/radio-button/radio-button-panel/radio-button-panel.d.ts +9 -1
  17. package/development/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -1
  18. package/development/radio-button/radio-button-panel.js +17 -7
  19. package/package.json +1 -1
  20. package/radio-button/common/radio-button-common.d.ts +0 -2
  21. package/radio-button/common/radio-button-common.d.ts.map +1 -1
  22. package/radio-button/common.js +13 -18
  23. package/radio-button/radio-button-group.js +1 -1
  24. package/radio-button/radio-button-panel/radio-button-panel.d.ts +9 -1
  25. package/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -1
  26. package/radio-button/radio-button-panel.js +40 -38
@@ -1,7 +1,6 @@
1
1
  import { __esDecorate, __runInitializers } from "tslib";
2
2
  import { property } from "lit/decorators.js";
3
3
  import { setModalityOnNextFocus } from "../core/a11y.js";
4
- import { EventEmitter } from "../core/eventing.js";
5
4
  import { SbbFormAssociatedRadioButtonMixin } from "../core/mixins.js";
6
5
  import { css } from "lit";
7
6
  const SbbRadioButtonCommonElementMixin = (superClass) => {
@@ -32,7 +31,6 @@ const SbbRadioButtonCommonElementMixin = (superClass) => {
32
31
  super();
33
32
  this._allowEmptySelection = (__runInitializers(this, _instanceExtraInitializers), false);
34
33
  this._group = null;
35
- this._stateChange = new EventEmitter(this, _a.events.stateChange, { bubbles: true });
36
34
  (_a2 = this.addEventListener) == null ? void 0 : _a2.call(this, "click", (e) => this._handleClick(e));
37
35
  (_b = this.addEventListener) == null ? void 0 : _b.call(this, "keydown", (e) => this._handleKeyDown(e));
38
36
  }
@@ -57,19 +55,6 @@ const SbbRadioButtonCommonElementMixin = (superClass) => {
57
55
  this.emitChangeEvents();
58
56
  }
59
57
  }
60
- willUpdate(changedProperties) {
61
- super.willUpdate(changedProperties);
62
- if (changedProperties.has("checked")) {
63
- if (this.checked !== changedProperties.get("checked")) {
64
- this._stateChange.emit({ type: "checked", checked: this.checked });
65
- }
66
- }
67
- if (changedProperties.has("disabled")) {
68
- if (this.disabled !== changedProperties.get("disabled")) {
69
- this._stateChange.emit({ type: "disabled", disabled: this.disabled });
70
- }
71
- }
72
- }
73
58
  isDisabledExternally() {
74
59
  var _a2;
75
60
  return ((_a2 = this.group) == null ? void 0 : _a2.disabled) ?? false;
@@ -100,8 +85,7 @@ const SbbRadioButtonCommonElementMixin = (superClass) => {
100
85
  if (_metadata) Object.defineProperty(_a, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
101
86
  })(), _a.events = {
102
87
  change: "change",
103
- input: "input",
104
- stateChange: "stateChange"
88
+ input: "input"
105
89
  }, _a;
106
90
  })();
107
91
  return SbbRadioButtonCommonElement;
@@ -244,4 +228,4 @@ export {
244
228
  SbbRadioButtonCommonElementMixin,
245
229
  radioButtonCommon as radioButtonCommonStyle
246
230
  };
247
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"common.js","sources":["../../../../src/elements/radio-button/common/radio-button-common.ts"],"sourcesContent":["import type { LitElement, PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { setModalityOnNextFocus } from '../../core/a11y.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport type {\n  SbbCheckedStateChange,\n  SbbDisabledStateChange,\n  SbbStateChange,\n} from '../../core/interfaces.js';\nimport {\n  type AbstractConstructor,\n  type Constructor,\n  SbbFormAssociatedRadioButtonMixin,\n  type SbbFormAssociatedRadioButtonMixinType,\n} from '../../core/mixins.js';\nimport type { SbbRadioButtonGroupElement } from '../radio-button-group.js';\n\nexport type SbbRadioButtonSize = 'xs' | 's' | 'm';\n\nexport type SbbRadioButtonStateChange = Extract<\n  SbbStateChange,\n  SbbDisabledStateChange | SbbCheckedStateChange\n>;\n\nexport declare class SbbRadioButtonCommonElementMixinType extends SbbFormAssociatedRadioButtonMixinType {\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<LitElement>>(\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      stateChange: 'stateChange',\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    /**\n     * @internal\n     * Internal event that emits whenever the state of the radio option\n     * in relation to the parent selection panel changes.\n     */\n    private _stateChange: EventEmitter<SbbRadioButtonStateChange> = new EventEmitter(\n      this,\n      SbbRadioButtonCommonElement.events.stateChange,\n      { bubbles: true },\n    );\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('checked')) {\n        if (this.checked !== changedProperties.get('checked')!) {\n          this._stateChange.emit({ type: 'checked', checked: this.checked });\n        }\n      }\n      if (changedProperties.has('disabled')) {\n        if (this.disabled !== changedProperties.get('disabled')!) {\n          this._stateChange.emit({ type: 'disabled', disabled: this.disabled });\n        }\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      setModalityOnNextFocus(this);\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"],"names":["_a","SbbRadioButtonCommonElement"],"mappings":";;;;;;AAiCa,MAAA,mCAAmC,CAC9C,eACiE;MAClD,+BAA2B,MAAA;;sBAChC,kCAAkC,UAAU;;;AADvC,WAAA,mBACL,YAA6C;AAAA;AAAA;AAAA;AAAA,MAarD,IAAW,oBAAoB,OAAc;AACtC,aAAA,uBAAuB,QAAQ,KAAK;AAAA,MAAA;AAAA,MAE3C,IAAW,sBAAmB;;AAC5B,eAAO,KAAK,2BAAyBA,MAAA,KAAK,UAAL,gBAAAA,IAAY,wBAAuB;AAAA,MAAA;AAAA;AAAA;AAAA;AAAA,MAO1E,IAAW,QAAK;AACd,eAAO,KAAK;AAAA,MAAA;AAAA,MAed,cAAA;;;AArBQ,aAAA,wBApBK,kBAAA,MAAA,0BAAA,GAoBkB;AAQvB,aAAM,SAAsC;AAO5C,aAAA,eAAwD,IAAI,aAClE,MACAC,GAA4B,OAAO,aACnC,EAAE,SAAS,MAAM;AAKjB,SAAAD,MAAA,KAAK,qBAAL,gBAAAA,IAAA,WAAwB,SAAS,CAAC,MAAM,KAAK,aAAa,CAAC;AAC3D,mBAAK,qBAAL,8BAAwB,WAAW,CAAC,MAAM,KAAK,eAAe,CAAC;AAAA,MAAC;AAAA,MAGlD,oBAAiB;AAC/B,cAAM,kBAAiB;AAClB,aAAA,SAAS,KAAK,QAAQ,wBAAwB;AAGlD,SAAA,YAAY,YAAY,MAAM,EAAE,QAAQ,CAAC,MAAM,KAAK,cAAc,CAAC,CAAC;AAAA,MAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAOhE,SAAM;AACP,YAAA,KAAK,YAAY,KAAK,cAAc;AACtC;AAAA,QAAA;AAGF,YAAI,KAAK,qBAAqB;AACvB,eAAA,UAAU,CAAC,KAAK;AACrB,eAAK,iBAAgB;AAAA,QAAA,WACZ,CAAC,KAAK,SAAS;AACxB,eAAK,UAAU;AACf,eAAK,iBAAgB;AAAA,QAAA;AAAA,MACvB;AAAA,MAGiB,WAAW,mBAAuC;AACnE,cAAM,WAAW,iBAAiB;AAE9B,YAAA,kBAAkB,IAAI,SAAS,GAAG;AACpC,cAAI,KAAK,YAAY,kBAAkB,IAAI,SAAS,GAAI;AACjD,iBAAA,aAAa,KAAK,EAAE,MAAM,WAAW,SAAS,KAAK,SAAS;AAAA,UAAA;AAAA,QACnE;AAEE,YAAA,kBAAkB,IAAI,UAAU,GAAG;AACrC,cAAI,KAAK,aAAa,kBAAkB,IAAI,UAAU,GAAI;AACnD,iBAAA,aAAa,KAAK,EAAE,MAAM,YAAY,UAAU,KAAK,UAAU;AAAA,UAAA;AAAA,QACtE;AAAA,MACF;AAAA,MAGiB,uBAAoB;;AAC9B,iBAAAA,MAAA,KAAK,UAAL,gBAAAA,IAAY,aAAY;AAAA,MAAA;AAAA,MAGd,uBAAoB;;AAC9B,iBAAAA,MAAA,KAAK,UAAL,gBAAAA,IAAY,aAAY;AAAA,MAAA;AAAA,MAGzB,MAAM,aAAa,OAAY;AACrC,cAAM,eAAc;AACpB,aAAK,OAAM;AAMX,cAAM,KAAK;AACX,+BAAuB,IAAI;AAC3B,aAAK,MAAK;AAAA,MAAA;AAAA,MAGJ,eAAe,KAAkB;AACnC,YAAA,IAAI,SAAS,SAAS;AACxB,cAAI,eAAc;AAClB,eAAK,OAAM;AAAA,QAAA;AAAA,MACb;AAAA;;6CApGD,SAAS,EAAE,WAAW,yBAAyB,MAAM,QAAA,CAAS,CAAC;AAChE,mBAAA,IAAA,MAAA,qCAAA,EAAA,MAAA,UAAA,MAAA,uBAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,yBAAA,KAAA,KAAA,CAAA,KAAA,UAAA;AAAA,YAAW,sBAEV;AAAA,WAAA,UAAA,aAAA,MAAA,0BAAA;;UAZsB,GAAA,SAAS;AAAA,MAC9B,QAAQ;AAAA,MACR,OAAO;AAAA,MACP,aAAa;AAAA,IACL,GARG;AAAA;AAqHR,SAAA;AAET;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
231
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMvcmFkaW8tYnV0dG9uL2NvbW1vbi9yYWRpby1idXR0b24tY29tbW9uLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgTGl0RWxlbWVudCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBwcm9wZXJ0eSB9IGZyb20gJ2xpdC9kZWNvcmF0b3JzLmpzJztcblxuaW1wb3J0IHsgc2V0TW9kYWxpdHlPbk5leHRGb2N1cyB9IGZyb20gJy4uLy4uL2NvcmUvYTExeS5qcyc7XG5pbXBvcnQge1xuICB0eXBlIEFic3RyYWN0Q29uc3RydWN0b3IsXG4gIHR5cGUgQ29uc3RydWN0b3IsXG4gIFNiYkZvcm1Bc3NvY2lhdGVkUmFkaW9CdXR0b25NaXhpbixcbiAgdHlwZSBTYmJGb3JtQXNzb2NpYXRlZFJhZGlvQnV0dG9uTWl4aW5UeXBlLFxufSBmcm9tICcuLi8uLi9jb3JlL21peGlucy5qcyc7XG5pbXBvcnQgdHlwZSB7IFNiYlJhZGlvQnV0dG9uR3JvdXBFbGVtZW50IH0gZnJvbSAnLi4vcmFkaW8tYnV0dG9uLWdyb3VwLmpzJztcblxuZXhwb3J0IHR5cGUgU2JiUmFkaW9CdXR0b25TaXplID0gJ3hzJyB8ICdzJyB8ICdtJztcblxuZXhwb3J0IGRlY2xhcmUgY2xhc3MgU2JiUmFkaW9CdXR0b25Db21tb25FbGVtZW50TWl4aW5UeXBlIGV4dGVuZHMgU2JiRm9ybUFzc29jaWF0ZWRSYWRpb0J1dHRvbk1peGluVHlwZSB7XG4gIHB1YmxpYyBnZXQgYWxsb3dFbXB0eVNlbGVjdGlvbigpOiBib29sZWFuO1xuICBwdWJsaWMgc2V0IGFsbG93RW1wdHlTZWxlY3Rpb24oYm9vbGVhbik7XG4gIHB1YmxpYyBnZXQgZ3JvdXAoKTogU2JiUmFkaW9CdXR0b25Hcm91cEVsZW1lbnQgfCBudWxsO1xuICBwdWJsaWMgc2VsZWN0KCk6IHZvaWQ7XG59XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbmV4cG9ydCBjb25zdCBTYmJSYWRpb0J1dHRvbkNvbW1vbkVsZW1lbnRNaXhpbiA9IDxUIGV4dGVuZHMgQ29uc3RydWN0b3I8TGl0RWxlbWVudD4+KFxuICBzdXBlckNsYXNzOiBULFxuKTogQWJzdHJhY3RDb25zdHJ1Y3RvcjxTYmJSYWRpb0J1dHRvbkNvbW1vbkVsZW1lbnRNaXhpblR5cGU+ICYgVCA9PiB7XG4gIGFic3RyYWN0IGNsYXNzIFNiYlJhZGlvQnV0dG9uQ29tbW9uRWxlbWVudFxuICAgIGV4dGVuZHMgU2JiRm9ybUFzc29jaWF0ZWRSYWRpb0J1dHRvbk1peGluKHN1cGVyQ2xhc3MpXG4gICAgaW1wbGVtZW50cyBQYXJ0aWFsPFNiYlJhZGlvQnV0dG9uQ29tbW9uRWxlbWVudE1peGluVHlwZT5cbiAge1xuICAgIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgZXZlbnRzID0ge1xuICAgICAgY2hhbmdlOiAnY2hhbmdlJyxcbiAgICAgIGlucHV0OiAnaW5wdXQnLFxuICAgIH0gYXMgY29uc3Q7XG5cbiAgICAvKipcbiAgICAgKiBXaGV0aGVyIHRoZSByYWRpbyBjYW4gYmUgZGVzZWxlY3RlZC5cbiAgICAgKi9cbiAgICBAcHJvcGVydHkoeyBhdHRyaWJ1dGU6ICdhbGxvdy1lbXB0eS1zZWxlY3Rpb24nLCB0eXBlOiBCb29sZWFuIH0pXG4gICAgcHVibGljIHNldCBhbGxvd0VtcHR5U2VsZWN0aW9uKHZhbHVlOiBib29sZWFuKSB7XG4gICAgICB0aGlzLl9hbGxvd0VtcHR5U2VsZWN0aW9uID0gQm9vbGVhbih2YWx1ZSk7XG4gICAgfVxuICAgIHB1YmxpYyBnZXQgYWxsb3dFbXB0eVNlbGVjdGlvbigpOiBib29sZWFuIHtcbiAgICAgIHJldHVybiB0aGlzLl9hbGxvd0VtcHR5U2VsZWN0aW9uIHx8ICh0aGlzLmdyb3VwPy5hbGxvd0VtcHR5U2VsZWN0aW9uID8/IGZhbHNlKTtcbiAgICB9XG4gICAgcHJpdmF0ZSBfYWxsb3dFbXB0eVNlbGVjdGlvbiA9IGZhbHNlO1xuXG4gICAgLyoqXG4gICAgICogUmVmZXJlbmNlIHRvIHRoZSBjb25uZWN0ZWQgcmFkaW8gYnV0dG9uIGdyb3VwLlxuICAgICAqL1xuICAgIHB1YmxpYyBnZXQgZ3JvdXAoKTogU2JiUmFkaW9CdXR0b25Hcm91cEVsZW1lbnQgfCBudWxsIHtcbiAgICAgIHJldHVybiB0aGlzLl9ncm91cDtcbiAgICB9XG4gICAgcHJpdmF0ZSBfZ3JvdXA6IFNiYlJhZGlvQnV0dG9uR3JvdXBFbGVtZW50IHwgbnVsbCA9IG51bGw7XG5cbiAgICBwdWJsaWMgY29uc3RydWN0b3IoKSB7XG4gICAgICBzdXBlcigpO1xuICAgICAgdGhpcy5hZGRFdmVudExpc3RlbmVyPy4oJ2NsaWNrJywgKGUpID0+IHRoaXMuX2hhbmRsZUNsaWNrKGUpKTtcbiAgICAgIHRoaXMuYWRkRXZlbnRMaXN0ZW5lcj8uKCdrZXlkb3duJywgKGUpID0+IHRoaXMuX2hhbmRsZUtleURvd24oZSkpO1xuICAgIH1cblxuICAgIHB1YmxpYyBvdmVycmlkZSBjb25uZWN0ZWRDYWxsYmFjaygpOiB2b2lkIHtcbiAgICAgIHN1cGVyLmNvbm5lY3RlZENhbGxiYWNrKCk7XG4gICAgICB0aGlzLl9ncm91cCA9IHRoaXMuY2xvc2VzdCgnc2JiLXJhZGlvLWJ1dHRvbi1ncm91cCcpIGFzIFNiYlJhZGlvQnV0dG9uR3JvdXBFbGVtZW50O1xuXG4gICAgICAvLyBXZSBuZWVkIHRvIGNhbGwgcmVxdWVzdFVwZGF0ZSB0byB1cGRhdGUgdGhlIHJlZmxlY3RlZCBhdHRyaWJ1dGVzXG4gICAgICBbJ2Rpc2FibGVkJywgJ3JlcXVpcmVkJywgJ3NpemUnXS5mb3JFYWNoKChwKSA9PiB0aGlzLnJlcXVlc3RVcGRhdGUocCkpO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFNldCB0aGUgcmFkaW8tYnV0dG9uIGFzICdjaGVja2VkJzsgaWYgJ2FsbG93RW1wdHlTZWxlY3Rpb24nLCB0b2dnbGUgdGhlIGNoZWNrZWQgcHJvcGVydHkuXG4gICAgICogSW4gYm90aCBjYXNlcyBpdCBlbWl0cyB0aGUgY2hhbmdlIGV2ZW50cy5cbiAgICAgKi9cbiAgICBwdWJsaWMgc2VsZWN0KCk6IHZvaWQge1xuICAgICAgaWYgKHRoaXMuZGlzYWJsZWQgfHwgdGhpcy5mb3JtRGlzYWJsZWQpIHtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuXG4gICAgICBpZiAodGhpcy5hbGxvd0VtcHR5U2VsZWN0aW9uKSB7XG4gICAgICAgIHRoaXMuY2hlY2tlZCA9ICF0aGlzLmNoZWNrZWQ7XG4gICAgICAgIHRoaXMuZW1pdENoYW5nZUV2ZW50cygpO1xuICAgICAgfSBlbHNlIGlmICghdGhpcy5jaGVja2VkKSB7XG4gICAgICAgIHRoaXMuY2hlY2tlZCA9IHRydWU7XG4gICAgICAgIHRoaXMuZW1pdENoYW5nZUV2ZW50cygpO1xuICAgICAgfVxuICAgIH1cblxuICAgIHByb3RlY3RlZCBvdmVycmlkZSBpc0Rpc2FibGVkRXh0ZXJuYWxseSgpOiBib29sZWFuIHtcbiAgICAgIHJldHVybiB0aGlzLmdyb3VwPy5kaXNhYmxlZCA/PyBmYWxzZTtcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgb3ZlcnJpZGUgaXNSZXF1aXJlZEV4dGVybmFsbHkoKTogYm9vbGVhbiB7XG4gICAgICByZXR1cm4gdGhpcy5ncm91cD8ucmVxdWlyZWQgPz8gZmFsc2U7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBhc3luYyBfaGFuZGxlQ2xpY2soZXZlbnQ6IEV2ZW50KTogUHJvbWlzZTx2b2lkPiB7XG4gICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgdGhpcy5zZWxlY3QoKTtcblxuICAgICAgLyoqXG4gICAgICAgKiBTaW5jZSBvbmx5IGEgc2luZ2xlIHJhZGlvIG9mIGEgZ3JvdXAgaXMgZm9jdXNhYmxlIGF0IGFueSB0aW1lLCBpdCBpcyBwb3NzaWJsZSB0aGF0IHRoZSBvbmUgY2xpY2tlZCBkb2VzIG5vdCBoYXZlICd0YWJpbmRleD0wJy5cbiAgICAgICAqIFRvIGNvdmVyIHRoYXQsIHdlIGF3YWl0IHRoZSBuZXh0IHJlbmRlciAod2hpY2ggd2lsbCBtYWtlIHRoZSAnY2hlY2tlZCcgcmFkaW8gZm9jdXNhYmxlKSBhbmQgZm9jdXMgdGhlIGNsaWNrZWQgcmFkaW9cbiAgICAgICAqL1xuICAgICAgYXdhaXQgdGhpcy51cGRhdGVDb21wbGV0ZTsgLy8gV2FpdCBmb3IgJ3RhYmluZGV4JyB0byBiZSB1cGRhdGVkXG4gICAgICBzZXRNb2RhbGl0eU9uTmV4dEZvY3VzKHRoaXMpO1xuICAgICAgdGhpcy5mb2N1cygpO1xuICAgIH1cblxuICAgIHByaXZhdGUgX2hhbmRsZUtleURvd24oZXZ0OiBLZXlib2FyZEV2ZW50KTogdm9pZCB7XG4gICAgICBpZiAoZXZ0LmNvZGUgPT09ICdTcGFjZScpIHtcbiAgICAgICAgZXZ0LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgIHRoaXMuc2VsZWN0KCk7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIFNiYlJhZGlvQnV0dG9uQ29tbW9uRWxlbWVudCBhcyB1bmtub3duIGFzIEFic3RyYWN0Q29uc3RydWN0b3I8U2JiUmFkaW9CdXR0b25Db21tb25FbGVtZW50TWl4aW5UeXBlPiAmXG4gICAgVDtcbn07XG4iXSwibmFtZXMiOlsiX2EiXSwibWFwcGluZ3MiOiI7Ozs7O0FBc0JhLE1BQUEsbUNBQW1DLENBQzlDLGVBQ2lFO01BQ2xELCtCQUEyQixNQUFBOztzQkFDaEMsa0NBQWtDLFVBQVU7OztBQUR2QyxXQUFBLG1CQUNMLFlBQTZDO0FBQUE7QUFBQTtBQUFBO0FBQUEsTUFZckQsSUFBVyxvQkFBb0IsT0FBYztBQUN0QyxhQUFBLHVCQUF1QixRQUFRLEtBQUs7QUFBQSxNQUFBO0FBQUEsTUFFM0MsSUFBVyxzQkFBbUI7O0FBQzVCLGVBQU8sS0FBSywyQkFBeUJBLE1BQUEsS0FBSyxVQUFMLGdCQUFBQSxJQUFZLHdCQUF1QjtBQUFBLE1BQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxNQU8xRSxJQUFXLFFBQUs7QUFDZCxlQUFPLEtBQUs7QUFBQSxNQUFBO0FBQUEsTUFJZCxjQUFBOzs7QUFWUSxhQUFBLHdCQW5CSyxrQkFBQSxNQUFBLDBCQUFBLEdBbUJrQjtBQVF2QixhQUFNLFNBQXNDO0FBSWxELFNBQUFBLE1BQUEsS0FBSyxxQkFBTCxnQkFBQUEsSUFBQSxXQUF3QixTQUFTLENBQUMsTUFBTSxLQUFLLGFBQWEsQ0FBQztBQUMzRCxtQkFBSyxxQkFBTCw4QkFBd0IsV0FBVyxDQUFDLE1BQU0sS0FBSyxlQUFlLENBQUM7QUFBQSxNQUFDO0FBQUEsTUFHbEQsb0JBQWlCO0FBQy9CLGNBQU0sa0JBQWlCO0FBQ2xCLGFBQUEsU0FBUyxLQUFLLFFBQVEsd0JBQXdCO0FBR2xELFNBQUEsWUFBWSxZQUFZLE1BQU0sRUFBRSxRQUFRLENBQUMsTUFBTSxLQUFLLGNBQWMsQ0FBQyxDQUFDO0FBQUEsTUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsTUFPaEUsU0FBTTtBQUNQLFlBQUEsS0FBSyxZQUFZLEtBQUssY0FBYztBQUN0QztBQUFBLFFBQUE7QUFHRixZQUFJLEtBQUsscUJBQXFCO0FBQ3ZCLGVBQUEsVUFBVSxDQUFDLEtBQUs7QUFDckIsZUFBSyxpQkFBZ0I7QUFBQSxRQUFBLFdBQ1osQ0FBQyxLQUFLLFNBQVM7QUFDeEIsZUFBSyxVQUFVO0FBQ2YsZUFBSyxpQkFBZ0I7QUFBQSxRQUFBO0FBQUEsTUFDdkI7QUFBQSxNQUdpQix1QkFBb0I7O0FBQzlCLGlCQUFBQSxNQUFBLEtBQUssVUFBTCxnQkFBQUEsSUFBWSxhQUFZO0FBQUEsTUFBQTtBQUFBLE1BR2QsdUJBQW9COztBQUM5QixpQkFBQUEsTUFBQSxLQUFLLFVBQUwsZ0JBQUFBLElBQVksYUFBWTtBQUFBLE1BQUE7QUFBQSxNQUd6QixNQUFNLGFBQWEsT0FBWTtBQUNyQyxjQUFNLGVBQWM7QUFDcEIsYUFBSyxPQUFNO0FBTVgsY0FBTSxLQUFLO0FBQ1gsK0JBQXVCLElBQUk7QUFDM0IsYUFBSyxNQUFLO0FBQUEsTUFBQTtBQUFBLE1BR0osZUFBZSxLQUFrQjtBQUNuQyxZQUFBLElBQUksU0FBUyxTQUFTO0FBQ3hCLGNBQUksZUFBYztBQUNsQixlQUFLLE9BQU07QUFBQSxRQUFBO0FBQUEsTUFDYjtBQUFBOzs2Q0ExRUQsU0FBUyxFQUFFLFdBQVcseUJBQXlCLE1BQU0sUUFBQSxDQUFTLENBQUM7QUFDaEUsbUJBQUEsSUFBQSxNQUFBLHFDQUFBLEVBQUEsTUFBQSxVQUFBLE1BQUEsdUJBQUEsUUFBQSxPQUFBLFNBQUEsT0FBQSxRQUFBLEVBQUEsS0FBQSxDQUFBLFFBQUEseUJBQUEsS0FBQSxLQUFBLENBQUEsS0FBQSxVQUFBO0FBQUEsWUFBVyxzQkFFVjtBQUFBLFdBQUEsVUFBQSxhQUFBLE1BQUEsMEJBQUE7O1VBWHNCLEdBQUEsU0FBUztBQUFBLE1BQzlCLFFBQVE7QUFBQSxNQUNSLE9BQU87QUFBQSxJQUNDLEdBUEc7QUFBQTtBQTBGUixTQUFBO0FBRVQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OzsifQ==
@@ -213,7 +213,7 @@ let SbbRadioButtonGroupElement = (() => {
213
213
  if (!this._didLoad) {
214
214
  return;
215
215
  }
216
- if (!val) {
216
+ if (val == null) {
217
217
  this.radioButtons.forEach((r) => r.checked = false);
218
218
  return;
219
219
  }
@@ -386,4 +386,4 @@ let SbbRadioButtonGroupElement = (() => {
386
386
  export {
387
387
  SbbRadioButtonGroupElement
388
388
  };
389
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"radio-button-group.js","sources":["../../../../src/elements/radio-button/radio-button-group/radio-button-group.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { LitElement, html } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { forceType, hostAttributes, slotState } from '../../core/decorators.js';\nimport { isLean } from '../../core/dom.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport type { SbbHorizontalFrom, SbbOrientation } from '../../core/interfaces.js';\nimport { SbbDisabledMixin } from '../../core/mixins.js';\nimport type { SbbRadioButtonSize } from '../common.js';\nimport type { SbbRadioButtonPanelElement } from '../radio-button-panel.js';\nimport type { SbbRadioButtonElement } from '../radio-button.js';\n\nimport style from './radio-button-group.scss?lit&inline';\n\nlet nextId = 0;\n\n/**\n * It can be used as a container for one or more `sbb-radio-button`.\n *\n * @slot - Use the unnamed slot to add `sbb-radio-button` elements to the `sbb-radio-button-group`.\n * @slot error - Use this to provide a `sbb-form-error` to show an error message.\n * @event {CustomEvent<void>} didChange - Deprecated. Only used for React. Will probably be removed once React 19 is available. Emits whenever the `sbb-radio-group` value changes.\n */\nexport\n@customElement('sbb-radio-button-group')\n@hostAttributes({\n  role: 'radiogroup',\n})\n@slotState()\nclass SbbRadioButtonGroupElement extends SbbDisabledMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    didChange: 'didChange',\n    change: 'change',\n    input: 'input',\n  } as const;\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   * Whether the radio group is required.\n   */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor required: boolean = false;\n\n  /**\n   * The value of the radio group.\n   */\n  @property()\n  public set value(val: string | null) {\n    this._fallbackValue = val;\n    if (!this._didLoad) {\n      return;\n    }\n    if (!val) {\n      this.radioButtons.forEach((r) => (r.checked = false));\n      return;\n    }\n    const toCheck = this.radioButtons.find((r) => r.value === val);\n    if (toCheck) {\n      toCheck.checked = true;\n    }\n  }\n  public get value(): string | null {\n    return this.radioButtons.find((r) => r.checked && !r.disabled)?.value ?? this._fallbackValue;\n  }\n  /**\n   * Used to preserve the `value` in case the radios are not yet 'loaded'\n   */\n  private _fallbackValue: string | null = null;\n\n  /**\n   * Size variant, either xs, s or m.\n   * @default 'm' / 'xs' (lean)\n   */\n  @property() public accessor size: SbbRadioButtonSize = isLean() ? 'xs' : 'm';\n\n  /**\n   * Overrides the behaviour of `orientation` property.\n   */\n  @property({ attribute: 'horizontal-from', reflect: true })\n  public accessor horizontalFrom: SbbHorizontalFrom | null = null;\n\n  /**\n   * Radio group's orientation, either horizontal or vertical.\n   */\n  @property({ reflect: true })\n  public accessor orientation: SbbOrientation = 'horizontal';\n\n  @forceType()\n  @property()\n  public accessor name: string = `sbb-radio-button-group-${++nextId}`;\n\n  /**\n   * List of contained radio buttons.\n   */\n  public get radioButtons(): (SbbRadioButtonElement | SbbRadioButtonPanelElement)[] {\n    return (\n      Array.from(this.querySelectorAll?.('sbb-radio-button, sbb-radio-button-panel') ?? []) as (\n        | SbbRadioButtonElement\n        | SbbRadioButtonPanelElement\n      )[]\n    ).filter((el) => el.closest?.('sbb-radio-button-group') === this);\n  }\n\n  private _didLoad = false;\n\n  /**\n   * Emits whenever the `sbb-radio-group` value changes.\n   * @deprecated only used for React. Will probably be removed once React 19 is available.\n   */\n  private _didChange: EventEmitter = new EventEmitter(\n    this,\n    SbbRadioButtonGroupElement.events.didChange,\n  );\n\n  public constructor() {\n    super();\n    this.addEventListener?.('change', (e: Event) => this._onRadioChange(e));\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.toggleAttribute(\n      'data-has-panel',\n      !!this.querySelector?.('sbb-selection-expansion-panel, sbb-radio-button-panel'),\n    );\n  }\n\n  public override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('disabled')) {\n      this.radioButtons.forEach((r) => r.requestUpdate?.('disabled'));\n    }\n    if (changedProperties.has('required')) {\n      this.radioButtons.forEach((r) => r.requestUpdate?.('required'));\n    }\n    if (changedProperties.has('size')) {\n      this.radioButtons.forEach((r) => r.requestUpdate?.('size'));\n    }\n    if (changedProperties.has('name')) {\n      this._updateRadiosName();\n    }\n  }\n\n  protected override async firstUpdated(changedProperties: PropertyValues<this>): Promise<void> {\n    super.firstUpdated(changedProperties);\n    this._didLoad = true;\n\n    await this.updateComplete;\n    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 (target.localName !== 'sbb-radio-button' && target.localName !== 'sbb-radio-button-panel') {\n      return;\n    }\n\n    this._fallbackValue = null; // Since the user interacted, the fallbackValue logic does not apply anymore\n    this._didChange.emit();\n  }\n\n  /**\n   * Proxy 'name' to child radio-buttons\n   */\n  private _updateRadiosName(): void {\n    this.radioButtons.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) {\n      // eslint-disable-next-line no-self-assign\n      this.value = this.value;\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-radio-group\">\n        <slot\n          @slotchange=${() => {\n            this._updateRadiosName();\n            this._updateRadioState();\n          }}\n        ></slot>\n      </div>\n      <div class=\"sbb-radio-group__error\">\n        <slot name=\"error\"></slot>\n      </div>\n    `;\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"],"names":["SbbRadioButtonGroupElement","_a"],"mappings":"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"}
389
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"radio-button-group.js","sources":["../../../../src/elements/radio-button/radio-button-group/radio-button-group.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { LitElement, html } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { forceType, hostAttributes, slotState } from '../../core/decorators.js';\nimport { isLean } from '../../core/dom.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport type { SbbHorizontalFrom, SbbOrientation } from '../../core/interfaces.js';\nimport { SbbDisabledMixin } from '../../core/mixins.js';\nimport type { SbbRadioButtonSize } from '../common.js';\nimport type { SbbRadioButtonPanelElement } from '../radio-button-panel.js';\nimport type { SbbRadioButtonElement } from '../radio-button.js';\n\nimport style from './radio-button-group.scss?lit&inline';\n\nlet nextId = 0;\n\n/**\n * It can be used as a container for one or more `sbb-radio-button`.\n *\n * @slot - Use the unnamed slot to add `sbb-radio-button` elements to the `sbb-radio-button-group`.\n * @slot error - Use this to provide a `sbb-form-error` to show an error message.\n * @event {CustomEvent<void>} didChange - Deprecated. Only used for React. Will probably be removed once React 19 is available. Emits whenever the `sbb-radio-group` value changes.\n */\nexport\n@customElement('sbb-radio-button-group')\n@hostAttributes({\n  role: 'radiogroup',\n})\n@slotState()\nclass SbbRadioButtonGroupElement extends SbbDisabledMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    didChange: 'didChange',\n    change: 'change',\n    input: 'input',\n  } as const;\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   * Whether the radio group is required.\n   */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor required: boolean = false;\n\n  /**\n   * The value of the radio group.\n   */\n  @property()\n  public set value(val: string | null) {\n    this._fallbackValue = val;\n    if (!this._didLoad) {\n      return;\n    }\n    if (val == null) {\n      this.radioButtons.forEach((r) => (r.checked = false));\n      return;\n    }\n    const toCheck = this.radioButtons.find((r) => r.value === val);\n    if (toCheck) {\n      toCheck.checked = true;\n    }\n  }\n  public get value(): string | null {\n    return this.radioButtons.find((r) => r.checked && !r.disabled)?.value ?? this._fallbackValue;\n  }\n  /**\n   * Used to preserve the `value` in case the radios are not yet 'loaded'\n   */\n  private _fallbackValue: string | null = null;\n\n  /**\n   * Size variant, either xs, s or m.\n   * @default 'm' / 'xs' (lean)\n   */\n  @property() public accessor size: SbbRadioButtonSize = isLean() ? 'xs' : 'm';\n\n  /**\n   * Overrides the behaviour of `orientation` property.\n   */\n  @property({ attribute: 'horizontal-from', reflect: true })\n  public accessor horizontalFrom: SbbHorizontalFrom | null = null;\n\n  /**\n   * Radio group's orientation, either horizontal or vertical.\n   */\n  @property({ reflect: true })\n  public accessor orientation: SbbOrientation = 'horizontal';\n\n  @forceType()\n  @property()\n  public accessor name: string = `sbb-radio-button-group-${++nextId}`;\n\n  /**\n   * List of contained radio buttons.\n   */\n  public get radioButtons(): (SbbRadioButtonElement | SbbRadioButtonPanelElement)[] {\n    return (\n      Array.from(this.querySelectorAll?.('sbb-radio-button, sbb-radio-button-panel') ?? []) as (\n        | SbbRadioButtonElement\n        | SbbRadioButtonPanelElement\n      )[]\n    ).filter((el) => el.closest?.('sbb-radio-button-group') === this);\n  }\n\n  private _didLoad = false;\n\n  /**\n   * Emits whenever the `sbb-radio-group` value changes.\n   * @deprecated only used for React. Will probably be removed once React 19 is available.\n   */\n  private _didChange: EventEmitter = new EventEmitter(\n    this,\n    SbbRadioButtonGroupElement.events.didChange,\n  );\n\n  public constructor() {\n    super();\n    this.addEventListener?.('change', (e: Event) => this._onRadioChange(e));\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.toggleAttribute(\n      'data-has-panel',\n      !!this.querySelector?.('sbb-selection-expansion-panel, sbb-radio-button-panel'),\n    );\n  }\n\n  public override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('disabled')) {\n      this.radioButtons.forEach((r) => r.requestUpdate?.('disabled'));\n    }\n    if (changedProperties.has('required')) {\n      this.radioButtons.forEach((r) => r.requestUpdate?.('required'));\n    }\n    if (changedProperties.has('size')) {\n      this.radioButtons.forEach((r) => r.requestUpdate?.('size'));\n    }\n    if (changedProperties.has('name')) {\n      this._updateRadiosName();\n    }\n  }\n\n  protected override async firstUpdated(changedProperties: PropertyValues<this>): Promise<void> {\n    super.firstUpdated(changedProperties);\n    this._didLoad = true;\n\n    await this.updateComplete;\n    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 (target.localName !== 'sbb-radio-button' && target.localName !== 'sbb-radio-button-panel') {\n      return;\n    }\n\n    this._fallbackValue = null; // Since the user interacted, the fallbackValue logic does not apply anymore\n    this._didChange.emit();\n  }\n\n  /**\n   * Proxy 'name' to child radio-buttons\n   */\n  private _updateRadiosName(): void {\n    this.radioButtons.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) {\n      // eslint-disable-next-line no-self-assign\n      this.value = this.value;\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-radio-group\">\n        <slot\n          @slotchange=${() => {\n            this._updateRadiosName();\n            this._updateRadioState();\n          }}\n        ></slot>\n      </div>\n      <div class=\"sbb-radio-group__error\">\n        <slot name=\"error\"></slot>\n      </div>\n    `;\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"],"names":["SbbRadioButtonGroupElement","_a"],"mappings":"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"}
@@ -1,5 +1,7 @@
1
1
  import { CSSResultGroup, LitElement, PropertyValues, TemplateResult } from 'lit';
2
+ import { SbbCheckedStateChange, SbbDisabledStateChange, SbbStateChange } from '../../core/interfaces.js';
2
3
  import { SbbPanelSize } from '../../core/mixins.js';
4
+ export type SbbRadioButtonStateChange = Extract<SbbStateChange, SbbDisabledStateChange | SbbCheckedStateChange>;
3
5
  declare const SbbRadioButtonPanelElement_base: import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbPanelMixinType> & import('../../core/mixins.js').AbstractConstructor<import('../common.js').SbbRadioButtonCommonElementMixinType> & import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbUpdateSchedulerMixinType> & typeof LitElement;
4
6
  /**
5
7
  /**
@@ -16,10 +18,10 @@ declare const SbbRadioButtonPanelElement_base: import('../../core/mixins.js').Ab
16
18
  export declare class SbbRadioButtonPanelElement extends SbbRadioButtonPanelElement_base {
17
19
  static styles: CSSResultGroup;
18
20
  static readonly events: {
19
- readonly stateChange: "stateChange";
20
21
  readonly change: "change";
21
22
  readonly input: "input";
22
23
  readonly panelConnected: "panelConnected";
24
+ readonly stateChange: "stateChange";
23
25
  };
24
26
  /**
25
27
  * Size variant, either s or m.
@@ -27,6 +29,12 @@ export declare class SbbRadioButtonPanelElement extends SbbRadioButtonPanelEleme
27
29
  */
28
30
  accessor size: SbbPanelSize;
29
31
  private _hasSelectionExpansionPanelElement;
32
+ /**
33
+ * @internal
34
+ * Internal event that emits whenever the state of the radio option
35
+ * in relation to the parent selection panel changes.
36
+ */
37
+ private _stateChange;
30
38
  connectedCallback(): void;
31
39
  protected willUpdate(changedProperties: PropertyValues<this>): void;
32
40
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"radio-button-panel.d.ts","sourceRoot":"","sources":["../../../../../src/elements/radio-button/radio-button-panel/radio-button-panel.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAEnB,UAAU,EAEV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAKb,OAAO,EAGL,KAAK,YAAY,EAElB,MAAM,sBAAsB,CAAC;AAG9B,OAAO,6BAA6B,CAAC;;AAErC;;;;;;;;;;;GAWG;AACH,qBAGM,0BAA2B,SAAQ,+BAExC;IACC,OAAuB,MAAM,EAAE,cAAc,CAA8C;IAG3F,gBAAuB,MAAM;;;;;MAKlB;IAEX;;;OAGG;IACH,SAEgB,IAAI,EAAE,YAAY,CAAwB;IAE1D,OAAO,CAAC,kCAAkC,CAAkB;IAE5C,iBAAiB,IAAI,IAAI;cAKtB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5E;;OAEG;cACgB,qBAAqB,IAAI,IAAI;IAShD;;OAEG;cACsB,kBAAkB,CAAC,IAAI,EAAE,0BAA0B,GAAG,OAAO,CAAC,IAAI,CAAC;cAQzE,MAAM,IAAI,cAAc;CAmB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,wBAAwB,EAAE,0BAA0B,CAAC;KACtD;CACF"}
1
+ {"version":3,"file":"radio-button-panel.d.ts","sourceRoot":"","sources":["../../../../../src/elements/radio-button/radio-button-panel/radio-button-panel.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAEnB,UAAU,EAEV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAMb,OAAO,KAAK,EACV,qBAAqB,EACrB,sBAAsB,EACtB,cAAc,EACf,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAGL,KAAK,YAAY,EAElB,MAAM,sBAAsB,CAAC;AAG9B,OAAO,6BAA6B,CAAC;AAErC,MAAM,MAAM,yBAAyB,GAAG,OAAO,CAC7C,cAAc,EACd,sBAAsB,GAAG,qBAAqB,CAC/C,CAAC;;AAEF;;;;;;;;;;;GAWG;AACH,qBAGM,0BAA2B,SAAQ,+BAExC;IACC,OAAuB,MAAM,EAAE,cAAc,CAA8C;IAG3F,gBAAuB,MAAM;;;;;MAKlB;IAEX;;;OAGG;IACH,SAEgB,IAAI,EAAE,YAAY,CAAwB;IAE1D,OAAO,CAAC,kCAAkC,CAAkB;IAE5D;;;;OAIG;IACH,OAAO,CAAC,YAAY,CAIlB;IAEc,iBAAiB,IAAI,IAAI;cAKtB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAkB5E;;OAEG;cACgB,qBAAqB,IAAI,IAAI;IAShD;;OAEG;cACsB,kBAAkB,CAAC,IAAI,EAAE,0BAA0B,GAAG,OAAO,CAAC,IAAI,CAAC;cAQzE,MAAM,IAAI,cAAc;CAmB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,wBAAwB,EAAE,0BAA0B,CAAC;KACtD;CACF"}
@@ -10,6 +10,7 @@ import { LitElement, html, nothing } from "lit";
10
10
  import { customElement, property } from "lit/decorators.js";
11
11
  import { slotState, getOverride } from "../core/decorators.js";
12
12
  import { isLean } from "../core/dom.js";
13
+ import { EventEmitter } from "../core/eventing.js";
13
14
  import { SbbPanelMixin, SbbUpdateSchedulerMixin, panelCommonStyle } from "../core/mixins.js";
14
15
  import { SbbRadioButtonCommonElementMixin, radioButtonCommonStyle } from "./common.js";
15
16
  import "../screen-reader-only.js";
@@ -23,12 +24,13 @@ let SbbRadioButtonPanelElement = (() => {
23
24
  let _size_decorators;
24
25
  let _size_initializers = [];
25
26
  let _size_extraInitializers = [];
26
- _a = class extends _classSuper {
27
+ var SbbRadioButtonPanelElement2 = (_a = class extends _classSuper {
27
28
  constructor() {
28
29
  super(...arguments);
29
30
  __privateAdd(this, _size_accessor_storage);
30
31
  __privateSet(this, _size_accessor_storage, __runInitializers(this, _size_initializers, isLean() ? "s" : "m"));
31
32
  this._hasSelectionExpansionPanelElement = (__runInitializers(this, _size_extraInitializers), false);
33
+ this._stateChange = new EventEmitter(this, SbbRadioButtonPanelElement2.events.stateChange, { bubbles: true });
32
34
  }
33
35
  /**
34
36
  * Size variant, either s or m.
@@ -49,6 +51,14 @@ let SbbRadioButtonPanelElement = (() => {
49
51
  super.willUpdate(changedProperties);
50
52
  if (changedProperties.has("checked")) {
51
53
  this.toggleAttribute("data-checked", this.checked);
54
+ if (this.checked !== changedProperties.get("checked")) {
55
+ this._stateChange.emit({ type: "checked", checked: this.checked });
56
+ }
57
+ }
58
+ if (changedProperties.has("disabled")) {
59
+ if (this.disabled !== changedProperties.get("disabled")) {
60
+ this._stateChange.emit({ type: "disabled", disabled: this.disabled });
61
+ }
52
62
  }
53
63
  }
54
64
  /**
@@ -96,17 +106,17 @@ let SbbRadioButtonPanelElement = (() => {
96
106
  obj.size = value;
97
107
  } }, metadata: _metadata }, _size_initializers, _size_extraInitializers);
98
108
  __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
99
- _classThis = _classDescriptor.value;
109
+ SbbRadioButtonPanelElement2 = _classThis = _classDescriptor.value;
100
110
  if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
101
111
  })(), _a.styles = [radioButtonCommonStyle, panelCommonStyle], _a.events = {
102
- stateChange: "stateChange",
103
112
  change: "change",
104
113
  input: "input",
105
- panelConnected: "panelConnected"
106
- }, __runInitializers(_classThis, _classExtraInitializers), _a;
107
- return _classThis;
114
+ panelConnected: "panelConnected",
115
+ stateChange: "stateChange"
116
+ }, __runInitializers(_classThis, _classExtraInitializers), _a);
117
+ return SbbRadioButtonPanelElement2 = _classThis;
108
118
  })();
109
119
  export {
110
120
  SbbRadioButtonPanelElement
111
121
  };
112
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"radio-button-panel.js","sources":["../../../../src/elements/radio-button/radio-button-panel/radio-button-panel.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  LitElement,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { getOverride, slotState } from '../../core/decorators.js';\nimport { isLean } from '../../core/dom.js';\nimport {\n  panelCommonStyle,\n  SbbPanelMixin,\n  type SbbPanelSize,\n  SbbUpdateSchedulerMixin,\n} from '../../core/mixins.js';\nimport { radioButtonCommonStyle, SbbRadioButtonCommonElementMixin } from '../common.js';\n\nimport '../../screen-reader-only.js';\n\n/**\n /**\n * It displays a radio button enhanced with the panel design.\n *\n * @slot - Use the unnamed slot to add content to the radio label.\n * @slot subtext - Slot used to render a subtext under the label.\n * @slot suffix - Slot used to render additional content after the label.\n * @slot badge - Use this slot to provide a `sbb-card-badge` (optional).\n * @event {Event} change - Fired on change.\n * @event {InputEvent} input - Fired on input.\n * @overrideType value - string | null\n */\nexport\n@customElement('sbb-radio-button-panel')\n@slotState()\nclass SbbRadioButtonPanelElement extends SbbPanelMixin(\n  SbbRadioButtonCommonElementMixin(SbbUpdateSchedulerMixin(LitElement)),\n) {\n  public static override styles: CSSResultGroup = [radioButtonCommonStyle, panelCommonStyle];\n\n  // TODO: fix using ...super.events requires: https://github.com/sbb-design-systems/lyne-components/issues/2600\n  public static readonly events = {\n    stateChange: 'stateChange',\n    change: 'change',\n    input: 'input',\n    panelConnected: 'panelConnected',\n  } as const;\n\n  /**\n   * Size variant, either s or m.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true })\n  @getOverride((i, v) => (i.group?.size ? (i.group.size === 'xs' ? 's' : i.group.size) : v))\n  public accessor size: SbbPanelSize = isLean() ? 's' : 'm';\n\n  private _hasSelectionExpansionPanelElement: boolean = false;\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this._hasSelectionExpansionPanelElement = !!this.closest?.('sbb-selection-expansion-panel');\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('checked')) {\n      this.toggleAttribute('data-checked', this.checked);\n    }\n  }\n\n  /**\n   * As an exception, panels with an expansion-panel attached are always focusable\n   */\n  protected override updateFocusableRadios(): void {\n    super.updateFocusableRadios();\n    const radios = Array.from(this.associatedRadioButtons ?? []) as SbbRadioButtonPanelElement[];\n\n    radios\n      .filter((r) => !r.disabled && r._hasSelectionExpansionPanelElement)\n      .forEach((r) => (r.tabIndex = 0));\n  }\n\n  /**\n   * As an exception, radio-panels with an expansion-panel attached are not checked automatically when navigating by keyboard\n   */\n  protected override async navigateByKeyboard(next: SbbRadioButtonPanelElement): Promise<void> {\n    if (!this._hasSelectionExpansionPanelElement) {\n      await super.navigateByKeyboard(next);\n    } else {\n      next.focus();\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <label class=\"sbb-selection-panel\">\n        <div class=\"sbb-selection-panel__badge\">\n          <slot name=\"badge\"></slot>\n        </div>\n        <span class=\"sbb-radio-button\">\n          <span class=\"sbb-radio-button__label-slot\">\n            <slot></slot>\n            <slot name=\"suffix\"></slot>\n          </span>\n          <slot name=\"subtext\"></slot>\n          ${this.expansionState\n            ? html`<sbb-screen-reader-only>${this.expansionState}</sbb-screen-reader-only>`\n            : nothing}\n        </span>\n      </label>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-radio-button-panel': SbbRadioButtonPanelElement;\n  }\n}\n"],"names":["_a"],"mappings":";;;;;;;;;;;;;;;IAqCM,8BAA0B,MAAA;;AAF/B,MAAA,mBAAA,CAAA,cAAc,wBAAwB,GACtC,WAAW;;;;oBAC6B,cACvC,iCAAiC,wBAAwB,UAAU,CAAC,CAAC;;;;AADtC,EAAA,mBAAQ,YAExC;AAAA;;AAiBC;AAAgB,yBAAqB,wBAAA,kBAAA,MAAA,oBAAA,OAAQ,IAAG,MAAM,GAAG;AAEjD,WAAkC,sCAAA,kBAAA,MAAA,uBAAA,GAAY;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAFtD,IAAgB,OAA0C;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA1D,IAAgB,KAA0C,OAAA;AAAA,yBAAA,wBAAA;AAAA,IAAA;AAAA,IAI1C,oBAAiB;;AAC/B,YAAM,kBAAiB;AACvB,WAAK,qCAAqC,CAAC,GAACA,MAAA,KAAK,YAAL,gBAAAA,IAAA,WAAe;AAAA,IAA+B;AAAA,IAGzE,WAAW,mBAAuC;AACnE,YAAM,WAAW,iBAAiB;AAE9B,UAAA,kBAAkB,IAAI,SAAS,GAAG;AAC/B,aAAA,gBAAgB,gBAAgB,KAAK,OAAO;AAAA,MAAA;AAAA,IACnD;AAAA;AAAA;AAAA;AAAA,IAMiB,wBAAqB;AACtC,YAAM,sBAAqB;AAC3B,YAAM,SAAS,MAAM,KAAK,KAAK,0BAA0B,CAAA,CAAE;AAE3D,aACG,OAAO,CAAC,MAAM,CAAC,EAAE,YAAY,EAAE,kCAAkC,EACjE,QAAQ,CAAC,MAAO,EAAE,WAAW,CAAE;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA,IAMjB,MAAM,mBAAmB,MAAgC;AACtE,UAAA,CAAC,KAAK,oCAAoC;AACtC,cAAA,MAAM,mBAAmB,IAAI;AAAA,MAAA,OAC9B;AACL,aAAK,MAAK;AAAA,MAAA;AAAA,IACZ;AAAA,IAGiB,SAAM;AAChB,aAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,YAWC,KAAK,iBACH,+BAA+B,KAAK,cAAc,8BAClD,OAAO;AAAA;AAAA;AAAA;AAAA,IAAA;AAAA,KAtDnB;;wBAFC,SAAS,EAAE,SAAS,MAAM,GAC1B,YAAY,CAAC,GAAG;;AAAO,eAAAA,MAAA,EAAE,UAAF,gBAAAA,IAAS,QAAQ,EAAE,MAAM,SAAS,OAAO,MAAM,EAAE,MAAM,OAAQ;AAAA,KAAE,CAAC;AAC1E,iBAAA,IAAA,MAAA,kBAAA,EAAA,MAAA,YAAA,MAAA,QAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,UAAA,KAAA,KAAA,CAAA,QAAA,IAAA,MAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,OAA0C;AAAA,SAAA,UAAA,aAAA,oBAAA,uBAAA;AAnB5D,iBA8EC,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QA3EwB,GAAA,SAAyB,CAAC,wBAAwB,gBAAgB,GAGlE,GAAA,SAAS;AAAA,IAC9B,aAAa;AAAA,IACb,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,gBAAgB;AAAA,EACR,GAXN,kBAA0B,YAAA,uBAAA,GAAC;;;"}
122
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"radio-button-panel.js","sources":["../../../../src/elements/radio-button/radio-button-panel/radio-button-panel.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  LitElement,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { getOverride, slotState } from '../../core/decorators.js';\nimport { isLean } from '../../core/dom.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport type {\n  SbbCheckedStateChange,\n  SbbDisabledStateChange,\n  SbbStateChange,\n} from '../../core/interfaces.js';\nimport {\n  panelCommonStyle,\n  SbbPanelMixin,\n  type SbbPanelSize,\n  SbbUpdateSchedulerMixin,\n} from '../../core/mixins.js';\nimport { radioButtonCommonStyle, SbbRadioButtonCommonElementMixin } from '../common.js';\n\nimport '../../screen-reader-only.js';\n\nexport type SbbRadioButtonStateChange = Extract<\n  SbbStateChange,\n  SbbDisabledStateChange | SbbCheckedStateChange\n>;\n\n/**\n /**\n * It displays a radio button enhanced with the panel design.\n *\n * @slot - Use the unnamed slot to add content to the radio label.\n * @slot subtext - Slot used to render a subtext under the label.\n * @slot suffix - Slot used to render additional content after the label.\n * @slot badge - Use this slot to provide a `sbb-card-badge` (optional).\n * @event {Event} change - Fired on change.\n * @event {InputEvent} input - Fired on input.\n * @overrideType value - string | null\n */\nexport\n@customElement('sbb-radio-button-panel')\n@slotState()\nclass SbbRadioButtonPanelElement extends SbbPanelMixin(\n  SbbRadioButtonCommonElementMixin(SbbUpdateSchedulerMixin(LitElement)),\n) {\n  public static override styles: CSSResultGroup = [radioButtonCommonStyle, panelCommonStyle];\n\n  // TODO: fix using ...super.events requires: https://github.com/sbb-design-systems/lyne-components/issues/2600\n  public static readonly events = {\n    change: 'change',\n    input: 'input',\n    panelConnected: 'panelConnected',\n    stateChange: 'stateChange',\n  } as const;\n\n  /**\n   * Size variant, either s or m.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true })\n  @getOverride((i, v) => (i.group?.size ? (i.group.size === 'xs' ? 's' : i.group.size) : v))\n  public accessor size: SbbPanelSize = isLean() ? 's' : 'm';\n\n  private _hasSelectionExpansionPanelElement: boolean = false;\n\n  /**\n   * @internal\n   * Internal event that emits whenever the state of the radio option\n   * in relation to the parent selection panel changes.\n   */\n  private _stateChange: EventEmitter<SbbRadioButtonStateChange> = new EventEmitter(\n    this,\n    SbbRadioButtonPanelElement.events.stateChange,\n    { bubbles: true },\n  );\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this._hasSelectionExpansionPanelElement = !!this.closest?.('sbb-selection-expansion-panel');\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('checked')) {\n      this.toggleAttribute('data-checked', this.checked);\n\n      if (this.checked !== changedProperties.get('checked')!) {\n        this._stateChange.emit({ type: 'checked', checked: this.checked });\n      }\n    }\n\n    if (changedProperties.has('disabled')) {\n      if (this.disabled !== changedProperties.get('disabled')!) {\n        this._stateChange.emit({ type: 'disabled', disabled: this.disabled });\n      }\n    }\n  }\n\n  /**\n   * As an exception, panels with an expansion-panel attached are always focusable\n   */\n  protected override updateFocusableRadios(): void {\n    super.updateFocusableRadios();\n    const radios = Array.from(this.associatedRadioButtons ?? []) as SbbRadioButtonPanelElement[];\n\n    radios\n      .filter((r) => !r.disabled && r._hasSelectionExpansionPanelElement)\n      .forEach((r) => (r.tabIndex = 0));\n  }\n\n  /**\n   * As an exception, radio-panels with an expansion-panel attached are not checked automatically when navigating by keyboard\n   */\n  protected override async navigateByKeyboard(next: SbbRadioButtonPanelElement): Promise<void> {\n    if (!this._hasSelectionExpansionPanelElement) {\n      await super.navigateByKeyboard(next);\n    } else {\n      next.focus();\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <label class=\"sbb-selection-panel\">\n        <div class=\"sbb-selection-panel__badge\">\n          <slot name=\"badge\"></slot>\n        </div>\n        <span class=\"sbb-radio-button\">\n          <span class=\"sbb-radio-button__label-slot\">\n            <slot></slot>\n            <slot name=\"suffix\"></slot>\n          </span>\n          <slot name=\"subtext\"></slot>\n          ${this.expansionState\n            ? html`<sbb-screen-reader-only>${this.expansionState}</sbb-screen-reader-only>`\n            : nothing}\n        </span>\n      </label>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-radio-button-panel': SbbRadioButtonPanelElement;\n  }\n}\n"],"names":["SbbRadioButtonPanelElement","_a"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements",
3
- "version": "2.0.2",
3
+ "version": "2.0.3",
4
4
  "description": "Lyne Design System",
5
5
  "keywords": [
6
6
  "design system",
@@ -1,9 +1,7 @@
1
1
  import { LitElement } from 'lit';
2
- import { SbbCheckedStateChange, SbbDisabledStateChange, SbbStateChange } from '../../core/interfaces.js';
3
2
  import { AbstractConstructor, Constructor, SbbFormAssociatedRadioButtonMixinType } from '../../core/mixins.js';
4
3
  import { SbbRadioButtonGroupElement } from '../radio-button-group.js';
5
4
  export type SbbRadioButtonSize = 'xs' | 's' | 'm';
6
- export type SbbRadioButtonStateChange = Extract<SbbStateChange, SbbDisabledStateChange | SbbCheckedStateChange>;
7
5
  export declare class SbbRadioButtonCommonElementMixinType extends SbbFormAssociatedRadioButtonMixinType {
8
6
  get allowEmptySelection(): boolean;
9
7
  set allowEmptySelection(boolean: boolean);
@@ -1 +1 @@
1
- {"version":3,"file":"radio-button-common.d.ts","sourceRoot":"","sources":["../../../../src/elements/radio-button/common/radio-button-common.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAkB,MAAM,KAAK,CAAC;AAKtD,OAAO,KAAK,EACV,qBAAqB,EACrB,sBAAsB,EACtB,cAAc,EACf,MAAM,0BAA0B,CAAC;AAClC,OAAO,EACL,KAAK,mBAAmB,EACxB,KAAK,WAAW,EAEhB,KAAK,qCAAqC,EAC3C,MAAM,sBAAsB,CAAC;AAC9B,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AAE3E,MAAM,MAAM,kBAAkB,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,CAAC;AAElD,MAAM,MAAM,yBAAyB,GAAG,OAAO,CAC7C,cAAc,EACd,sBAAsB,GAAG,qBAAqB,CAC/C,CAAC;AAEF,MAAM,CAAC,OAAO,OAAO,oCAAqC,SAAQ,qCAAqC;IACrG,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,cACpE,CAAC,KACZ,mBAAmB,CAAC,oCAAoC,CAAC,GAAG,CAwH9D,CAAC"}
1
+ {"version":3,"file":"radio-button-common.d.ts","sourceRoot":"","sources":["../../../../src/elements/radio-button/common/radio-button-common.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,KAAK,CAAC;AAItC,OAAO,EACL,KAAK,mBAAmB,EACxB,KAAK,WAAW,EAEhB,KAAK,qCAAqC,EAC3C,MAAM,sBAAsB,CAAC;AAC9B,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AAE3E,MAAM,MAAM,kBAAkB,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,CAAC;AAElD,MAAM,CAAC,OAAO,OAAO,oCAAqC,SAAQ,qCAAqC;IACrG,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,cACpE,CAAC,KACZ,mBAAmB,CAAC,oCAAoC,CAAC,GAAG,CA6F9D,CAAC"}
@@ -1,13 +1,12 @@
1
1
  import { __esDecorate as n, __runInitializers as l } from "tslib";
2
2
  import { property as d } from "lit/decorators.js";
3
3
  import { setModalityOnNextFocus as c } from "../core/a11y.js";
4
- import { EventEmitter as u } from "../core/eventing.js";
5
- import { SbbFormAssociatedRadioButtonMixin as h } from "../core/mixins.js";
6
- import { css as m } from "lit";
7
- const k = (s) => (() => {
4
+ import { SbbFormAssociatedRadioButtonMixin as u } from "../core/mixins.js";
5
+ import { css as h } from "lit";
6
+ const x = (s) => (() => {
8
7
  var o;
9
- let r = h(s), b = [], a;
10
- return o = class extends r {
8
+ let i = u(s), b = [], a;
9
+ return o = class extends i {
11
10
  /**
12
11
  * Whether the radio can be deselected.
13
12
  */
@@ -26,7 +25,7 @@ const k = (s) => (() => {
26
25
  }
27
26
  constructor() {
28
27
  var t, e;
29
- super(), this._allowEmptySelection = (l(this, b), !1), this._group = null, this._stateChange = new u(this, o.events.stateChange, { bubbles: !0 }), (t = this.addEventListener) == null || t.call(this, "click", (i) => this._handleClick(i)), (e = this.addEventListener) == null || e.call(this, "keydown", (i) => this._handleKeyDown(i));
28
+ super(), this._allowEmptySelection = (l(this, b), !1), this._group = null, (t = this.addEventListener) == null || t.call(this, "click", (r) => this._handleClick(r)), (e = this.addEventListener) == null || e.call(this, "keydown", (r) => this._handleKeyDown(r));
30
29
  }
31
30
  connectedCallback() {
32
31
  super.connectedCallback(), this._group = this.closest("sbb-radio-button-group"), ["disabled", "required", "size"].forEach((t) => this.requestUpdate(t));
@@ -38,9 +37,6 @@ const k = (s) => (() => {
38
37
  select() {
39
38
  this.disabled || this.formDisabled || (this.allowEmptySelection ? (this.checked = !this.checked, this.emitChangeEvents()) : this.checked || (this.checked = !0, this.emitChangeEvents()));
40
39
  }
41
- willUpdate(t) {
42
- super.willUpdate(t), t.has("checked") && this.checked !== t.get("checked") && this._stateChange.emit({ type: "checked", checked: this.checked }), t.has("disabled") && this.disabled !== t.get("disabled") && this._stateChange.emit({ type: "disabled", disabled: this.disabled });
43
- }
44
40
  isDisabledExternally() {
45
41
  var t;
46
42
  return ((t = this.group) == null ? void 0 : t.disabled) ?? !1;
@@ -56,17 +52,16 @@ const k = (s) => (() => {
56
52
  t.code === "Space" && (t.preventDefault(), this.select());
57
53
  }
58
54
  }, (() => {
59
- const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(r[Symbol.metadata] ?? null) : void 0;
60
- a = [d({ attribute: "allow-empty-selection", type: Boolean })], n(o, null, a, { kind: "setter", name: "allowEmptySelection", static: !1, private: !1, access: { has: (e) => "allowEmptySelection" in e, set: (e, i) => {
61
- e.allowEmptySelection = i;
55
+ const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(i[Symbol.metadata] ?? null) : void 0;
56
+ a = [d({ attribute: "allow-empty-selection", type: Boolean })], n(o, null, a, { kind: "setter", name: "allowEmptySelection", static: !1, private: !1, access: { has: (e) => "allowEmptySelection" in e, set: (e, r) => {
57
+ e.allowEmptySelection = r;
62
58
  } }, metadata: t }, null, b), t && Object.defineProperty(o, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
63
59
  })(), o.events = {
64
60
  change: "change",
65
- input: "input",
66
- stateChange: "stateChange"
61
+ input: "input"
67
62
  }, o;
68
- })(), _ = m`*,:before,:after{box-sizing:border-box}:host{--sbb-radio-button-label-color: var(--sbb-color-charcoal);--sbb-radio-button-background-color: var(--sbb-color-white);--sbb-radio-button-inner-circle-color: var(--sbb-color-white);--sbb-radio-button-border-width: var(--sbb-border-width-1x);--sbb-radio-button-border-style: solid;--sbb-radio-button-border-color: var(--sbb-color-smoke);--sbb-radio-button-dimension: var(--sbb-size-icon-ui-small);--sbb-radio-button-inner-circle-dimension: .625rem;--sbb-radio-button-cursor: pointer;--sbb-radio-button-background-fake-border-width: calc(var(--sbb-radio-button-dimension) / 2);--sbb-radio-button-icon-align: calc( (1em * var(--sbb-typo-line-height-body-text) - var(--sbb-radio-button-dimension)) / 2 )}@media (forced-colors: active){:host{--sbb-radio-button-background-color: Canvas !important;--sbb-radio-button-border-width: var(--sbb-border-width-2x);--sbb-radio-button-border-color: ButtonBorder}}:host([data-checked]){--sbb-radio-button-inner-circle-color: var(--sbb-color-red);--sbb-radio-button-background-fake-border-width: calc( (var(--sbb-radio-button-dimension) - var(--sbb-radio-button-inner-circle-dimension)) / 2 )}@media (forced-colors: active){:host([data-checked]){--sbb-radio-button-inner-circle-color: Highlight;--sbb-radio-button-border-color: Highlight}}:host(:disabled){--sbb-radio-button-label-color: var(--sbb-color-granite);--sbb-radio-button-background-color: var(--sbb-color-milk);--sbb-radio-button-border-style: dashed;--sbb-radio-button-inner-circle-color: var(--sbb-color-charcoal);--sbb-radio-button-cursor: default}@media (forced-colors: active){:host(:disabled){--sbb-radio-button-inner-circle-color: GrayText;--sbb-radio-button-border-color: GrayText;--sbb-radio-button-border-style: solid}}:host([size=xs]){--sbb-radio-button-dimension: 1.25rem}.sbb-screen-reader-only{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.sbb-radio-button{display:block;cursor:var(--sbb-radio-button-cursor);-webkit-user-select:none;user-select:none;position:relative;color:var(--sbb-radio-button-label-color);-webkit-tap-highlight-color:transparent;--sbb-text-font-size: var(--sbb-font-size-text-m);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size)}:host([size=s]) .sbb-radio-button{--sbb-text-font-size: var(--sbb-font-size-text-s);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size)}:host([size=xs]) .sbb-radio-button{--sbb-text-font-size: var(--sbb-font-size-text-xs);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size)}.sbb-radio-button__label-slot{display:flex;align-items:flex-start;overflow:hidden}.sbb-radio-button__label-slot:before,.sbb-radio-button__label-slot:after{content:"";flex-shrink:0;width:var(--sbb-radio-button-dimension);height:var(--sbb-radio-button-dimension);border-radius:50%;margin-block-start:var(--sbb-radio-button-icon-align);transition-duration:var(--sbb-disable-animation-duration, var(--sbb-animation-duration-4x));transition-timing-function:ease;transition-property:background-color,border}@media (forced-colors: active){.sbb-radio-button__label-slot:before,.sbb-radio-button__label-slot:after{transition:none}}.sbb-radio-button__label-slot:before{background:var(--sbb-radio-button-inner-circle-color);border:var(--sbb-radio-button-background-fake-border-width) solid var(--sbb-radio-button-background-color);margin-inline-end:var(--sbb-spacing-fixed-2x)}.sbb-radio-button__label-slot:after{position:absolute;border:var(--sbb-radio-button-border-width) var(--sbb-radio-button-border-style) var(--sbb-radio-button-border-color)}`;
63
+ })(), w = h`*,:before,:after{box-sizing:border-box}:host{--sbb-radio-button-label-color: var(--sbb-color-charcoal);--sbb-radio-button-background-color: var(--sbb-color-white);--sbb-radio-button-inner-circle-color: var(--sbb-color-white);--sbb-radio-button-border-width: var(--sbb-border-width-1x);--sbb-radio-button-border-style: solid;--sbb-radio-button-border-color: var(--sbb-color-smoke);--sbb-radio-button-dimension: var(--sbb-size-icon-ui-small);--sbb-radio-button-inner-circle-dimension: .625rem;--sbb-radio-button-cursor: pointer;--sbb-radio-button-background-fake-border-width: calc(var(--sbb-radio-button-dimension) / 2);--sbb-radio-button-icon-align: calc( (1em * var(--sbb-typo-line-height-body-text) - var(--sbb-radio-button-dimension)) / 2 )}@media (forced-colors: active){:host{--sbb-radio-button-background-color: Canvas !important;--sbb-radio-button-border-width: var(--sbb-border-width-2x);--sbb-radio-button-border-color: ButtonBorder}}:host([data-checked]){--sbb-radio-button-inner-circle-color: var(--sbb-color-red);--sbb-radio-button-background-fake-border-width: calc( (var(--sbb-radio-button-dimension) - var(--sbb-radio-button-inner-circle-dimension)) / 2 )}@media (forced-colors: active){:host([data-checked]){--sbb-radio-button-inner-circle-color: Highlight;--sbb-radio-button-border-color: Highlight}}:host(:disabled){--sbb-radio-button-label-color: var(--sbb-color-granite);--sbb-radio-button-background-color: var(--sbb-color-milk);--sbb-radio-button-border-style: dashed;--sbb-radio-button-inner-circle-color: var(--sbb-color-charcoal);--sbb-radio-button-cursor: default}@media (forced-colors: active){:host(:disabled){--sbb-radio-button-inner-circle-color: GrayText;--sbb-radio-button-border-color: GrayText;--sbb-radio-button-border-style: solid}}:host([size=xs]){--sbb-radio-button-dimension: 1.25rem}.sbb-screen-reader-only{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.sbb-radio-button{display:block;cursor:var(--sbb-radio-button-cursor);-webkit-user-select:none;user-select:none;position:relative;color:var(--sbb-radio-button-label-color);-webkit-tap-highlight-color:transparent;--sbb-text-font-size: var(--sbb-font-size-text-m);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size)}:host([size=s]) .sbb-radio-button{--sbb-text-font-size: var(--sbb-font-size-text-s);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size)}:host([size=xs]) .sbb-radio-button{--sbb-text-font-size: var(--sbb-font-size-text-xs);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size)}.sbb-radio-button__label-slot{display:flex;align-items:flex-start;overflow:hidden}.sbb-radio-button__label-slot:before,.sbb-radio-button__label-slot:after{content:"";flex-shrink:0;width:var(--sbb-radio-button-dimension);height:var(--sbb-radio-button-dimension);border-radius:50%;margin-block-start:var(--sbb-radio-button-icon-align);transition-duration:var(--sbb-disable-animation-duration, var(--sbb-animation-duration-4x));transition-timing-function:ease;transition-property:background-color,border}@media (forced-colors: active){.sbb-radio-button__label-slot:before,.sbb-radio-button__label-slot:after{transition:none}}.sbb-radio-button__label-slot:before{background:var(--sbb-radio-button-inner-circle-color);border:var(--sbb-radio-button-background-fake-border-width) solid var(--sbb-radio-button-background-color);margin-inline-end:var(--sbb-spacing-fixed-2x)}.sbb-radio-button__label-slot:after{position:absolute;border:var(--sbb-radio-button-border-width) var(--sbb-radio-button-border-style) var(--sbb-radio-button-border-color)}`;
69
64
  export {
70
- k as SbbRadioButtonCommonElementMixin,
71
- _ as radioButtonCommonStyle
65
+ x as SbbRadioButtonCommonElementMixin,
66
+ w as radioButtonCommonStyle
72
67
  };
@@ -52,7 +52,7 @@ let et = 0, ut = (() => {
52
52
  set value(e) {
53
53
  if (this._fallbackValue = e, !this._didLoad)
54
54
  return;
55
- if (!e) {
55
+ if (e == null) {
56
56
  this.radioButtons.forEach((a) => a.checked = !1);
57
57
  return;
58
58
  }
@@ -1,5 +1,7 @@
1
1
  import { CSSResultGroup, LitElement, PropertyValues, TemplateResult } from 'lit';
2
+ import { SbbCheckedStateChange, SbbDisabledStateChange, SbbStateChange } from '../../core/interfaces.js';
2
3
  import { SbbPanelSize } from '../../core/mixins.js';
4
+ export type SbbRadioButtonStateChange = Extract<SbbStateChange, SbbDisabledStateChange | SbbCheckedStateChange>;
3
5
  declare const SbbRadioButtonPanelElement_base: import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbPanelMixinType> & import('../../core/mixins.js').AbstractConstructor<import('../common.js').SbbRadioButtonCommonElementMixinType> & import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbUpdateSchedulerMixinType> & typeof LitElement;
4
6
  /**
5
7
  /**
@@ -16,10 +18,10 @@ declare const SbbRadioButtonPanelElement_base: import('../../core/mixins.js').Ab
16
18
  export declare class SbbRadioButtonPanelElement extends SbbRadioButtonPanelElement_base {
17
19
  static styles: CSSResultGroup;
18
20
  static readonly events: {
19
- readonly stateChange: "stateChange";
20
21
  readonly change: "change";
21
22
  readonly input: "input";
22
23
  readonly panelConnected: "panelConnected";
24
+ readonly stateChange: "stateChange";
23
25
  };
24
26
  /**
25
27
  * Size variant, either s or m.
@@ -27,6 +29,12 @@ export declare class SbbRadioButtonPanelElement extends SbbRadioButtonPanelEleme
27
29
  */
28
30
  accessor size: SbbPanelSize;
29
31
  private _hasSelectionExpansionPanelElement;
32
+ /**
33
+ * @internal
34
+ * Internal event that emits whenever the state of the radio option
35
+ * in relation to the parent selection panel changes.
36
+ */
37
+ private _stateChange;
30
38
  connectedCallback(): void;
31
39
  protected willUpdate(changedProperties: PropertyValues<this>): void;
32
40
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"radio-button-panel.d.ts","sourceRoot":"","sources":["../../../../src/elements/radio-button/radio-button-panel/radio-button-panel.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAEnB,UAAU,EAEV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAKb,OAAO,EAGL,KAAK,YAAY,EAElB,MAAM,sBAAsB,CAAC;AAG9B,OAAO,6BAA6B,CAAC;;AAErC;;;;;;;;;;;GAWG;AACH,qBAGM,0BAA2B,SAAQ,+BAExC;IACC,OAAuB,MAAM,EAAE,cAAc,CAA8C;IAG3F,gBAAuB,MAAM;;;;;MAKlB;IAEX;;;OAGG;IACH,SAEgB,IAAI,EAAE,YAAY,CAAwB;IAE1D,OAAO,CAAC,kCAAkC,CAAkB;IAE5C,iBAAiB,IAAI,IAAI;cAKtB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5E;;OAEG;cACgB,qBAAqB,IAAI,IAAI;IAShD;;OAEG;cACsB,kBAAkB,CAAC,IAAI,EAAE,0BAA0B,GAAG,OAAO,CAAC,IAAI,CAAC;cAQzE,MAAM,IAAI,cAAc;CAmB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,wBAAwB,EAAE,0BAA0B,CAAC;KACtD;CACF"}
1
+ {"version":3,"file":"radio-button-panel.d.ts","sourceRoot":"","sources":["../../../../src/elements/radio-button/radio-button-panel/radio-button-panel.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAEnB,UAAU,EAEV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAMb,OAAO,KAAK,EACV,qBAAqB,EACrB,sBAAsB,EACtB,cAAc,EACf,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAGL,KAAK,YAAY,EAElB,MAAM,sBAAsB,CAAC;AAG9B,OAAO,6BAA6B,CAAC;AAErC,MAAM,MAAM,yBAAyB,GAAG,OAAO,CAC7C,cAAc,EACd,sBAAsB,GAAG,qBAAqB,CAC/C,CAAC;;AAEF;;;;;;;;;;;GAWG;AACH,qBAGM,0BAA2B,SAAQ,+BAExC;IACC,OAAuB,MAAM,EAAE,cAAc,CAA8C;IAG3F,gBAAuB,MAAM;;;;;MAKlB;IAEX;;;OAGG;IACH,SAEgB,IAAI,EAAE,YAAY,CAAwB;IAE1D,OAAO,CAAC,kCAAkC,CAAkB;IAE5D;;;;OAIG;IACH,OAAO,CAAC,YAAY,CAIlB;IAEc,iBAAiB,IAAI,IAAI;cAKtB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAkB5E;;OAEG;cACgB,qBAAqB,IAAI,IAAI;IAShD;;OAEG;cACsB,kBAAkB,CAAC,IAAI,EAAE,0BAA0B,GAAG,OAAO,CAAC,IAAI,CAAC;cAQzE,MAAM,IAAI,cAAc;CAmB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,wBAAwB,EAAE,0BAA0B,CAAC;KACtD;CACF"}
@@ -1,41 +1,42 @@
1
- var _ = (e) => {
2
- throw TypeError(e);
1
+ var f = (t) => {
2
+ throw TypeError(t);
3
3
  };
4
- var f = (e, s, i) => s.has(e) || _("Cannot " + i);
5
- var g = (e, s, i) => (f(e, s, "read from private field"), i ? i.call(e) : s.get(e)), S = (e, s, i) => s.has(e) ? _("Cannot add the same private member more than once") : s instanceof WeakSet ? s.add(e) : s.set(e, i), c = (e, s, i, n) => (f(e, s, "write to private field"), n ? n.call(e, i) : s.set(e, i), i);
6
- import { __runInitializers as b, __esDecorate as y } from "tslib";
7
- import { LitElement as z, html as x, nothing as E } from "lit";
8
- import { customElement as v, property as C } from "lit/decorators.js";
9
- import { slotState as k, getOverride as B } from "../core/decorators.js";
10
- import { isLean as P } from "../core/dom.js";
11
- import { SbbPanelMixin as R, SbbUpdateSchedulerMixin as w, panelCommonStyle as I } from "../core/mixins.js";
12
- import { SbbRadioButtonCommonElementMixin as D, radioButtonCommonStyle as M } from "./common.js";
4
+ var g = (t, s, i) => s.has(t) || f("Cannot " + i);
5
+ var y = (t, s, i) => (g(t, s, "read from private field"), i ? i.call(t) : s.get(t)), S = (t, s, i) => s.has(t) ? f("Cannot add the same private member more than once") : s instanceof WeakSet ? s.add(t) : s.set(t, i), d = (t, s, i, n) => (g(t, s, "write to private field"), n ? n.call(t, i) : s.set(t, i), i);
6
+ import { __runInitializers as b, __esDecorate as x } from "tslib";
7
+ import { LitElement as E, html as z, nothing as v } from "lit";
8
+ import { customElement as C, property as k } from "lit/decorators.js";
9
+ import { slotState as B, getOverride as R } from "../core/decorators.js";
10
+ import { isLean as w } from "../core/dom.js";
11
+ import { EventEmitter as I } from "../core/eventing.js";
12
+ import { SbbPanelMixin as P, SbbUpdateSchedulerMixin as D, panelCommonStyle as M } from "../core/mixins.js";
13
+ import { SbbRadioButtonCommonElementMixin as O, radioButtonCommonStyle as U } from "./common.js";
13
14
  import "../screen-reader-only.js";
14
- let G = (() => {
15
+ let N = (() => {
15
16
  var o, l;
16
- let e = [v("sbb-radio-button-panel"), k()], s, i = [], n, m = R(D(w(z))), d, p = [], u = [];
17
- return l = class extends m {
17
+ let t = [C("sbb-radio-button-panel"), B()], s, i = [], n, m = P(O(D(E))), u, h = [], p = [];
18
+ var r = (l = class extends m {
18
19
  constructor() {
19
20
  super(...arguments);
20
21
  S(this, o);
21
- c(this, o, b(this, p, P() ? "s" : "m")), this._hasSelectionExpansionPanelElement = (b(this, u), !1);
22
+ d(this, o, b(this, h, w() ? "s" : "m")), this._hasSelectionExpansionPanelElement = (b(this, p), !1), this._stateChange = new I(this, r.events.stateChange, { bubbles: !0 });
22
23
  }
23
24
  /**
24
25
  * Size variant, either s or m.
25
26
  * @default 'm' / 's' (lean)
26
27
  */
27
28
  get size() {
28
- return g(this, o);
29
+ return y(this, o);
29
30
  }
30
- set size(t) {
31
- c(this, o, t);
31
+ set size(e) {
32
+ d(this, o, e);
32
33
  }
33
34
  connectedCallback() {
34
- var t;
35
- super.connectedCallback(), this._hasSelectionExpansionPanelElement = !!((t = this.closest) != null && t.call(this, "sbb-selection-expansion-panel"));
35
+ var e;
36
+ super.connectedCallback(), this._hasSelectionExpansionPanelElement = !!((e = this.closest) != null && e.call(this, "sbb-selection-expansion-panel"));
36
37
  }
37
- willUpdate(t) {
38
- super.willUpdate(t), t.has("checked") && this.toggleAttribute("data-checked", this.checked);
38
+ willUpdate(e) {
39
+ super.willUpdate(e), e.has("checked") && (this.toggleAttribute("data-checked", this.checked), this.checked !== e.get("checked") && this._stateChange.emit({ type: "checked", checked: this.checked })), e.has("disabled") && this.disabled !== e.get("disabled") && this._stateChange.emit({ type: "disabled", disabled: this.disabled });
39
40
  }
40
41
  /**
41
42
  * As an exception, panels with an expansion-panel attached are always focusable
@@ -46,11 +47,11 @@ let G = (() => {
46
47
  /**
47
48
  * As an exception, radio-panels with an expansion-panel attached are not checked automatically when navigating by keyboard
48
49
  */
49
- async navigateByKeyboard(t) {
50
- this._hasSelectionExpansionPanelElement ? t.focus() : await super.navigateByKeyboard(t);
50
+ async navigateByKeyboard(e) {
51
+ this._hasSelectionExpansionPanelElement ? e.focus() : await super.navigateByKeyboard(e);
51
52
  }
52
53
  render() {
53
- return x`
54
+ return z`
54
55
  <label class="sbb-selection-panel">
55
56
  <div class="sbb-selection-panel__badge">
56
57
  <slot name="badge"></slot>
@@ -61,26 +62,27 @@ let G = (() => {
61
62
  <slot name="suffix"></slot>
62
63
  </span>
63
64
  <slot name="subtext"></slot>
64
- ${this.expansionState ? x`<sbb-screen-reader-only>${this.expansionState}</sbb-screen-reader-only>` : E}
65
+ ${this.expansionState ? z`<sbb-screen-reader-only>${this.expansionState}</sbb-screen-reader-only>` : v}
65
66
  </span>
66
67
  </label>
67
68
  `;
68
69
  }
69
70
  }, o = new WeakMap(), n = l, (() => {
70
- const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(m[Symbol.metadata] ?? null) : void 0;
71
- d = [C({ reflect: !0 }), B((a, r) => {
72
- var h;
73
- return (h = a.group) != null && h.size ? a.group.size === "xs" ? "s" : a.group.size : r;
74
- })], y(l, null, d, { kind: "accessor", name: "size", static: !1, private: !1, access: { has: (a) => "size" in a, get: (a) => a.size, set: (a, r) => {
75
- a.size = r;
76
- } }, metadata: t }, p, u), y(null, s = { value: n }, e, { kind: "class", name: n.name, metadata: t }, null, i), n = s.value, t && Object.defineProperty(n, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
77
- })(), l.styles = [M, I], l.events = {
78
- stateChange: "stateChange",
71
+ const e = typeof Symbol == "function" && Symbol.metadata ? Object.create(m[Symbol.metadata] ?? null) : void 0;
72
+ u = [k({ reflect: !0 }), R((a, c) => {
73
+ var _;
74
+ return (_ = a.group) != null && _.size ? a.group.size === "xs" ? "s" : a.group.size : c;
75
+ })], x(l, null, u, { kind: "accessor", name: "size", static: !1, private: !1, access: { has: (a) => "size" in a, get: (a) => a.size, set: (a, c) => {
76
+ a.size = c;
77
+ } }, metadata: e }, h, p), x(null, s = { value: n }, t, { kind: "class", name: n.name, metadata: e }, null, i), r = n = s.value, e && Object.defineProperty(n, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: e });
78
+ })(), l.styles = [U, M], l.events = {
79
79
  change: "change",
80
80
  input: "input",
81
- panelConnected: "panelConnected"
82
- }, b(n, i), n;
81
+ panelConnected: "panelConnected",
82
+ stateChange: "stateChange"
83
+ }, b(n, i), l);
84
+ return r = n;
83
85
  })();
84
86
  export {
85
- G as SbbRadioButtonPanelElement
87
+ N as SbbRadioButtonPanelElement
86
88
  };