@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.
- package/core/mixins/form-associated-mixin.d.ts +2 -4
- package/core/mixins/form-associated-mixin.d.ts.map +1 -1
- package/core/mixins/form-associated-radio-button-mixin.d.ts +3 -3
- package/core/mixins/form-associated-radio-button-mixin.d.ts.map +1 -1
- package/core/mixins.js +276 -276
- package/custom-elements.json +164 -126
- package/development/core/mixins/form-associated-mixin.d.ts +2 -4
- package/development/core/mixins/form-associated-mixin.d.ts.map +1 -1
- package/development/core/mixins/form-associated-radio-button-mixin.d.ts +3 -3
- package/development/core/mixins/form-associated-radio-button-mixin.d.ts.map +1 -1
- package/development/core/mixins.js +45 -49
- package/development/radio-button/common/radio-button-common.d.ts +0 -2
- package/development/radio-button/common/radio-button-common.d.ts.map +1 -1
- package/development/radio-button/common.js +2 -18
- package/development/radio-button/radio-button-group.js +2 -2
- package/development/radio-button/radio-button-panel/radio-button-panel.d.ts +9 -1
- package/development/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -1
- package/development/radio-button/radio-button-panel.js +17 -7
- package/package.json +1 -1
- package/radio-button/common/radio-button-common.d.ts +0 -2
- package/radio-button/common/radio-button-common.d.ts.map +1 -1
- package/radio-button/common.js +13 -18
- package/radio-button/radio-button-group.js +1 -1
- package/radio-button/radio-button-panel/radio-button-panel.d.ts +9 -1
- package/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -1
- 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":"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"}
|
|
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 (
|
|
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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAeA,IAAI,SAAS;IAeP,8BAA0B,MAAA;;AAL/B,MAAA,mBAAA,CAAA,cAAc,wBAAwB,GACtC,eAAe;AAAA,IACd,MAAM;AAAA,EAAA,CACP,GACA,UAAA,CAAW;;;;oBAC6B,iBAAiB,UAAU;;;;;;;;;;;;;;;;;;;;;AAAnCA,MAAAA,+BAAA,mBAAQ,YAA4B;AAAA,IA6FnE,cAAA;;;AAhFA;AAOA;AAgCY;AAMZ;AAMA;AAIA;AApEI,yBAAA,wCAAA,kBAAA,MAAA,0BAAA,GAa2C,kBAAA,MAAA,mCAAA,KAAK;AAOpC,yBAAA,6BAAA,kBAAA,MAAA,sCAAA,GAAA,kBAAA,MAAA,wBAAoB,KAAK;AA0BjC,WAAc,kBAAA,kBAAA,MAAA,2BAAA,GAAkB;AAMZ,yBAA2B,wBAAA,kBAAA,MAAA,oBAAA,OAAQ,IAAG,OAAO,GAAG;AAM5D,yBAAA,mCAAA,kBAAA,MAAA,uBAAA,GAAA,kBAAA,MAAA,8BAA2C,IAAI;AAM/C,yBAAA,gCAAA,kBAAA,MAAA,iCAAA,GAAA,kBAAA,MAAA,2BAA8B,YAAY;AAI1C,yBAAA,yBAAA,kBAAA,MAAA,8BAAA,GAAA,kBAAA,MAAA,oBAAe,0BAA0B,EAAE,MAAM,EAAE;AAc3D,WAAQ,YAAA,kBAAA,MAAA,uBAAA,GAAG;AAMX,WAAA,aAA2B,IAAI,aACrC,MACAA,4BAA2B,OAAO,SAAS;AAK3C,OAAAC,MAAA,KAAK,qBAAL,gBAAAA,IAAA,WAAwB,UAAU,CAAC,MAAa,KAAK,eAAe,CAAC;AAAA,IAAC;AAAA;AAAA;AAAA;AAAA,IAlFxE,IAAgB,sBAAqC;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAArD,IAAgB,oBAAqC,OAAA;AAAA,yBAAA,uCAAA;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA,IAOrD,IAAgB,WAA0B;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA1C,IAAgB,SAA0B,OAAA;AAAA,yBAAA,4BAAA;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA,IAM1C,IAAW,MAAM,KAAkB;AACjC,WAAK,iBAAiB;AAClB,UAAA,CAAC,KAAK,UAAU;AAClB;AAAA,MAAA;AAEF,UAAI,OAAO,MAAM;AACf,aAAK,aAAa,QAAQ,CAAC,MAAO,EAAE,UAAU,KAAM;AACpD;AAAA,MAAA;AAEI,YAAA,UAAU,KAAK,aAAa,KAAK,CAAC,MAAM,EAAE,UAAU,GAAG;AAC7D,UAAI,SAAS;AACX,gBAAQ,UAAU;AAAA,MAAA;AAAA,IACpB;AAAA,IAEF,IAAW,QAAK;;AACd,eAAOA,MAAA,KAAK,aAAa,KAAK,CAAC,MAAM,EAAE,WAAW,CAAC,EAAE,QAAQ,MAAtD,gBAAAA,IAAyD,UAAS,KAAK;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAWpE,IAAgB,OAAiD;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAjE,IAAgB,KAAiD,OAAA;AAAA,yBAAA,wBAAA;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA,IAM7E,IAAgB,iBAAgD;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAhE,IAAgB,eAAgD,OAAA;AAAA,yBAAA,kCAAA;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA,IAMhE,IAAgB,cAA2C;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA3D,IAAgB,YAA2C,OAAA;AAAA,yBAAA,+BAAA;AAAA,IAAA;AAAA,IAI3D,IAAgB,OAAoD;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAApE,IAAgB,KAAoD,OAAA;AAAA,yBAAA,wBAAA;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA,IAKpE,IAAW,eAAY;;AACrB,aACE,MAAM,OAAKA,MAAA,KAAK,qBAAL,gBAAAA,IAAA,WAAwB,gDAA+C,CAAE,CAAA,EAIpF,OAAO,CAAC,OAAO;;AAAA,iBAAAA,MAAA,GAAG,YAAH,gBAAAA,IAAA,SAAa,+BAA8B;AAAA,OAAI;AAAA,IAAA;AAAA,IAmBlD,oBAAiB;;AAC/B,YAAM,kBAAiB;AACvB,WAAK,gBACH,kBACA,CAAC,GAACA,MAAA,KAAK,kBAAL,gBAAAA,IAAA,WAAqB,yDAAwD;AAAA,IAAA;AAAA,IAInE,WAAW,mBAAuC;AAChE,YAAM,WAAW,iBAAiB;AAE9B,UAAA,kBAAkB,IAAI,UAAU,GAAG;AACrC,aAAK,aAAa,QAAQ,CAAC;;AAAM,kBAAAA,MAAA,EAAE,kBAAF,gBAAAA,IAAA,QAAkB;AAAA,SAAW;AAAA,MAAA;AAE5D,UAAA,kBAAkB,IAAI,UAAU,GAAG;AACrC,aAAK,aAAa,QAAQ,CAAC;;AAAM,kBAAAA,MAAA,EAAE,kBAAF,gBAAAA,IAAA,QAAkB;AAAA,SAAW;AAAA,MAAA;AAE5D,UAAA,kBAAkB,IAAI,MAAM,GAAG;AACjC,aAAK,aAAa,QAAQ,CAAC;;AAAM,kBAAAA,MAAA,EAAE,kBAAF,gBAAAA,IAAA,QAAkB;AAAA,SAAO;AAAA,MAAA;AAExD,UAAA,kBAAkB,IAAI,MAAM,GAAG;AACjC,aAAK,kBAAiB;AAAA,MAAA;AAAA,IACxB;AAAA,IAGiB,MAAM,aAAa,mBAAuC;AAC3E,YAAM,aAAa,iBAAiB;AACpC,WAAK,WAAW;AAEhB,YAAM,KAAK;AACX,WAAK,kBAAiB;AAAA,IAAA;AAAA,IAGhB,eAAe,OAAY;AACjC,YAAM,SAAS,MAAM;AAGrB,UAAI,OAAO,cAAc,sBAAsB,OAAO,cAAc,0BAA0B;AAC5F;AAAA,MAAA;AAGF,WAAK,iBAAiB;AACtB,WAAK,WAAW;;;;;IAMV,oBAAiB;AACvB,WAAK,aAAa,QAAQ,CAAC,MAAO,EAAE,OAAO,KAAK,IAAK;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAO/C,oBAAiB;AACvB,UAAI,KAAK,gBAAgB;AAEvB,aAAK,QAAQ,KAAK;AAAA,MAAA;AAAA,IACpB;AAAA,IAGiB,SAAM;AAChB,aAAA;AAAA;AAAA;AAAA,wBAGa,MAAK;AACjB,aAAK,kBAAiB;AACtB,aAAK,kBAAiB;AAAA,MACvB,CAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAAA;AAAA,KA3JT,uDAOA,4CAgCY,wCAMZ,kDAMA,+CAIA;;AAzDC,sCAAA,CAAA,UAAW,GACX,SAAS,EAAE,WAAW,yBAAyB,MAAM,SAAS,CAAC;4BAM/D,aACA,SAAS,EAAE,MAAM,QAAA,CAAS,CAAC;AAM3B,4BAAA,CAAA,UAAU;AA2BV,uBAAA,CAAA,UAAU;kCAKV,SAAS,EAAE,WAAW,mBAAmB,SAAS,KAAA,CAAM,CAAC;AAMzD,8BAAA,CAAA,SAAS,EAAE,SAAS,KAAM,CAAA,CAAC;wBAG3B,aACA,UAAU;AAtDK,iBAAA,IAAA,MAAA,iCAAA,EAAA,MAAA,YAAA,MAAA,uBAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,yBAAA,KAAA,KAAA,CAAA,QAAA,IAAA,qBAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,sBAAqC;AAAA,SAAA,UAAA,aAAA,mCAAA,sCAAA;AAOrC,iBAAA,IAAA,MAAA,sBAAA,EAAA,MAAA,YAAA,MAAA,YAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,cAAA,KAAA,KAAA,CAAA,QAAA,IAAA,UAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,WAA0B;AAAA,SAAA,UAAA,aAAA,wBAAA,2BAAA;AAM1C,iBAAA,IAAA,MAAA,uBAAA,EAAA,MAAA,UAAA,MAAA,SAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,WAAA,KAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAW,QAaV;AAAA,SAAA,UAAA,aAAA,MAAA,0BAAA;AAa2B,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,OAAiD;AAAA,SAAA,UAAA,aAAA,oBAAA,uBAAA;AAM7D,iBAAA,IAAA,MAAA,4BAAA,EAAA,MAAA,YAAA,MAAA,kBAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,oBAAA,KAAA,KAAA,CAAA,QAAA,IAAA,gBAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,iBAAgD;AAAA,SAAA,UAAA,aAAA,8BAAA,iCAAA;AAMhD,iBAAA,IAAA,MAAA,yBAAA,EAAA,MAAA,YAAA,MAAA,eAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,iBAAA,KAAA,KAAA,CAAA,QAAA,IAAA,aAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,cAA2C;AAAA,SAAA,UAAA,aAAA,2BAAA,8BAAA;AAI3C,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,OAAoD;AAAA,SAAA,UAAA,aAAA,oBAAA,uBAAA;AApEtE,iBAgLC,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QA/KwB,GAAM,SAAmB,OACzB,GAAA,SAAS;AAAA,IAC9B,WAAW;AAAA,IACX,QAAQ;AAAA,IACR,OAAO;AAAA,EACC,GANN,kBAA0B,YAAA,uBAAA,GAAC;;;"}
|
|
@@ -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;
|
|
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
|
-
|
|
107
|
-
|
|
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,
|
|
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,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,
|
|
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"}
|
package/radio-button/common.js
CHANGED
|
@@ -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 {
|
|
5
|
-
import {
|
|
6
|
-
|
|
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
|
|
10
|
-
return o = class extends
|
|
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,
|
|
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(
|
|
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,
|
|
61
|
-
e.allowEmptySelection =
|
|
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
|
-
})(),
|
|
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
|
-
|
|
71
|
-
|
|
65
|
+
x as SbbRadioButtonCommonElementMixin,
|
|
66
|
+
w as radioButtonCommonStyle
|
|
72
67
|
};
|
|
@@ -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;
|
|
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
|
|
2
|
-
throw TypeError(
|
|
1
|
+
var f = (t) => {
|
|
2
|
+
throw TypeError(t);
|
|
3
3
|
};
|
|
4
|
-
var
|
|
5
|
-
var
|
|
6
|
-
import { __runInitializers as b, __esDecorate as
|
|
7
|
-
import { LitElement as
|
|
8
|
-
import { customElement as
|
|
9
|
-
import { slotState as
|
|
10
|
-
import { isLean as
|
|
11
|
-
import {
|
|
12
|
-
import {
|
|
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
|
|
15
|
+
let N = (() => {
|
|
15
16
|
var o, l;
|
|
16
|
-
let
|
|
17
|
-
|
|
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
|
-
|
|
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
|
|
29
|
+
return y(this, o);
|
|
29
30
|
}
|
|
30
|
-
set size(
|
|
31
|
-
|
|
31
|
+
set size(e) {
|
|
32
|
+
d(this, o, e);
|
|
32
33
|
}
|
|
33
34
|
connectedCallback() {
|
|
34
|
-
var
|
|
35
|
-
super.connectedCallback(), this._hasSelectionExpansionPanelElement = !!((
|
|
35
|
+
var e;
|
|
36
|
+
super.connectedCallback(), this._hasSelectionExpansionPanelElement = !!((e = this.closest) != null && e.call(this, "sbb-selection-expansion-panel"));
|
|
36
37
|
}
|
|
37
|
-
willUpdate(
|
|
38
|
-
super.willUpdate(
|
|
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(
|
|
50
|
-
this._hasSelectionExpansionPanelElement ?
|
|
50
|
+
async navigateByKeyboard(e) {
|
|
51
|
+
this._hasSelectionExpansionPanelElement ? e.focus() : await super.navigateByKeyboard(e);
|
|
51
52
|
}
|
|
52
53
|
render() {
|
|
53
|
-
return
|
|
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 ?
|
|
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
|
|
71
|
-
|
|
72
|
-
var
|
|
73
|
-
return (
|
|
74
|
-
})],
|
|
75
|
-
a.size =
|
|
76
|
-
} }, metadata:
|
|
77
|
-
})(), l.styles = [
|
|
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
|
-
|
|
81
|
+
panelConnected: "panelConnected",
|
|
82
|
+
stateChange: "stateChange"
|
|
83
|
+
}, b(n, i), l);
|
|
84
|
+
return r = n;
|
|
83
85
|
})();
|
|
84
86
|
export {
|
|
85
|
-
|
|
87
|
+
N as SbbRadioButtonPanelElement
|
|
86
88
|
};
|