UNPKG

tdesign-react

Version:
236 lines (235 loc) 7.55 kB
.t-switch { font: var(--td-font-body-medium); color: var(--td-text-color-primary); -webkit-box-sizing: border-box; box-sizing: border-box; list-style: none; position: relative; display: -webkit-inline-box; display: -ms-inline-flexbox; display: inline-flex; vertical-align: middle; -webkit-box-align: center; -ms-flex-align: center; align-items: center; outline: none; border: 0; padding: 0; margin: 0; height: var(--td-comp-size-xxs); line-height: var(--td-comp-size-xxs); border-radius: var(--td-radius-round); min-width: calc(var(--td-comp-size-xxs) / 0.618); -webkit-transition: all 0.2s cubic-bezier(0.38, 0, 0.24, 1); transition: all 0.2s cubic-bezier(0.38, 0, 0.24, 1); background-color: var(--td-bg-color-secondarycomponent); cursor: pointer; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; } .t-switch:hover { background-color: var(--td-bg-color-secondarycomponent-hover); } .t-switch__handle { position: absolute; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; top: 4px; left: 4px; width: calc(var(--td-comp-size-xxs) - 2 * 4px); height: calc(var(--td-comp-size-xxs) - 2 * 4px); border-radius: var(--td-radius-round); -webkit-transition: all 0.2s cubic-bezier(0.38, 0, 0.24, 1); transition: all 0.2s cubic-bezier(0.38, 0, 0.24, 1); -webkit-box-shadow: var(--td-shadow-1); box-shadow: var(--td-shadow-1); } .t-switch__handle .t-icon { font-size: calc(var(--td-comp-size-xxs) - 4px); color: transparent; } .t-switch__handle::before { content: ""; position: absolute; top: 0; left: 0; right: 0; bottom: 0; border-radius: var(--td-radius-round); background-color: #fff; -webkit-transition: all 0.2s cubic-bezier(0.38, 0, 0.24, 1); transition: all 0.2s cubic-bezier(0.38, 0, 0.24, 1); } .t-switch:active:not(.t-is-disabled):not(.t-is-loading) .t-switch__handle::before { left: 0; right: -6px; } .t-switch:active:not(.t-is-disabled):not(.t-is-loading).t-is-checked .t-switch__handle::before { right: 0; left: -6px; } .t-switch:active:not(.t-is-disabled):not(.t-is-loading) .t-switch__content { opacity: 0; } .t-switch__content { -webkit-box-sizing: border-box; box-sizing: border-box; display: -webkit-inline-box; display: -ms-inline-flexbox; display: inline-flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; color: var(--td-text-color-anti); padding: 0 var(--td-comp-margin-xs) 0 calc(calc(var(--td-comp-size-xxs) / 0.618) / 2 + 2px); font-size: var(--td-font-size-body-small); min-width: calc(var(--td-comp-size-xxs) / 0.618); -webkit-transition: padding 0.2s cubic-bezier(0.38, 0, 0.24, 1), opacity 0.2s linear; transition: padding 0.2s cubic-bezier(0.38, 0, 0.24, 1), opacity 0.2s linear; } .t-switch__content .t-icon { font-size: var(--td-font-size-body-large); } .t-switch.t-is-checked { background-color: var(--td-brand-color); } .t-switch.t-is-checked:hover { background-color: var(--td-brand-color-hover); } .t-switch.t-is-checked .t-switch__handle { left: calc(100% - 2.5px); -webkit-transform: translate(-100%, 0); transform: translate(-100%, 0); width: calc(var(--td-comp-size-xxs) - 2 * 2.5px); height: calc(var(--td-comp-size-xxs) - 2 * 2.5px); top: 2.5px; } .t-switch.t-is-checked .t-switch__content { padding: 0 calc(calc(var(--td-comp-size-xxs) / 0.618) / 2 + 2px) 0 var(--td-comp-margin-xs); color: var(--td-text-color-anti); } .t-switch.t-is-loading { cursor: not-allowed; background-color: var(--td-bg-color-component-disabled); } .t-switch.t-is-loading .t-loading { display: -webkit-inline-box; display: -ms-inline-flexbox; display: inline-flex; } .t-switch.t-is-loading .t-switch__handle .t-icon { color: var(--td-bg-color-component-disabled); } .t-switch.t-is-loading.t-is-checked { background-color: var(--td-brand-color-focus); } .t-switch.t-is-loading.t-is-checked .t-switch__handle .t-icon { color: var(--td-brand-color-focus); } .t-switch.t-is-disabled { cursor: not-allowed; background-color: var(--td-bg-color-component-disabled); } .t-switch.t-is-disabled .t-switch__handle { -webkit-box-shadow: none; box-shadow: none; } .t-switch.t-is-disabled.t-is-checked { background-color: var(--td-brand-color-disabled); } .t-switch.t-is-disabled.t-is-checked .t-switch__handle { -webkit-box-shadow: none; box-shadow: none; } .t-switch.t-is-disabled.t-is-checked .t-switch__handle .t-icon { color: var(--td-brand-color-disabled); } .t-switch.t-size-l { min-width: calc(var(--td-comp-size-xs) / 0.618); height: var(--td-comp-size-xs); line-height: var(--td-comp-size-xs); border-radius: var(--td-radius-round); } .t-switch.t-size-l:active:not(.t-is-disabled):not(.t-is-loading) .t-switch__handle::before { left: 0; right: -8px; } .t-switch.t-size-l:active:not(.t-is-disabled):not(.t-is-loading).t-is-checked .t-switch__handle::before { right: 0; left: -8px; } .t-switch.t-size-l .t-switch__handle { top: 5px; left: 5px; width: calc(var(--td-comp-size-xs) - 2 * 5px); height: calc(var(--td-comp-size-xs) - 2 * 5px); } .t-switch.t-size-l .t-switch__handle .t-icon { font-size: calc(var(--td-comp-size-xs) - 4px); } .t-switch.t-size-l .t-switch__content { padding: 0 var(--td-comp-margin-s) 0 calc(calc(var(--td-comp-size-xs) / 0.618) / 2 + 4px); min-width: calc(var(--td-comp-size-xs) / 0.618); font-size: var(--td-font-size-body-large); } .t-switch.t-size-l .t-switch__content .t-icon { font-size: var(--td-font-size-body-large); } .t-switch.t-size-l.t-is-checked .t-switch__handle { left: calc(100% - 3px); top: 3px; width: calc(var(--td-comp-size-xs) - 2 * 3px); height: calc(var(--td-comp-size-xs) - 2 * 3px); } .t-switch.t-size-l.t-is-checked .t-switch__content { padding: 0 calc(calc(var(--td-comp-size-xs) / 0.618) / 2 + 4px) 0 var(--td-comp-margin-s); } .t-switch.t-size-s { min-width: calc(var(--td-comp-size-xxxs) / 0.618); height: var(--td-comp-size-xxxs); line-height: var(--td-comp-size-xxxs); border-radius: var(--td-radius-round); } .t-switch.t-size-s:active:not(.t-is-disabled):not(.t-is-loading) .t-switch__handle::before { left: 0; right: -4px; } .t-switch.t-size-s:active:not(.t-is-disabled):not(.t-is-loading).t-is-checked .t-switch__handle::before { right: 0; left: -4px; } .t-switch.t-size-s .t-switch__handle { top: 3px; left: 3px; width: calc(var(--td-comp-size-xxxs) - 2 * 3px); height: calc(var(--td-comp-size-xxxs) - 2 * 3px); } .t-switch.t-size-s .t-switch__handle .t-icon { font-size: calc(var(--td-comp-size-xxxs) - 4px); } .t-switch.t-size-s .t-switch__content { padding: 0 var(--td-comp-margin-xxs) 0 calc(calc(var(--td-comp-size-xxxs) / 0.618) / 2 + 2px); min-width: calc(var(--td-comp-size-xxxs) / 0.618); font-size: 9px; } .t-switch.t-size-s .t-switch__content .t-icon { font-size: var(--td-font-size-body-large); } .t-switch.t-size-s.t-is-checked .t-switch__handle { left: calc(100% - 2px); top: 2px; width: calc(var(--td-comp-size-xxxs) - 2 * 2px); height: calc(var(--td-comp-size-xxxs) - 2 * 2px); } .t-switch.t-size-s.t-is-checked .t-switch__content { padding: 0 calc(calc(var(--td-comp-size-xxxs) / 0.618) / 2 + 2px) 0 var(--td-comp-margin-xxs); }