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

118 lines (96 loc) 3.64 kB
// src/components/switch/switch.custom.styles.ts import { css } from "lit"; var switch_custom_styles_default = css` :host([size='small']) { --height: calc(var(--syn-font-size-medium) + 2px); --thumb-size: var(--syn-font-size-small); --width: calc((var(--height) * 2) - 6px); } :host([size='medium']) { --height: var(--syn-font-size-large); --thumb-size: var(--syn-font-size-medium); --width: calc((var(--height) * 2) - 6px); } :host([size='large']) { --height: calc(var(--syn-toggle-size-large) + 4px); --thumb-size: var(--syn-toggle-size-large); --width: calc((var(--height) * 2) - 6px); } /** #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-color-neutral-600); border: solid var(--syn-border-width-medium) var(--syn-color-neutral-600); } .switch__control .switch__thumb { border: none; } /* Hover */ .switch:not(.switch--checked):not(.switch--disabled) .switch__control:hover { background-color: var(--syn-color-neutral-900); border-color: var(--syn-color-neutral-900); } .switch:not(.switch--checked):not(.switch--disabled) .switch__control:hover .switch__thumb { background-color: var(--syn-color-neutral-0); } /* Checked + hover */ .switch.switch--checked:not(.switch--disabled) .switch__control:hover { background-color: var(--syn-color-primary-900); border-color: var(--syn-color-primary-900); } .switch.switch--checked:not(.switch--disabled) .switch__control:hover .switch__thumb { background-color: var(--syn-color-neutral-0); } /* Focus */ .switch:not(.switch--checked):not(.switch--disabled) .switch__input:focus-visible ~ .switch__control { background-color: var(--syn-color-neutral-600); border-color: var(--syn-color-neutral-600); 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-color-primary-900); border-color: var(--syn-color-primary-900); 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-color-error-700); border-color: var(--syn-color-error-700); } :host([data-user-invalid]) .switch:not(.switch--checked):not(.switch--disabled) .switch__control:hover { background-color: var(--syn-color-error-900); border-color: var(--syn-color-error-900); } `; export { switch_custom_styles_default }; //# sourceMappingURL=chunk.3QYBPNXR.js.map