UNPKG

@synergy-design-system/components

Version:

This package provides the base of the Synergy Design System as native web components. It uses [lit](https://www.lit.dev) and parts of [shoelace](https://shoelace.style/). Synergy officially supports the latest two versions of all major browsers (as define

147 lines (119 loc) 5.45 kB
// src/components/switch/switch.custom.styles.ts import { css } from "lit"; var switch_custom_styles_default = css` :host([size='small']) { --height: var(--syn-switch-height-small, calc(var(--syn-toggle-size-medium) + 2px)); --thumb-size: var(--syn-toggle-size-small); --width: var(--syn-switch-width-small, calc((var(--height) * 2) - 6px)); font-size: var(--syn-input-font-size-small); } :host([size='medium']) { --height: var(--syn-switch-height-medium, calc(var(--syn-toggle-size-medium) + 4px)); --thumb-size: var(--syn-toggle-size-medium); --width: var(--syn-switch-width-medium, calc((var(--height) * 2) - 6px)); font-size: var(--syn-input-font-size-medium); } :host([size='large']) { --height: var(--syn-switch-height-large, calc(var(--syn-toggle-size-large) + 4px)); --thumb-size: var(--syn-toggle-size-large); --width: var(--syn-switch-width-large, calc((var(--height) * 2) - 6px)); font-size: var(--syn-input-font-size-large); } /** #429: Use token for opacity */ .switch--disabled { opacity: var(--syn-input-disabled-opacity); } .switch.switch--small { padding: var(--syn-spacing-2x-small) 0; } .switch.switch--medium { padding: var(--syn-spacing-2x-small) 0; } .switch.switch--large { padding: var(--syn-spacing-3x-small) 0; } /* Hint: can be removed, if the padding stylings for sizes from above are removed */ .form-control--has-help-text .switch { padding-bottom: 0; } .switch__control { background-color: var(--syn-input-icon-icon-clearable-color); border: solid var(--syn-border-width-medium) var(--syn-input-icon-icon-clearable-color); } .switch__control .switch__thumb { border: none; } /* Checked */ .switch--checked .switch__control { background-color: var(--syn-interactive-emphasis-color, var(--syn-color-primary-600)); border-color: var(--syn-interactive-emphasis-color, var(--syn-color-primary-600)); } /* Hover */ .switch:not(.switch--checked):not(.switch--disabled):hover .switch__control { background-color: var(--syn-input-icon-icon-clearable-color-hover); border-color: var(--syn-input-icon-icon-clearable-color-hover); } .switch:not(.switch--checked):not(.switch--disabled):hover .switch__control:hover .switch__thumb { background-color: var(--syn-color-neutral-0); } /* Checked + hover */ .switch.switch--checked:not(.switch--disabled):hover .switch__control { background-color: var(--syn-interactive-emphasis-color-hover, var(--syn-color-primary-900)); border-color: var(--syn-interactive-emphasis-color-hover, var(--syn-color-primary-900)); } .switch.switch--checked:not(.switch--disabled):hover .switch__control:hover .switch__thumb { background-color: var(--syn-color-neutral-0); } /* * #443: Add active styles * The checked and unchecked states have different active colors * Note the fallback is defined to match the hover color. * This is done to make sure no active state is shown at all if no active color is defined. * Still better than showing one for the unchecked state but not for the checked state. */ .switch:not(.switch--checked):not(.switch--disabled):active .switch__control { background: var(--syn-input-icon-icon-clearable-color-active); border-color: var(--syn-input-icon-icon-clearable-color-active); } .switch.switch--checked:not(.switch--disabled):active .switch__control { background: var(--syn-interactive-emphasis-color-active); border-color: var(--syn-interactive-emphasis-color-active); } /* Focus */ .switch:not(.switch--checked):not(.switch--disabled) .switch__input:focus-visible ~ .switch__control { background-color: var(--syn-input-icon-icon-clearable-color); border-color: var(--syn-input-icon-icon-clearable-color); outline: var(--syn-focus-ring); outline-offset: var(--syn-focus-ring-offset); } .switch:not(.switch--checked):not(.switch--disabled) .switch__input:focus-visible ~ .switch__control .switch__thumb { background-color: var(--syn-color-neutral-0); outline: none; } /* Checked + focus */ .switch.switch--checked:not(.switch--disabled) .switch__input:focus-visible ~ .switch__control { background-color: var(--syn-interactive-emphasis-color, var(--syn-color-primary-600)); border-color: var(--syn-interactive-emphasis-color, var(--syn-color-primary-600)); outline: var(--syn-focus-ring); outline-offset: var(--syn-focus-ring-offset); } .switch.switch--checked:not(.switch--disabled) .switch__input:focus-visible ~ .switch__control .switch__thumb { background-color: var(--syn-color-neutral-0); outline: none; } .switch__label { margin-inline-start: var(--syn-spacing-x-small); } :host([data-user-invalid]) .switch:not(.switch--checked):not(.switch--disabled) .switch__control { background-color: var(--syn-input-border-color-focus-error, var(--syn-color-error-700)); border-color: var(--syn-input-border-color-focus-error, var(--syn-color-error-700)); } :host([data-user-invalid]) .switch:not(.switch--checked):not(.switch--disabled):hover .switch__control { background-color: var(--syn-input-border-color-hover, var(--syn-color-error-900)); border-color: var(--syn-input-border-color-hover, var(--syn-color-error-900)); } `; export { switch_custom_styles_default }; //# sourceMappingURL=chunk.T7PPSROA.js.map