@sellmate/design-system 1.0.0 → 1.0.1
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/dist/cjs/design-system.cjs.js +1 -1
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/cjs/sd-badge.cjs.entry.js +1 -1
- package/dist/cjs/sd-button_6.cjs.entry.js +6 -6
- package/dist/cjs/sd-card.cjs.entry.js +1 -1
- package/dist/cjs/sd-date-picker.cjs.entry.js +1 -1
- package/dist/cjs/sd-date-range-picker.cjs.entry.js +2 -2
- package/dist/cjs/sd-field_3.cjs.entry.js +5 -5
- package/dist/cjs/sd-file-picker.cjs.entry.js +4 -5
- package/dist/cjs/sd-guide.cjs.entry.js +2 -2
- package/dist/cjs/sd-loading-spinner_2.cjs.entry.js +2 -2
- package/dist/cjs/sd-number-input.cjs.entry.js +4 -4
- package/dist/cjs/sd-popover.cjs.entry.js +2 -2
- package/dist/cjs/sd-progress.cjs.entry.js +2 -2
- package/dist/cjs/sd-radio-button-group.cjs.entry.js +3 -3
- package/dist/cjs/sd-radio-group.cjs.entry.js +8 -36
- package/dist/cjs/sd-radio.cjs.entry.js +41 -0
- package/dist/cjs/sd-select-dropdown_3.cjs.entry.js +6 -6
- package/dist/cjs/sd-select-multiple-group.cjs.entry.js +1 -1
- package/dist/cjs/sd-select-multiple.cjs.entry.js +1 -1
- package/dist/cjs/sd-select-option-group.cjs.entry.js +3 -3
- package/dist/cjs/sd-table.cjs.entry.js +4 -4
- package/dist/cjs/sd-tabs.cjs.entry.js +1 -1
- package/dist/cjs/sd-tag.cjs.entry.js +1 -1
- package/dist/cjs/sd-toast-message.cjs.entry.js +2 -2
- package/dist/cjs/sd-toggle-button.cjs.entry.js +1 -1
- package/dist/cjs/sd-toggle.cjs.entry.js +1 -1
- package/dist/collection/collection-manifest.json +1 -0
- package/dist/collection/components/sd-badge/sd-badge.js +1 -1
- package/dist/collection/components/sd-card/sd-card.js +1 -1
- package/dist/collection/components/sd-date-picker/sd-date-picker.js +1 -1
- package/dist/collection/components/sd-date-range-picker/sd-date-range-picker.js +2 -2
- package/dist/collection/components/sd-field/sd-field.js +3 -3
- package/dist/collection/components/sd-file-picker/sd-file-picker.css +2 -0
- package/dist/collection/components/sd-file-picker/sd-file-picker.js +3 -23
- package/dist/collection/components/sd-file-picker/sd-file-picker.js.map +1 -1
- package/dist/collection/components/sd-floating-portal/sd-floating-portal.js +1 -1
- package/dist/collection/components/sd-guide/sd-guide.js +2 -2
- package/dist/collection/components/sd-icon/sd-icon.js +1 -1
- package/dist/collection/components/sd-input/sd-input.js +1 -1
- package/dist/collection/components/sd-loading-spinner/sd-loading-spinner.js +1 -1
- package/dist/collection/components/sd-number-input/sd-number-input.js +4 -4
- package/dist/collection/components/sd-pagination/sd-pagination.js +2 -2
- package/dist/collection/components/sd-popover/sd-popover.js +2 -2
- package/dist/collection/components/sd-popover/sd-popover.js.map +1 -1
- package/dist/collection/components/sd-portal/sd-portal.js +1 -1
- package/dist/collection/components/sd-progress/sd-progress.js +2 -2
- package/dist/collection/components/sd-radio/sd-radio.css +59 -0
- package/dist/collection/components/sd-radio/sd-radio.js +151 -0
- package/dist/collection/components/sd-radio/sd-radio.js.map +1 -0
- package/dist/collection/components/sd-radio-button-group/sd-radio-button-group.css +20 -19
- package/dist/collection/components/sd-radio-button-group/sd-radio-button-group.js +3 -3
- package/dist/collection/components/sd-radio-button-group/sd-radio-button-group.js.map +1 -1
- package/dist/collection/components/sd-radio-group/sd-radio-group.css +34 -38
- package/dist/collection/components/sd-radio-group/sd-radio-group.js +17 -50
- package/dist/collection/components/sd-radio-group/sd-radio-group.js.map +1 -1
- package/dist/collection/components/sd-select/sd-select-dropdown/sd-select-dropdown.js +2 -2
- package/dist/collection/components/sd-select/sd-select-option/sd-select-option.js +1 -1
- package/dist/collection/components/sd-select/sd-select-search-input/sd-select-search-input.js +3 -3
- package/dist/collection/components/sd-select/sd-select.js +1 -1
- package/dist/collection/components/sd-select-multiple/sd-select-multiple.js +1 -1
- package/dist/collection/components/sd-select-multiple-group/sd-select-multiple-group.js +1 -1
- package/dist/collection/components/sd-select-multiple-group/sd-select-option-group/sd-select-option-group.js +3 -3
- package/dist/collection/components/sd-table/sd-table.js +4 -4
- package/dist/collection/components/sd-tabs/sd-tabs.js +1 -1
- package/dist/collection/components/sd-tag/sd-tag.js +1 -1
- package/dist/collection/components/sd-textarea/sd-textarea.js +2 -2
- package/dist/collection/components/sd-toast-message/sd-toast-message.js +2 -2
- package/dist/collection/components/sd-toggle/sd-toggle.js +1 -1
- package/dist/collection/components/sd-toggle-button/sd-toggle-button.js +1 -1
- package/dist/components/{p-CdGD6AqM.js → p-B-HVIIWo.js} +3 -3
- package/dist/components/{p-CdGD6AqM.js.map → p-B-HVIIWo.js.map} +1 -1
- package/dist/components/p-BBVGfsbU.js +62 -0
- package/dist/components/p-BBVGfsbU.js.map +1 -0
- package/dist/components/{p-RhBqdixM.js → p-BfHejNRG.js} +11 -11
- package/dist/components/{p-RhBqdixM.js.map → p-BfHejNRG.js.map} +1 -1
- package/dist/components/{p-JF61vPAh.js → p-BsBjOh8u.js} +5 -5
- package/dist/components/{p-JF61vPAh.js.map → p-BsBjOh8u.js.map} +1 -1
- package/dist/components/{p-CVMprLsE.js → p-CmghyzXg.js} +3 -3
- package/dist/components/{p-CVMprLsE.js.map → p-CmghyzXg.js.map} +1 -1
- package/dist/components/{p-D54IEoI6.js → p-Cp2TqeFd.js} +8 -8
- package/dist/components/{p-D54IEoI6.js.map → p-Cp2TqeFd.js.map} +1 -1
- package/dist/components/{p-DxSmO6Tr.js → p-CuHSbj5E.js} +5 -5
- package/dist/components/{p-DxSmO6Tr.js.map → p-CuHSbj5E.js.map} +1 -1
- package/dist/components/{p-DdKGhMHk.js → p-D1kEesx2.js} +3 -3
- package/dist/components/{p-DdKGhMHk.js.map → p-D1kEesx2.js.map} +1 -1
- package/dist/components/{p-zvZtN3nR.js → p-DBzZUOVq.js} +7 -7
- package/dist/components/{p-zvZtN3nR.js.map → p-DBzZUOVq.js.map} +1 -1
- package/dist/components/{p-s4Mg_xSz.js → p-DD16YjVA.js} +13 -13
- package/dist/components/{p-s4Mg_xSz.js.map → p-DD16YjVA.js.map} +1 -1
- package/dist/components/{p-7xekTQRB.js → p-Dtljyq_t.js} +5 -5
- package/dist/components/{p-7xekTQRB.js.map → p-Dtljyq_t.js.map} +1 -1
- package/dist/components/{p-CpRkV7pg.js → p-FVxa2OYe.js} +9 -9
- package/dist/components/{p-CpRkV7pg.js.map → p-FVxa2OYe.js.map} +1 -1
- package/dist/components/{p-DnQF6htq.js → p-Sw7TJWkF.js} +3 -3
- package/dist/components/{p-DnQF6htq.js.map → p-Sw7TJWkF.js.map} +1 -1
- package/dist/components/{p-DssRJcAn.js → p-VrppUi4Q.js} +3 -3
- package/dist/components/{p-DssRJcAn.js.map → p-VrppUi4Q.js.map} +1 -1
- package/dist/components/{p-D2movWkD.js → p-iBNSlotR.js} +14 -14
- package/dist/components/{p-D2movWkD.js.map → p-iBNSlotR.js.map} +1 -1
- package/dist/components/{p-UZEmuyIR.js → p-ldcuoYNT.js} +3 -3
- package/dist/components/{p-UZEmuyIR.js.map → p-ldcuoYNT.js.map} +1 -1
- package/dist/components/{p-DbebUQwg.js → p-o-oFeHDX.js} +3 -3
- package/dist/components/{p-DbebUQwg.js.map → p-o-oFeHDX.js.map} +1 -1
- package/dist/components/sd-badge.js +1 -1
- package/dist/components/sd-button.js +1 -1
- package/dist/components/sd-card.js +1 -1
- package/dist/components/sd-checkbox.js +1 -1
- package/dist/components/sd-date-picker.js +8 -8
- package/dist/components/sd-date-range-picker.js +9 -9
- package/dist/components/sd-field.js +1 -1
- package/dist/components/sd-file-picker.js +5 -7
- package/dist/components/sd-file-picker.js.map +1 -1
- package/dist/components/sd-floating-portal.js +1 -1
- package/dist/components/sd-guide.js +5 -5
- package/dist/components/sd-icon.js +1 -1
- package/dist/components/sd-input.js +1 -1
- package/dist/components/sd-loading-spinner.js +1 -1
- package/dist/components/sd-modal-card.js +2 -2
- package/dist/components/sd-number-input.js +5 -5
- package/dist/components/sd-pagination.js +1 -1
- package/dist/components/sd-popover.js +5 -5
- package/dist/components/sd-popover.js.map +1 -1
- package/dist/components/sd-portal.js +1 -1
- package/dist/components/sd-progress.js +2 -2
- package/dist/components/sd-radio-button-group.js +4 -4
- package/dist/components/sd-radio-button-group.js.map +1 -1
- package/dist/components/sd-radio-group.js +16 -39
- package/dist/components/sd-radio-group.js.map +1 -1
- package/dist/components/sd-radio.d.ts +11 -0
- package/dist/components/sd-radio.js +9 -0
- package/dist/components/sd-radio.js.map +1 -0
- package/dist/components/sd-select-dropdown.js +1 -1
- package/dist/components/sd-select-multiple-group.js +11 -11
- package/dist/components/sd-select-multiple.js +12 -12
- package/dist/components/sd-select-option-group.js +1 -1
- package/dist/components/sd-select-option.js +1 -1
- package/dist/components/sd-select-search-input.js +1 -1
- package/dist/components/sd-select.js +1 -1
- package/dist/components/sd-table.js +18 -18
- package/dist/components/sd-tabs.js +2 -2
- package/dist/components/sd-tag.js +1 -1
- package/dist/components/sd-textarea.js +2 -2
- package/dist/components/sd-toast-message.js +4 -4
- package/dist/components/sd-toggle-button.js +1 -1
- package/dist/components/sd-toggle.js +1 -1
- package/dist/components/sd-tooltip.js +1 -1
- package/dist/design-system/design-system.esm.js +1 -1
- package/dist/design-system/{p-d77422e4.entry.js → p-06b1b928.entry.js} +2 -2
- package/dist/design-system/{p-f254b09a.entry.js → p-0a80eff0.entry.js} +2 -2
- package/dist/design-system/p-0a9f4be0.entry.js +2 -0
- package/dist/design-system/p-0a9f4be0.entry.js.map +1 -0
- package/dist/design-system/p-0e12f7b6.entry.js +2 -0
- package/dist/design-system/{p-f3287206.entry.js → p-12c9cfda.entry.js} +2 -2
- package/dist/design-system/{p-02e23509.entry.js → p-17f36d15.entry.js} +2 -2
- package/dist/design-system/{p-9d2459ed.entry.js → p-1a5c8581.entry.js} +2 -2
- package/dist/design-system/{p-53972259.entry.js → p-2023e24a.entry.js} +2 -2
- package/dist/design-system/{p-0d3f019d.entry.js → p-206de2a1.entry.js} +2 -2
- package/dist/design-system/p-29a9975a.entry.js +2 -0
- package/dist/design-system/p-29a9975a.entry.js.map +1 -0
- package/dist/design-system/{p-ac29c52c.entry.js → p-43b9fd6b.entry.js} +2 -2
- package/dist/design-system/p-7a18002e.entry.js +2 -0
- package/dist/design-system/p-7a18002e.entry.js.map +1 -0
- package/dist/design-system/{p-0a2f733d.entry.js → p-82356c0a.entry.js} +2 -2
- package/dist/design-system/{p-811c5aa4.entry.js → p-86830071.entry.js} +2 -2
- package/dist/design-system/{p-6277b220.entry.js → p-97d0ce6e.entry.js} +2 -2
- package/dist/design-system/p-9a68ab88.entry.js +2 -0
- package/dist/design-system/{p-c3061828.entry.js.map → p-9a68ab88.entry.js.map} +1 -1
- package/dist/design-system/{p-686958c5.entry.js → p-9fdf431c.entry.js} +2 -2
- package/dist/design-system/{p-c25c4bd6.entry.js → p-b521ce06.entry.js} +2 -2
- package/dist/design-system/p-cdd7880f.entry.js +2 -0
- package/dist/design-system/p-cdd7880f.entry.js.map +1 -0
- package/dist/design-system/{p-2400d67b.entry.js → p-dc2f4b2f.entry.js} +2 -2
- package/dist/design-system/{p-388d5b9f.entry.js → p-f43b8c46.entry.js} +2 -2
- package/dist/design-system/{p-652c4d37.entry.js → p-f8e3d576.entry.js} +2 -2
- package/dist/design-system/{p-a7d4c6bd.entry.js → p-f9bc026f.entry.js} +2 -2
- package/dist/design-system/{p-4d7bb5b6.entry.js → p-fca80354.entry.js} +2 -2
- package/dist/design-system/p-ff131fbc.entry.js +2 -0
- package/dist/design-system/p-ff131fbc.entry.js.map +1 -0
- package/dist/esm/design-system.js +1 -1
- package/dist/esm/loader.js +1 -1
- package/dist/esm/sd-badge.entry.js +1 -1
- package/dist/esm/sd-button_6.entry.js +6 -6
- package/dist/esm/sd-card.entry.js +1 -1
- package/dist/esm/sd-date-picker.entry.js +1 -1
- package/dist/esm/sd-date-range-picker.entry.js +2 -2
- package/dist/esm/sd-field_3.entry.js +5 -5
- package/dist/esm/sd-file-picker.entry.js +4 -5
- package/dist/esm/sd-file-picker.entry.js.map +1 -1
- package/dist/esm/sd-guide.entry.js +2 -2
- package/dist/esm/sd-loading-spinner_2.entry.js +2 -2
- package/dist/esm/sd-number-input.entry.js +4 -4
- package/dist/esm/sd-popover.entry.js +2 -2
- package/dist/esm/sd-popover.entry.js.map +1 -1
- package/dist/esm/sd-progress.entry.js +2 -2
- package/dist/esm/sd-radio-button-group.entry.js +4 -4
- package/dist/esm/sd-radio-button-group.entry.js.map +1 -1
- package/dist/esm/sd-radio-group.entry.js +8 -36
- package/dist/esm/sd-radio-group.entry.js.map +1 -1
- package/dist/esm/sd-radio.entry.js +39 -0
- package/dist/esm/sd-radio.entry.js.map +1 -0
- package/dist/esm/sd-select-dropdown_3.entry.js +6 -6
- package/dist/esm/sd-select-multiple-group.entry.js +1 -1
- package/dist/esm/sd-select-multiple.entry.js +1 -1
- package/dist/esm/sd-select-option-group.entry.js +3 -3
- package/dist/esm/sd-table.entry.js +4 -4
- package/dist/esm/sd-tabs.entry.js +1 -1
- package/dist/esm/sd-tag.entry.js +1 -1
- package/dist/esm/sd-toast-message.entry.js +2 -2
- package/dist/esm/sd-toggle-button.entry.js +1 -1
- package/dist/esm/sd-toggle.entry.js +1 -1
- package/dist/types/components/sd-file-picker/sd-file-picker.d.ts +0 -1
- package/dist/types/components/sd-radio/sd-radio.d.ts +12 -0
- package/dist/types/components/sd-radio-group/sd-radio-group.d.ts +3 -8
- package/dist/types/components.d.ts +63 -18
- package/hydrate/index.js +114 -96
- package/hydrate/index.mjs +114 -96
- package/package.json +2 -2
- package/dist/design-system/p-15dd1289.entry.js +0 -2
- package/dist/design-system/p-15dd1289.entry.js.map +0 -1
- package/dist/design-system/p-216c6543.entry.js +0 -2
- package/dist/design-system/p-216c6543.entry.js.map +0 -1
- package/dist/design-system/p-282f4087.entry.js +0 -2
- package/dist/design-system/p-b0277422.entry.js +0 -2
- package/dist/design-system/p-b0277422.entry.js.map +0 -1
- package/dist/design-system/p-c3061828.entry.js +0 -2
- package/dist/design-system/p-cde56c79.entry.js +0 -2
- package/dist/design-system/p-cde56c79.entry.js.map +0 -1
- /package/dist/design-system/{p-d77422e4.entry.js.map → p-06b1b928.entry.js.map} +0 -0
- /package/dist/design-system/{p-f254b09a.entry.js.map → p-0a80eff0.entry.js.map} +0 -0
- /package/dist/design-system/{p-282f4087.entry.js.map → p-0e12f7b6.entry.js.map} +0 -0
- /package/dist/design-system/{p-f3287206.entry.js.map → p-12c9cfda.entry.js.map} +0 -0
- /package/dist/design-system/{p-02e23509.entry.js.map → p-17f36d15.entry.js.map} +0 -0
- /package/dist/design-system/{p-9d2459ed.entry.js.map → p-1a5c8581.entry.js.map} +0 -0
- /package/dist/design-system/{p-53972259.entry.js.map → p-2023e24a.entry.js.map} +0 -0
- /package/dist/design-system/{p-0d3f019d.entry.js.map → p-206de2a1.entry.js.map} +0 -0
- /package/dist/design-system/{p-ac29c52c.entry.js.map → p-43b9fd6b.entry.js.map} +0 -0
- /package/dist/design-system/{p-0a2f733d.entry.js.map → p-82356c0a.entry.js.map} +0 -0
- /package/dist/design-system/{p-811c5aa4.entry.js.map → p-86830071.entry.js.map} +0 -0
- /package/dist/design-system/{p-6277b220.entry.js.map → p-97d0ce6e.entry.js.map} +0 -0
- /package/dist/design-system/{p-686958c5.entry.js.map → p-9fdf431c.entry.js.map} +0 -0
- /package/dist/design-system/{p-c25c4bd6.entry.js.map → p-b521ce06.entry.js.map} +0 -0
- /package/dist/design-system/{p-2400d67b.entry.js.map → p-dc2f4b2f.entry.js.map} +0 -0
- /package/dist/design-system/{p-388d5b9f.entry.js.map → p-f43b8c46.entry.js.map} +0 -0
- /package/dist/design-system/{p-652c4d37.entry.js.map → p-f8e3d576.entry.js.map} +0 -0
- /package/dist/design-system/{p-a7d4c6bd.entry.js.map → p-f9bc026f.entry.js.map} +0 -0
- /package/dist/design-system/{p-4d7bb5b6.entry.js.map → p-fca80354.entry.js.map} +0 -0
|
@@ -6,7 +6,7 @@ export class SdLoadingSpinner {
|
|
|
6
6
|
return resolveColor(this.color);
|
|
7
7
|
}
|
|
8
8
|
render() {
|
|
9
|
-
return (h(Host, { key: '
|
|
9
|
+
return (h(Host, { key: '90e8d5b70e299835006b59d8240e0e0a526c14f7' }, h("svg", { key: '22c2e6c4a638440fd97abc82ebcba99a26a6e13c', class: "sd-loading-spinner", width: "72px", height: "72px", viewBox: "25 25 50 50", style: { color: this.resolvedColor } }, h("circle", { key: '41470486ab808e13a8d9fa0815b1a26436d6ca79', class: "path", cx: "50", cy: "50", r: "20", fill: "none", stroke: "currentColor", "stroke-width": "5", "stroke-miterlimit": "10" }))));
|
|
10
10
|
}
|
|
11
11
|
static get is() { return "sd-loading-spinner"; }
|
|
12
12
|
static get originalStyleUrls() {
|
|
@@ -227,17 +227,17 @@ export class SdNumberInput {
|
|
|
227
227
|
const inputStyles = {
|
|
228
228
|
textAlign: this.useButton ? 'center' : 'right',
|
|
229
229
|
};
|
|
230
|
-
return (h(Host, { key: '
|
|
230
|
+
return (h(Host, { key: '808776f5dac544141ffd67482d23a9e04c410900', style: inputWidth, onFocus: this.handleFocus, onBlur: this.handleBlur }, this.useButton ? 'use buttons' : 'dont use buttons', this.label && h("div", { key: '0c4ebbbfbe31d9d01f1652e7a2135e56c7d8bbb1', class: "sd-number-input__label" }, this.label), h("label", { key: 'c25ba6871d48f13a082f04a42e0d412e806031fc', class: {
|
|
231
231
|
'sd-number-input': true,
|
|
232
232
|
[this.getInputStatus()]: true,
|
|
233
233
|
'sd-number-input--with-buttons': this.useButton,
|
|
234
|
-
}, onMouseEnter: () => (this.hovered = true), onMouseLeave: () => (this.hovered = false), style: this.inputStyle }, h("input", { key: '
|
|
234
|
+
}, onMouseEnter: () => (this.hovered = true), onMouseLeave: () => (this.hovered = false), style: this.inputStyle }, h("input", { key: 'f2c88d5209f1886de1c7f89af8e7b1778bdc2ac1', ref: el => (this.nativeEl = el), class: `sd-number-input__input ${this.inputClass}`, type: "text", inputMode: "numeric", value: this.displayValue, placeholder: this.placeholder, disabled: this.disabled, readonly: this.readonly, autofocus: this.autoFocus, onInput: this.handleInput, onKeyDown: this.handleKeyDown, style: inputStyles }), this.useButton && (h("div", { key: '4c66e1a5b8880fed901aa6656e2e49ce817ae991', class: "sd-number-input__buttons" }, h("button", { key: '39e2935eae836c7f209deebaa2c5ad79d8643920', type: "button", class: {
|
|
235
235
|
'sd-number-input__button': true,
|
|
236
236
|
'sd-number-input__button--decrement': true,
|
|
237
|
-
}, disabled: this.isDecrementDisabled(), onClick: this.handleDecrement, tabindex: -1 }, h("sd-icon", { key: '
|
|
237
|
+
}, disabled: this.isDecrementDisabled(), onClick: this.handleDecrement, tabindex: -1 }, h("sd-icon", { key: 'a81ba14b5ebc2a46a2349fbb2de1015a2e1894a1', name: "minus", size: 12, color: this.isDecrementDisabled() ? '#CCCCCC' : '#2D8DFF' })), h("button", { key: '2f2e8948470c699124b99e6862bf112bb79d7721', type: "button", class: {
|
|
238
238
|
'sd-number-input__button': true,
|
|
239
239
|
'sd-number-input__button--increment': true,
|
|
240
|
-
}, disabled: this.isIncrementDisabled(), onClick: this.handleIncrement, tabindex: -1 }, h("sd-icon", { key: '
|
|
240
|
+
}, disabled: this.isIncrementDisabled(), onClick: this.handleIncrement, tabindex: -1 }, h("sd-icon", { key: 'c269060a857285fa060d4c4971235cc9fb4e991a', name: "add", size: 12, color: this.isIncrementDisabled() ? '#CCCCCC' : '#2D8DFF' })))))));
|
|
241
241
|
}
|
|
242
242
|
static get is() { return "sd-number-input"; }
|
|
243
243
|
static get originalStyleUrls() {
|
|
@@ -68,12 +68,12 @@ export class SdPagination {
|
|
|
68
68
|
}
|
|
69
69
|
}
|
|
70
70
|
render() {
|
|
71
|
-
return (h("div", { key: '
|
|
71
|
+
return (h("div", { key: '7498d55ef3206deb0c3feb22cd1da426f754eb05', class: this.paginationClasses }, h("div", { key: '60918ebae391824240a8c182360751426c07c69c', class: "prepend-btns" }, this.renderPrevButtons()), this.simple ? (h("div", { class: "pagination-info" }, h("span", { class: "current-page" }, this.currentPage), h("span", null, "/"), h("span", { class: "last-page" }, this.lastPage))) : (this.pageNumbers.map(n => (h("button", { type: "button", "aria-current": this.currentPage === n ? 'page' : undefined, class: {
|
|
72
72
|
'pagination-btn': true,
|
|
73
73
|
'pagination-btn--selected': this.currentPage === n,
|
|
74
74
|
}, disabled: this.currentPage === n, style: {
|
|
75
75
|
'--pagination-btn-width': `${this.buttonWidth}px`,
|
|
76
|
-
}, onClick: () => this.handlePageChange(n) }, n)))), h("div", { key: '
|
|
76
|
+
}, onClick: () => this.handlePageChange(n) }, n)))), h("div", { key: 'c827cf8b7d8d8013b85487891fc768dcbe172be9', class: "append-btns" }, this.renderNextButtons())));
|
|
77
77
|
}
|
|
78
78
|
static get is() { return "sd-pagination"; }
|
|
79
79
|
static get originalStyleUrls() {
|
|
@@ -30,11 +30,11 @@ export class SdPopover {
|
|
|
30
30
|
this.showPopover = false;
|
|
31
31
|
};
|
|
32
32
|
render() {
|
|
33
|
-
return (h(Fragment, { key: '
|
|
33
|
+
return (h(Fragment, { key: '56f328cfb09847d3f5968c4ed73f805f5666e258' }, this.label ? (h("sd-button", { ref: el => (this.buttonEl = el), label: this.label, icon: this.icon, size: this.buttonSize, color: this.color, variant: this.buttonVariant, class: "sd-popover", onClick: () => (this.showPopover = !this.showPopover) })) : (h("sd-icon", { ref: el => (this.buttonEl = el), name: this.icon, size: this.iconSize, color: this.color, class: "sd-popover", onClick: () => (this.showPopover = !this.showPopover) })), this.showPopover && (h("sd-floating-portal", { key: '8b6a8ce42c1464780fb089098fdda82600eefc86', parentRef: this.buttonEl, onSdClose: this.handleClose, placement: this.placement }, h("div", { key: '0cbeee5bb4a514bc2e1009d5d97c27fd8a309fd2', class: {
|
|
34
34
|
'sd-floating-menu': true,
|
|
35
35
|
[`sd-floating-menu--${this.placement}`]: true,
|
|
36
36
|
[this.menuClass]: !!this.menuClass,
|
|
37
|
-
} }, h("i", { key: '
|
|
37
|
+
} }, h("i", { key: 'd8f244e430aaacaaa4b124d4ae613546ca3cb04a', class: `sd-floating-menu__arrow sd-floating-menu__arrow--${this.placement}` }, h(TooltipArrow, { key: 'b5a9d9878144eb0a6093a05e0c5287d2721304d8' })), h("div", { key: '919c8ea1a1421f9db1b8f002704cb443e69b27dd', class: "sd-floating-menu__content" }, this.menuTitle && h("div", { key: '3a1bd157db78b03e894dd9234b15a1e0a42a20ad', class: "sd-floating-menu__title" }, this.menuTitle), this.messages.length > 0 && (h("div", { key: '775a8c45c194fce139b78bdea6cf3ea7e1d6aebd', class: "sd-floating-menu__messages" }, this.messages.map(message => (h("div", null, message))))), this.buttons.length > 0 && (h("div", { key: '1da478df75490f7ba81a8463cbbeea26c6cff64d', class: `sd-floating-menu__buttons sd-floating-menu__buttons--${this.buttons.length}` }, this.buttons.map(button => (h("sd-button", { ...button })))))), this.useClose && (h("button", { key: 'ce75525effbcc448900cbea452a9787f66447444', title: "close", class: "sd-floating-menu__close-button", onClick: () => this.handleClose() }, h("sd-icon", { key: '2dc6e721412c49ff91ea60e2355be1f0143fc7fb', name: "close", size: "12", color: "gery_55" }))))))));
|
|
38
38
|
}
|
|
39
39
|
static get is() { return "sd-popover"; }
|
|
40
40
|
static get originalStyleUrls() {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sd-popover.js","sourceRoot":"","sources":["../../../src/components/sd-popover/sd-popover.tsx"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"sd-popover.js","sourceRoot":"","sources":["../../../src/components/sd-popover/sd-popover.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Element, Fragment, Prop, State, Watch, h } from '@stencil/core';\nimport { ButtonSize, ButtonVariant } from '../sd-button/sd-button';\nimport { TooltipArrow } from '../assets/tooltipArrow';\n\n@Component({\n tag: 'sd-popover',\n styleUrl: 'sd-popover.scss',\n})\nexport class SdPopover {\n @Element() el!: HTMLElement;\n\n @Prop({ mutable: true }) show: boolean = false;\n\n @Prop({ reflect: true }) placement: 'top' | 'bottom' | 'left' | 'right' = 'bottom';\n @Prop({ reflect: true }) color: string = '#01BB4B';\n\n @Prop({ reflect: true }) icon: IconName = 'helpOutline';\n @Prop({ reflect: true }) iconSize: number = 12;\n\n @Prop() label: string = '';\n @Prop({ reflect: true }) buttonSize: ButtonSize = 'sm';\n @Prop({ reflect: true }) buttonVariant: ButtonVariant = 'primary';\n\n @Prop({ attribute: 'title', reflect: true }) menuTitle?: string;\n @Prop({ reflect: true }) messages: string[] = [];\n @Prop({ reflect: true }) buttons: {\n [key: string]: any;\n }[] = [];\n @Prop() menuClass: string = '';\n\n @Prop() noHover: boolean = true;\n\n @Prop() useClose: boolean = false;\n\n @State() showPopover: boolean = false;\n @State() slotContent: string = '';\n\n @Watch('show')\n watchShowHandler(newValue: boolean) {\n this.showPopover = newValue;\n }\n\n componentWillLoad() {\n this.showPopover = this.show;\n\n this.slotContent = this.el.innerHTML;\n }\n\n private buttonEl?: HTMLElement;\n\n private handleClose = () => {\n this.showPopover = false;\n };\n\n render() {\n return (\n <Fragment>\n {this.label ? (\n <sd-button\n ref={el => (this.buttonEl = el as unknown as HTMLElement)}\n label={this.label}\n icon={this.icon}\n size={this.buttonSize}\n color={this.color}\n variant={this.buttonVariant}\n class=\"sd-popover\"\n onClick={() => (this.showPopover = !this.showPopover)}\n ></sd-button>\n ) : (\n <sd-icon\n ref={el => (this.buttonEl = el as unknown as HTMLElement)}\n name={this.icon}\n size={this.iconSize}\n color={this.color}\n class=\"sd-popover\"\n onClick={() => (this.showPopover = !this.showPopover)}\n ></sd-icon>\n )}\n\n {this.showPopover && (\n <sd-floating-portal\n parentRef={this.buttonEl}\n onSdClose={this.handleClose}\n placement={this.placement}\n >\n <div\n class={{\n 'sd-floating-menu': true,\n [`sd-floating-menu--${this.placement}`]: true,\n [this.menuClass]: !!this.menuClass,\n }}\n >\n <i class={`sd-floating-menu__arrow sd-floating-menu__arrow--${this.placement}`}>\n <TooltipArrow></TooltipArrow>\n </i>\n\n <div class=\"sd-floating-menu__content\">\n {this.menuTitle && <div class=\"sd-floating-menu__title\">{this.menuTitle}</div>}\n\n {this.messages.length > 0 && (\n <div class=\"sd-floating-menu__messages\">\n {this.messages.map(message => (\n <div>{message}</div>\n ))}\n </div>\n )}\n\n {this.buttons.length > 0 && (\n <div class={`sd-floating-menu__buttons sd-floating-menu__buttons--${this.buttons.length}`}>\n {this.buttons.map(button => (\n <sd-button {...button} />\n ))}\n </div>\n )}\n </div>\n\n {this.useClose && (\n <button\n title=\"close\"\n class=\"sd-floating-menu__close-button\"\n onClick={() => this.handleClose()}\n >\n <sd-icon name=\"close\" size=\"12\" color=\"gery_55\"></sd-icon>\n </button>\n )}\n </div>\n </sd-floating-portal>\n )}\n </Fragment>\n );\n }\n}\n"]}
|
|
@@ -113,7 +113,7 @@ export class SdPortal {
|
|
|
113
113
|
this.close.emit();
|
|
114
114
|
}
|
|
115
115
|
render() {
|
|
116
|
-
return h("slot", { key: '
|
|
116
|
+
return h("slot", { key: '6181685d61b1e95116316b72208702597bba2b8e' });
|
|
117
117
|
}
|
|
118
118
|
static get is() { return "sd-portal"; }
|
|
119
119
|
static get properties() {
|
|
@@ -33,10 +33,10 @@ export class SdProgress {
|
|
|
33
33
|
return this.statusColor[this.progressStatus];
|
|
34
34
|
}
|
|
35
35
|
render() {
|
|
36
|
-
return (h(Host, { key: '
|
|
36
|
+
return (h(Host, { key: '8990c8a3fb4c8bf0cb32dd4310e1e99519fca550', style: {
|
|
37
37
|
'--progress-color': this.progressColor,
|
|
38
38
|
'--progress-percentage': `${this.progressPercentage}%`,
|
|
39
|
-
} }, this.type === 'bar' ? this.renderBarProgress() : this.renderSpinnerProgress(), this.label && h("div", { key: '
|
|
39
|
+
} }, this.type === 'bar' ? this.renderBarProgress() : this.renderSpinnerProgress(), this.label && h("div", { key: '50a4d45d8658eec2b0d949b201fbf55b0d3615a4', class: "sd-progress__label" }, this.label)));
|
|
40
40
|
}
|
|
41
41
|
renderBarProgress() {
|
|
42
42
|
return (h("div", { class: `sd-progress__bar sd-progress__bar--${this.progressStatus}` }, h("div", { class: ['sd-progress__bar__percent', this.progressPercentage < 100 ? 'proceed' : ''].join(' ') }), h("div", { class: "sd-progress__bar__indicator sd-progress__bar__indicator--left" }, this.progressPercentage, "%"), h("div", { class: "sd-progress__bar__indicator sd-progress__bar__indicator--right" }, this.progressPercentage, "%")));
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
sd-radio {
|
|
2
|
+
display: inline-flex;
|
|
3
|
+
}
|
|
4
|
+
sd-radio.sd-radio {
|
|
5
|
+
cursor: pointer;
|
|
6
|
+
}
|
|
7
|
+
sd-radio.sd-radio label {
|
|
8
|
+
display: flex;
|
|
9
|
+
align-items: center;
|
|
10
|
+
gap: 8px;
|
|
11
|
+
cursor: pointer;
|
|
12
|
+
}
|
|
13
|
+
sd-radio.sd-radio label input {
|
|
14
|
+
position: relative;
|
|
15
|
+
appearance: none;
|
|
16
|
+
margin: 0;
|
|
17
|
+
width: 16px;
|
|
18
|
+
height: 16px;
|
|
19
|
+
border: 1px solid #888888;
|
|
20
|
+
border-radius: 50%;
|
|
21
|
+
accent-color: #0075ff;
|
|
22
|
+
background-color: white;
|
|
23
|
+
cursor: pointer;
|
|
24
|
+
}
|
|
25
|
+
sd-radio.sd-radio label input:checked {
|
|
26
|
+
border-color: #0075ff;
|
|
27
|
+
background-color: white;
|
|
28
|
+
}
|
|
29
|
+
sd-radio.sd-radio label input:checked::before {
|
|
30
|
+
content: "";
|
|
31
|
+
position: absolute;
|
|
32
|
+
top: 50%;
|
|
33
|
+
left: 50%;
|
|
34
|
+
transform: translate(-50%, -50%);
|
|
35
|
+
width: 10px;
|
|
36
|
+
height: 10px;
|
|
37
|
+
border-radius: 50%;
|
|
38
|
+
background-color: #0075ff;
|
|
39
|
+
}
|
|
40
|
+
sd-radio.sd-radio label input:disabled {
|
|
41
|
+
border-color: #cccccc;
|
|
42
|
+
background-color: #eeeeee;
|
|
43
|
+
}
|
|
44
|
+
sd-radio.sd-radio label input:disabled:checked::before {
|
|
45
|
+
background-color: #cccccc;
|
|
46
|
+
}
|
|
47
|
+
sd-radio.sd-radio label input:not(:disabled):hover {
|
|
48
|
+
border-color: #0075ff;
|
|
49
|
+
background-color: #d9eaff;
|
|
50
|
+
}
|
|
51
|
+
sd-radio.sd-radio--disabled {
|
|
52
|
+
cursor: not-allowed !important;
|
|
53
|
+
}
|
|
54
|
+
sd-radio.sd-radio--disabled label {
|
|
55
|
+
cursor: not-allowed !important;
|
|
56
|
+
}
|
|
57
|
+
sd-radio.sd-radio--disabled label input {
|
|
58
|
+
cursor: not-allowed !important;
|
|
59
|
+
}
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
import { h, Host } from "@stencil/core";
|
|
2
|
+
export class SdRadio {
|
|
3
|
+
value;
|
|
4
|
+
disabled = false;
|
|
5
|
+
val;
|
|
6
|
+
label;
|
|
7
|
+
update;
|
|
8
|
+
getRadioClasses() {
|
|
9
|
+
const classes = [
|
|
10
|
+
'sd-radio',
|
|
11
|
+
String(this.val) === String(this.value) ? 'sd-radio--selected' : 'sd-radio--unselected',
|
|
12
|
+
];
|
|
13
|
+
if (this.disabled) {
|
|
14
|
+
classes.push('sd-radio--disabled');
|
|
15
|
+
}
|
|
16
|
+
return classes.join(' ');
|
|
17
|
+
}
|
|
18
|
+
handleRadioChange(detail) {
|
|
19
|
+
if (this.disabled)
|
|
20
|
+
return;
|
|
21
|
+
console.log('detail', detail);
|
|
22
|
+
this.value = this.val;
|
|
23
|
+
this.update.emit(this.value);
|
|
24
|
+
}
|
|
25
|
+
render() {
|
|
26
|
+
return (h(Host, { key: 'f288b8077193d0c1614b3c25fb9f3ebbedf0f9be', "aria-label": this.val || 'radio option', "aria-checked": String(this.val) === String(this.value) ? 'true' : 'false', "aria-disabled": this.disabled ? 'true' : 'false', class: this.getRadioClasses() }, h("label", { key: `radio-${this.val}` }, h("input", { key: '0f5e1cad59ec2a2c20247bec1341e58b11477699', type: "radio", name: this.val, value: String(this.val), checked: String(this.val) === String(this.value), disabled: this.disabled, onInput: ({ detail }) => this.handleRadioChange(detail) }), this.val && h("span", { key: '47fd723d1ec6c6124d01341f7edbe945061dc348', class: "sd-radio-group__label" }, this.label || this.val))));
|
|
27
|
+
}
|
|
28
|
+
static get is() { return "sd-radio"; }
|
|
29
|
+
static get originalStyleUrls() {
|
|
30
|
+
return {
|
|
31
|
+
"$": ["sd-radio.scss"]
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
static get styleUrls() {
|
|
35
|
+
return {
|
|
36
|
+
"$": ["sd-radio.css"]
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
static get properties() {
|
|
40
|
+
return {
|
|
41
|
+
"value": {
|
|
42
|
+
"type": "any",
|
|
43
|
+
"mutable": true,
|
|
44
|
+
"complexType": {
|
|
45
|
+
"original": "RadioValue",
|
|
46
|
+
"resolved": "boolean | number | string",
|
|
47
|
+
"references": {
|
|
48
|
+
"RadioValue": {
|
|
49
|
+
"location": "local",
|
|
50
|
+
"path": "/Users/meijing/Documents/sellmate/frontend/design-system/packages/stencil/src/components/sd-radio/sd-radio.tsx",
|
|
51
|
+
"id": "src/components/sd-radio/sd-radio.tsx::RadioValue"
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
},
|
|
55
|
+
"required": true,
|
|
56
|
+
"optional": false,
|
|
57
|
+
"docs": {
|
|
58
|
+
"tags": [],
|
|
59
|
+
"text": ""
|
|
60
|
+
},
|
|
61
|
+
"getter": false,
|
|
62
|
+
"setter": false,
|
|
63
|
+
"reflect": true,
|
|
64
|
+
"attribute": "value"
|
|
65
|
+
},
|
|
66
|
+
"disabled": {
|
|
67
|
+
"type": "boolean",
|
|
68
|
+
"mutable": false,
|
|
69
|
+
"complexType": {
|
|
70
|
+
"original": "boolean",
|
|
71
|
+
"resolved": "boolean",
|
|
72
|
+
"references": {}
|
|
73
|
+
},
|
|
74
|
+
"required": false,
|
|
75
|
+
"optional": false,
|
|
76
|
+
"docs": {
|
|
77
|
+
"tags": [],
|
|
78
|
+
"text": ""
|
|
79
|
+
},
|
|
80
|
+
"getter": false,
|
|
81
|
+
"setter": false,
|
|
82
|
+
"reflect": false,
|
|
83
|
+
"attribute": "disabled",
|
|
84
|
+
"defaultValue": "false"
|
|
85
|
+
},
|
|
86
|
+
"val": {
|
|
87
|
+
"type": "string",
|
|
88
|
+
"mutable": false,
|
|
89
|
+
"complexType": {
|
|
90
|
+
"original": "string",
|
|
91
|
+
"resolved": "string",
|
|
92
|
+
"references": {}
|
|
93
|
+
},
|
|
94
|
+
"required": true,
|
|
95
|
+
"optional": false,
|
|
96
|
+
"docs": {
|
|
97
|
+
"tags": [],
|
|
98
|
+
"text": ""
|
|
99
|
+
},
|
|
100
|
+
"getter": false,
|
|
101
|
+
"setter": false,
|
|
102
|
+
"reflect": false,
|
|
103
|
+
"attribute": "val"
|
|
104
|
+
},
|
|
105
|
+
"label": {
|
|
106
|
+
"type": "string",
|
|
107
|
+
"mutable": false,
|
|
108
|
+
"complexType": {
|
|
109
|
+
"original": "string",
|
|
110
|
+
"resolved": "string | undefined",
|
|
111
|
+
"references": {}
|
|
112
|
+
},
|
|
113
|
+
"required": false,
|
|
114
|
+
"optional": true,
|
|
115
|
+
"docs": {
|
|
116
|
+
"tags": [],
|
|
117
|
+
"text": ""
|
|
118
|
+
},
|
|
119
|
+
"getter": false,
|
|
120
|
+
"setter": false,
|
|
121
|
+
"reflect": false,
|
|
122
|
+
"attribute": "label"
|
|
123
|
+
}
|
|
124
|
+
};
|
|
125
|
+
}
|
|
126
|
+
static get events() {
|
|
127
|
+
return [{
|
|
128
|
+
"method": "update",
|
|
129
|
+
"name": "sdUpdate",
|
|
130
|
+
"bubbles": true,
|
|
131
|
+
"cancelable": true,
|
|
132
|
+
"composed": true,
|
|
133
|
+
"docs": {
|
|
134
|
+
"tags": [],
|
|
135
|
+
"text": ""
|
|
136
|
+
},
|
|
137
|
+
"complexType": {
|
|
138
|
+
"original": "RadioValue",
|
|
139
|
+
"resolved": "boolean | number | string",
|
|
140
|
+
"references": {
|
|
141
|
+
"RadioValue": {
|
|
142
|
+
"location": "local",
|
|
143
|
+
"path": "/Users/meijing/Documents/sellmate/frontend/design-system/packages/stencil/src/components/sd-radio/sd-radio.tsx",
|
|
144
|
+
"id": "src/components/sd-radio/sd-radio.tsx::RadioValue"
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
}];
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
//# sourceMappingURL=sd-radio.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sd-radio.js","sourceRoot":"","sources":["../../../src/components/sd-radio/sd-radio.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAgB,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAQ9E,MAAM,OAAO,OAAO;IACqB,KAAK,CAAc;IAEnD,QAAQ,GAAY,KAAK,CAAC;IAE1B,GAAG,CAAU;IAEb,KAAK,CAAU;IAEW,MAAM,CAA4B;IAE5D,eAAe;QACtB,MAAM,OAAO,GAAG;YACf,UAAU;YACV,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,sBAAsB;SACvF,CAAC;QAEF,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;QACpC,CAAC;QAED,OAAO,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC1B,CAAC;IAEO,iBAAiB,CAAC,MAAW;QACpC,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAE1B,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QAE9B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,GAAI,CAAC;QACvB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAED,MAAM;QACL,OAAO,CACN,EAAC,IAAI,mEACQ,IAAI,CAAC,GAAG,IAAI,cAAc,kBACxB,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,mBACzD,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,EAC/C,KAAK,EAAE,IAAI,CAAC,eAAe,EAAE;YAE7B,aAAO,GAAG,EAAE,SAAS,IAAI,CAAC,GAAG,EAAE;gBAC9B,8DACC,IAAI,EAAC,OAAO,EACZ,IAAI,EAAE,IAAI,CAAC,GAAG,EACd,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,EACvB,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAChD,QAAQ,EAAE,IAAI,CAAC,QAAQ,EACvB,OAAO,EAAE,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,GACtD;gBACD,IAAI,CAAC,GAAG,IAAI,6DAAM,KAAK,EAAC,uBAAuB,IAAE,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,GAAG,CAAQ,CACzE,CACF,CACP,CAAC;IACH,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACD","sourcesContent":["import { Component, Event, EventEmitter, h, Host, Prop } from '@stencil/core';\n\nexport type RadioValue = string | number | boolean;\n\n@Component({\n tag: 'sd-radio',\n styleUrl: 'sd-radio.scss',\n})\nexport class SdRadio {\n @Prop({ mutable: true, reflect: true }) value!: RadioValue;\n\n @Prop() disabled: boolean = false;\n\n @Prop() val!: string;\n\n @Prop() label?: string;\n\n @Event({ eventName: 'sdUpdate' }) update!: EventEmitter<RadioValue>;\n\n private getRadioClasses(): string {\n const classes = [\n 'sd-radio',\n String(this.val) === String(this.value) ? 'sd-radio--selected' : 'sd-radio--unselected',\n ];\n\n if (this.disabled) {\n classes.push('sd-radio--disabled');\n }\n\n return classes.join(' ');\n }\n\n private handleRadioChange(detail: any) {\n if (this.disabled) return;\n\n console.log('detail', detail);\n\n this.value = this.val!;\n this.update.emit(this.value);\n }\n\n render() {\n return (\n <Host\n aria-label={this.val || 'radio option'}\n aria-checked={String(this.val) === String(this.value) ? 'true' : 'false'}\n aria-disabled={this.disabled ? 'true' : 'false'}\n class={this.getRadioClasses()}\n >\n <label key={`radio-${this.val}`}>\n <input\n type=\"radio\"\n name={this.val}\n value={String(this.val)}\n checked={String(this.val) === String(this.value)}\n disabled={this.disabled}\n onInput={({ detail }) => this.handleRadioChange(detail)}\n />\n {this.val && <span class=\"sd-radio-group__label\">{this.label || this.val}</span>}\n </label>\n </Host>\n );\n }\n}\n"]}
|
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
sd-radio-button-group {
|
|
2
|
-
display: inline-
|
|
2
|
+
display: inline-flex;
|
|
3
3
|
}
|
|
4
|
-
sd-radio-button-group
|
|
5
|
-
|
|
6
|
-
flex-direction: row;
|
|
4
|
+
sd-radio-button-group.sd-radio-button-group {
|
|
5
|
+
flex-flow: row nowrap;
|
|
7
6
|
gap: 0;
|
|
8
7
|
}
|
|
9
|
-
sd-radio-button-group .sd-radio-button-group__option {
|
|
8
|
+
sd-radio-button-group.sd-radio-button-group .sd-radio-button-group__option {
|
|
10
9
|
display: flex;
|
|
11
10
|
align-items: center;
|
|
12
11
|
justify-content: center;
|
|
@@ -17,64 +16,66 @@ sd-radio-button-group .sd-radio-button-group__option {
|
|
|
17
16
|
font-weight: 400;
|
|
18
17
|
transition: all 0.2s ease;
|
|
19
18
|
position: relative;
|
|
19
|
+
-webkit-user-select: none;
|
|
20
20
|
user-select: none;
|
|
21
21
|
}
|
|
22
|
-
sd-radio-button-group .sd-radio-button-group__option input {
|
|
22
|
+
sd-radio-button-group.sd-radio-button-group .sd-radio-button-group__option input {
|
|
23
23
|
display: none;
|
|
24
24
|
}
|
|
25
|
-
sd-radio-button-group .sd-radio-button-group__option:not(:first-child) {
|
|
25
|
+
sd-radio-button-group.sd-radio-button-group .sd-radio-button-group__option:not(:first-child) {
|
|
26
26
|
margin-left: -1px;
|
|
27
27
|
}
|
|
28
|
-
sd-radio-button-group .sd-radio-button-group__option:first-child {
|
|
28
|
+
sd-radio-button-group.sd-radio-button-group .sd-radio-button-group__option:first-child {
|
|
29
29
|
border-radius: 4px 0 0 4px;
|
|
30
30
|
}
|
|
31
|
-
sd-radio-button-group .sd-radio-button-group__option:last-child {
|
|
31
|
+
sd-radio-button-group.sd-radio-button-group .sd-radio-button-group__option:last-child {
|
|
32
32
|
border-radius: 0 4px 4px 0;
|
|
33
33
|
}
|
|
34
|
-
sd-radio-button-group .sd-radio-button-group__option:only-child {
|
|
34
|
+
sd-radio-button-group.sd-radio-button-group .sd-radio-button-group__option:only-child {
|
|
35
35
|
border-radius: 4px;
|
|
36
36
|
}
|
|
37
|
-
sd-radio-button-group .sd-radio-button-group__option::after {
|
|
37
|
+
sd-radio-button-group.sd-radio-button-group .sd-radio-button-group__option::after {
|
|
38
38
|
content: attr(data-label);
|
|
39
39
|
position: absolute;
|
|
40
40
|
font-weight: 400;
|
|
41
41
|
transition: font-weight 0.2s ease;
|
|
42
42
|
}
|
|
43
|
-
sd-radio-button-group .sd-radio-button-group__option:not(sd-radio-button-group .sd-radio-button-group__option--disabled):not(sd-radio-button-group .sd-radio-button-group__option--selected):hover {
|
|
43
|
+
sd-radio-button-group.sd-radio-button-group .sd-radio-button-group__option:not(sd-radio-button-group.sd-radio-button-group .sd-radio-button-group__option--disabled):not(sd-radio-button-group.sd-radio-button-group .sd-radio-button-group__option--selected):hover {
|
|
44
44
|
background-color: #0075ff;
|
|
45
45
|
color: white;
|
|
46
46
|
border-color: #0075ff;
|
|
47
47
|
z-index: 2;
|
|
48
48
|
}
|
|
49
|
-
sd-radio-button-group .sd-radio-button-group__option:not(sd-radio-button-group .sd-radio-button-group__option--disabled):not(sd-radio-button-group .sd-radio-button-group__option--selected):hover::after {
|
|
49
|
+
sd-radio-button-group.sd-radio-button-group .sd-radio-button-group__option:not(sd-radio-button-group.sd-radio-button-group .sd-radio-button-group__option--disabled):not(sd-radio-button-group.sd-radio-button-group .sd-radio-button-group__option--selected):hover::after {
|
|
50
50
|
font-weight: 500;
|
|
51
51
|
}
|
|
52
|
-
sd-radio-button-group .sd-radio-button-group__option--selected {
|
|
52
|
+
sd-radio-button-group.sd-radio-button-group .sd-radio-button-group__option--selected {
|
|
53
53
|
border-color: #0075ff;
|
|
54
54
|
color: #0075ff;
|
|
55
55
|
background-color: white;
|
|
56
56
|
z-index: 1;
|
|
57
57
|
}
|
|
58
|
-
sd-radio-button-group .sd-radio-button-group__option--disabled {
|
|
58
|
+
sd-radio-button-group.sd-radio-button-group .sd-radio-button-group__option--disabled {
|
|
59
59
|
background-color: #e1e1e1;
|
|
60
60
|
border-color: #cccccc;
|
|
61
61
|
color: #888888;
|
|
62
62
|
cursor: not-allowed;
|
|
63
63
|
}
|
|
64
|
-
sd-radio-button-group .sd-radio-button-group__option:has(input:disabled) {
|
|
64
|
+
sd-radio-button-group.sd-radio-button-group .sd-radio-button-group__option:has(input:disabled) {
|
|
65
65
|
cursor: not-allowed;
|
|
66
66
|
}
|
|
67
|
-
sd-radio-button-group
|
|
67
|
+
sd-radio-button-group.sd-radio-button-group__label {
|
|
68
|
+
-webkit-user-select: none;
|
|
68
69
|
user-select: none;
|
|
69
70
|
font-weight: 500;
|
|
70
71
|
visibility: hidden;
|
|
71
72
|
}
|
|
72
|
-
sd-radio-button-group
|
|
73
|
+
sd-radio-button-group.sd-radio-button-group--sm .sd-radio-button-group__option {
|
|
73
74
|
padding: 4px 12px;
|
|
74
75
|
font-size: 12px;
|
|
75
76
|
line-height: 20px;
|
|
76
77
|
}
|
|
77
|
-
sd-radio-button-group
|
|
78
|
+
sd-radio-button-group.sd-radio-button-group--md .sd-radio-button-group__option {
|
|
78
79
|
padding: 4px 20px;
|
|
79
80
|
font-size: 16px;
|
|
80
81
|
line-height: 26px;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { h } from "@stencil/core";
|
|
1
|
+
import { h, Host } from "@stencil/core";
|
|
2
2
|
export class SdRadioButtonGroup {
|
|
3
3
|
value;
|
|
4
4
|
radioOptions = [];
|
|
@@ -36,10 +36,10 @@ export class SdRadioButtonGroup {
|
|
|
36
36
|
}
|
|
37
37
|
groupName = this.name || `sd-radio-button-group-${crypto.randomUUID()}`;
|
|
38
38
|
render() {
|
|
39
|
-
return (h(
|
|
39
|
+
return (h(Host, { key: '32517b5b2ead37b85464a19dbb944eb2a3b65a90', class: this.getGroupClasses(), role: "radiogroup", "aria-disabled": this.disabled.toString() }, this.radioOptions.map(option => {
|
|
40
40
|
const isSelected = this.isOptionSelected(option);
|
|
41
41
|
const isDisabled = this.isOptionDisabled(option);
|
|
42
|
-
return (h("label", { key: `radio-${option.value}`, class: this.getButtonClasses(option),
|
|
42
|
+
return (h("label", { key: `radio-${option.value}`, class: this.getButtonClasses(option), "aria-label": option.label || 'radio option', "data-label": option.label }, h("input", { type: "radio", name: this.groupName, value: option.value.toString(), checked: isSelected, disabled: isDisabled, onInput: () => this.handleRadioChange(option.value, option.disabled) }), option.label && h("span", { class: "sd-radio-button-group__label" }, option.label)));
|
|
43
43
|
})));
|
|
44
44
|
}
|
|
45
45
|
static get is() { return "sd-radio-button-group"; }
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sd-radio-button-group.js","sourceRoot":"","sources":["../../../src/components/sd-radio-button-group/sd-radio-button-group.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,EAAgB,KAAK,EAAE,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"sd-radio-button-group.js","sourceRoot":"","sources":["../../../src/components/sd-radio-button-group/sd-radio-button-group.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Prop, h, EventEmitter, Event, Host } from '@stencil/core';\n\nexport type RadioValue = string | number | boolean;\nexport type RadioOption = {\n label: string;\n value: RadioValue;\n disabled?: boolean;\n};\n\n@Component({\n tag: 'sd-radio-button-group',\n styleUrl: 'sd-radio-button-group.scss',\n})\nexport class SdRadioButtonGroup {\n @Prop({ mutable: true }) value!: RadioValue;\n\n @Prop({ mutable: true }) radioOptions: RadioOption[] = [];\n\n @Prop() size: 'sm' | 'md' = 'md';\n\n @Prop() disabled: boolean = false;\n\n @Prop() name?: string;\n\n @Event({ eventName: 'sdUpdate' })\n change!: EventEmitter<RadioValue>;\n\n private handleRadioChange = (optionValue: RadioValue, optionDisabled?: boolean) => {\n if (this.disabled || optionDisabled) return;\n this.value = optionValue;\n this.change.emit(optionValue);\n };\n\n private isOptionSelected(option: RadioOption): boolean {\n return this.value === option.value;\n }\n\n private isOptionDisabled(option: RadioOption): boolean {\n return this.disabled || !!option.disabled;\n }\n\n private getButtonClasses(option: RadioOption): string {\n const classes = [\n 'sd-radio-button-group__option',\n this.isOptionSelected(option)\n ? 'sd-radio-button-group__option--selected'\n : 'sd-radio-button-group__option--unselected',\n ];\n\n if (this.isOptionDisabled(option)) {\n classes.push('sd-radio-button-group__option--disabled');\n }\n\n return classes.join(' ');\n }\n\n private getGroupClasses(): string {\n const classes = ['sd-radio-button-group', `sd-radio-button-group--${this.size}`];\n return classes.join(' ');\n }\n\n private groupName = this.name || `sd-radio-button-group-${crypto.randomUUID()}`;\n\n render() {\n return (\n <Host class={this.getGroupClasses()} role=\"radiogroup\" aria-disabled={this.disabled.toString()}>\n {this.radioOptions.map(option => {\n const isSelected = this.isOptionSelected(option);\n const isDisabled = this.isOptionDisabled(option);\n\n return (\n <label\n key={`radio-${option.value}`}\n class={this.getButtonClasses(option)}\n aria-label={option.label || 'radio option'}\n data-label={option.label}\n >\n <input\n type=\"radio\"\n name={this.groupName}\n value={option.value.toString()}\n checked={isSelected}\n disabled={isDisabled}\n onInput={() => this.handleRadioChange(option.value, option.disabled)}\n />\n {option.label && <span class=\"sd-radio-button-group__label\">{option.label}</span>}\n </label>\n );\n })}\n </Host>\n );\n }\n}\n"]}
|
|
@@ -1,32 +1,16 @@
|
|
|
1
|
-
sd-radio
|
|
2
|
-
display: inline-
|
|
3
|
-
}
|
|
4
|
-
sd-radio-group .sd-radio-group {
|
|
5
|
-
display: flex;
|
|
6
|
-
}
|
|
7
|
-
sd-radio-group .sd-radio-group--vertical {
|
|
8
|
-
flex-direction: column;
|
|
9
|
-
gap: 8px;
|
|
1
|
+
sd-radio {
|
|
2
|
+
display: inline-flex;
|
|
10
3
|
}
|
|
11
|
-
sd-radio
|
|
12
|
-
|
|
13
|
-
align-items: center;
|
|
14
|
-
gap: 20px;
|
|
4
|
+
sd-radio.sd-radio {
|
|
5
|
+
cursor: pointer;
|
|
15
6
|
}
|
|
16
|
-
sd-radio
|
|
17
|
-
width: fit-content;
|
|
7
|
+
sd-radio.sd-radio label {
|
|
18
8
|
display: flex;
|
|
19
9
|
align-items: center;
|
|
20
10
|
gap: 8px;
|
|
21
|
-
font-weight: 400;
|
|
22
|
-
font-size: 12px;
|
|
23
|
-
line-height: 20px;
|
|
24
11
|
cursor: pointer;
|
|
25
12
|
}
|
|
26
|
-
sd-radio
|
|
27
|
-
cursor: not-allowed;
|
|
28
|
-
}
|
|
29
|
-
sd-radio-group .sd-radio-group__option input {
|
|
13
|
+
sd-radio.sd-radio label input {
|
|
30
14
|
position: relative;
|
|
31
15
|
appearance: none;
|
|
32
16
|
margin: 0;
|
|
@@ -34,15 +18,15 @@ sd-radio-group .sd-radio-group__option input {
|
|
|
34
18
|
height: 16px;
|
|
35
19
|
border: 1px solid #888888;
|
|
36
20
|
border-radius: 50%;
|
|
37
|
-
cursor: pointer;
|
|
38
21
|
accent-color: #0075ff;
|
|
39
22
|
background-color: white;
|
|
23
|
+
cursor: pointer;
|
|
40
24
|
}
|
|
41
|
-
sd-radio
|
|
25
|
+
sd-radio.sd-radio label input:checked {
|
|
42
26
|
border-color: #0075ff;
|
|
43
27
|
background-color: white;
|
|
44
28
|
}
|
|
45
|
-
sd-radio
|
|
29
|
+
sd-radio.sd-radio label input:checked::before {
|
|
46
30
|
content: "";
|
|
47
31
|
position: absolute;
|
|
48
32
|
top: 50%;
|
|
@@ -53,27 +37,39 @@ sd-radio-group .sd-radio-group__option input:checked::before {
|
|
|
53
37
|
border-radius: 50%;
|
|
54
38
|
background-color: #0075ff;
|
|
55
39
|
}
|
|
56
|
-
sd-radio
|
|
57
|
-
cursor: not-allowed;
|
|
40
|
+
sd-radio.sd-radio label input:disabled {
|
|
58
41
|
border-color: #cccccc;
|
|
59
42
|
background-color: #eeeeee;
|
|
60
43
|
}
|
|
61
|
-
sd-radio
|
|
44
|
+
sd-radio.sd-radio label input:disabled:checked::before {
|
|
62
45
|
background-color: #cccccc;
|
|
63
46
|
}
|
|
64
|
-
sd-radio
|
|
47
|
+
sd-radio.sd-radio label input:not(:disabled):hover {
|
|
65
48
|
border-color: #0075ff;
|
|
66
49
|
background-color: #d9eaff;
|
|
67
50
|
}
|
|
68
|
-
sd-radio
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
51
|
+
sd-radio.sd-radio--disabled {
|
|
52
|
+
cursor: not-allowed !important;
|
|
53
|
+
}
|
|
54
|
+
sd-radio.sd-radio--disabled label {
|
|
55
|
+
cursor: not-allowed !important;
|
|
56
|
+
}
|
|
57
|
+
sd-radio.sd-radio--disabled label input {
|
|
58
|
+
cursor: not-allowed !important;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
sd-radio-group {
|
|
62
|
+
display: inline-block;
|
|
63
|
+
}
|
|
64
|
+
sd-radio-group .sd-radio-group {
|
|
65
|
+
display: flex;
|
|
73
66
|
}
|
|
74
|
-
sd-radio-group .sd-radio-
|
|
75
|
-
|
|
67
|
+
sd-radio-group .sd-radio-group--vertical {
|
|
68
|
+
flex-direction: column;
|
|
69
|
+
gap: 8px;
|
|
76
70
|
}
|
|
77
|
-
sd-radio-group .sd-radio-
|
|
78
|
-
|
|
71
|
+
sd-radio-group .sd-radio-group--horizontal {
|
|
72
|
+
flex-direction: row;
|
|
73
|
+
align-items: center;
|
|
74
|
+
gap: 20px;
|
|
79
75
|
}
|