choerodon-ui
Version:
An enterprise-class UI design language and React-based implementation
167 lines (141 loc) • 3.53 kB
text/less
@import '../../style/themes/default';
@import '../../style/mixins/index';
@switch-prefix-cls: ~'@{c7n-prefix}-switch';
@switch-duration: 0.36s;
.@{switch-prefix-cls} {
.reset-component;
position: relative;
display: inline-block;
box-sizing: border-box;
min-width: 0.36rem;
height: calc(@switch-height - 0.04rem);
line-height: calc(@switch-height - 0.06rem);
vertical-align: middle;
background-color: rgba(0, 0, 0, 0.38);
border: @border-width-base @border-style-base transparent;
border-radius: 1rem;
cursor: pointer;
transition: all @switch-duration;
user-select: none;
&-inner {
display: block;
margin-right: 0.06rem;
margin-left: 0.24rem;
color: #fff;
font-size: @font-size-sm;
}
&::before,
&::after {
position: absolute;
top: -0.03rem;
left: -0.01rem;
width: @switch-height;
height: @switch-height;
background-color: @component-background;
border-radius: 0.18rem;
cursor: pointer;
transition: all @switch-duration @ease-in-out-circ;
content: ' ';
}
&::after {
box-shadow: 0 0.02rem 0.01rem -0.01rem rgba(0, 0, 0, 0.2),
0 0.01rem 0.01rem 0 rgba(0, 0, 0, 0.14), 0 0.01rem 0.03rem 0 rgba(0, 0, 0, 0.12);
}
&:active::before,
&:active::after {
width: 0.24rem;
}
&::before {
.iconfont-mixin(0.12rem);
z-index: 1;
display: none;
text-align: center;
background-color: transparent;
animation: loadingCircle 1s infinite linear;
content: "\e15a";
}
&-loading::before {
display: inline-block;
color: @text-color;
}
&-checked&-loading::before {
color: @switch-color;
}
&:focus {
outline: 0;
box-shadow: @switch-box-shadow;
}
&:focus:hover {
box-shadow: none;
}
&-small {
min-width: 0.28rem;
height: calc(@switch-sm-height - 0.04rem);
line-height: calc(@switch-sm-height - 0.06rem);
.@{switch-prefix-cls}-inner {
margin-right: 0.03rem;
margin-left: 0.18rem;
font-size: @font-size-sm;
}
&::before,
&::after {
width: @switch-sm-height;
height: @switch-sm-height;
}
&:active::before,
&:active::after {
width: 0.16rem;
}
}
&-small&-checked {
&::before,
&::after {
left: 100%;
margin-left: @switch-sm-checked-margin-left;
}
.@{switch-prefix-cls}-inner {
margin-right: 0.18rem;
margin-left: 0.03rem;
}
}
&-small:active&-checked::before,
&-small:active&-checked::after {
margin-left: -0.165rem;
}
&-small&-loading::before {
font-weight: bold;
animation: AntSwitchSmallLoadingCircle 1s infinite linear;
}
&-checked {
background-color: @switch-color;
.@{switch-prefix-cls}-inner {
margin-right: 0.24rem;
margin-left: 0.06rem;
}
&::before,
&::after {
left: 100%;
margin-left: @switch-checked-margin-left;
background-color: @switch-checked-color;
}
&:active::before,
&:active::after {
margin-left: -0.25rem;
}
}
&-loading,
&-disabled {
opacity: @switch-basic-disabled-opacity;
pointer-events: none;
}
}
@keyframes AntSwitchSmallLoadingCircle {
0% {
transform: rotate(0deg) scale(0.66667);
transform-origin: 50% 50%;
}
100% {
transform: rotate(360deg) scale(0.66667);
transform-origin: 50% 50%;
}
}