@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
JavaScript
// 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