zarm-web
Version:
基于 React 的桌面端UI库
359 lines (318 loc) • 10.3 kB
CSS
.zw-checkbox {
display: inline-block;
vertical-align: middle;
position: relative;
color: var(--color-text);
font-size: 14px;
}
.zw-checkbox:not(.zw-checkbox--disabled):hover .zw-checkbox__inner {
border-color: var(--theme-primary);
}
.zw-checkbox__widget {
display: inline-block;
vertical-align: middle;
}
.zw-checkbox__input {
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 100%;
opacity: 0;
cursor: pointer;
}
.zw-checkbox__text {
vertical-align: middle;
margin: 0 8px;
}
.zw-checkbox__inner {
display: flex;
align-items: center;
justify-content: center;
width: var(--checkbox-size);
height: var(--checkbox-size);
border: 1px solid var(--checkbox-border-color);
border-radius: var(--checkbox-radius);
background: var(--color-text-inverse);
}
.zw-checkbox__inner:before {
content: "";
width: calc(var(--checkbox-size) / 3.5);
height: calc(var(--checkbox-size) / 2);
border: calc(var(--checkbox-size) / 9) solid var(--color-text-inverse);
border-top: 0;
border-left: 0;
margin-top: calc(var(--checkbox-size) / -12);
margin-left: calc(var(--checkbox-size) / 18);
transform: rotate(45deg) scale(0);
transition: all 0.2s cubic-bezier(0.71, -0.46, 0.88, 0.6);
}
.zw-checkbox--indeterminate .zw-checkbox__inner:before {
transform: scale(1);
width: calc(var(--checkbox-size) / 2.33);
height: calc(var(--checkbox-size) / 2.33);
margin-top: 0;
margin-left: 0;
border: none;
background-color: var(--theme-primary);
}
.zw-checkbox--checked .zw-checkbox__inner {
border-color: var(--theme-primary);
background-color: var(--theme-primary);
}
.zw-checkbox--checked .zw-checkbox__inner:before {
transform: rotate(45deg) scale(1);
transition: all 0.2s cubic-bezier(0.12, 0.4, 0.29, 1.46) 0.1s;
}
.zw-checkbox--disabled .zw-checkbox__input {
cursor: not-allowed;
}
.zw-checkbox--disabled .zw-checkbox__text {
color: var(--color-text-disabled);
}
.zw-checkbox--disabled .zw-checkbox__inner {
opacity: var(--opacity-disabled);
}
.zw-checkbox--disabled.zw-checkbox--checked .zw-checkbox__inner {
border-color: var(--checkbox-border-color);
background-color: var(--checkbox-border-color);
}
.zw-checkbox--untext {
line-height: 1;
}
.zw-checkbox-group {
display: inline-block;
overflow: hidden;
}
.zw-checkbox-group__inner {
margin-right: -24px;
margin-bottom: -8px;
}
.zw-checkbox-group .zw-checkbox {
margin-right: 24px;
margin-bottom: 8px;
}
.zw-checkbox-group--block {
width: 100%;
}
.zw-checkbox-group--block .zw-checkbox-group__inner {
display: flex;
}
.zw-checkbox-group--block .zw-checkbox {
flex: 1;
}
.zw-checkbox-group--button .zw-checkbox-group__inner {
margin-right: -8px;
margin-bottom: -8px;
}
.zw-checkbox-group--button .zw-checkbox {
margin-right: 8px;
margin-bottom: 8px;
padding: 0;
border: none;
font-weight: normal;
text-align: center;
overflow: hidden;
color: var(--color-text);
outline: 0 none;
user-select: none;
cursor: pointer;
-webkit-appearance: none;
/* disabled Button */
/* block Button */
border-width: 1px;
border-style: solid;
border-radius: var(--radius-xs);
}
.zw-checkbox-group--button .zw-checkbox, .zw-checkbox-group--button .zw-checkbox:active, .zw-checkbox-group--button .zw-checkbox:hover, .zw-checkbox-group--button .zw-checkbox:focus, .zw-checkbox-group--button .zw-checkbox:visited {
text-decoration: none;
}
.zw-checkbox-group--button .zw-checkbox.zw-checkbox--disabled {
cursor: not-allowed;
opacity: var(--opacity-disabled);
}
.zw-checkbox-group--button .zw-checkbox.zw-checkbox--block {
display: block;
width: 100%;
}
.zw-checkbox-group--button .zw-checkbox, .zw-checkbox-group--button .zw-checkbox:hover {
background-color: var(--button-default-background);
border-color: var(--button-default-border);
color: var(--button-default-color);
}
.zw-checkbox-group--button .zw-checkbox:active {
background-color: var(--button-default-background);
border-color: var(--button-default-border);
color: var(--button-default-color);
}
.zw-checkbox-group--button .zw-checkbox.zw-checkbox--disabled {
opacity: var(--button-disabled-opacity);
cursor: not-allowed;
}
.zw-checkbox-group--button .zw-checkbox.zw-checkbox--shadow {
box-shadow: 0 3px 3px 0 var(--button-default-shadow-color);
}
.zw-checkbox-group--button .zw-checkbox .zw-checkbox__text {
margin: 0;
}
.zw-checkbox-group--button .zw-checkbox.zw-checkbox--checked, .zw-checkbox-group--button .zw-checkbox.zw-checkbox--checked:hover {
background-color: var(--button-primary-background);
border-color: var(--button-primary-border);
color: var(--button-primary-color);
}
.zw-checkbox-group--button .zw-checkbox.zw-checkbox--checked:active {
background-color: var(--button-primary-active-background);
border-color: var(--button-primary-active-border);
color: var(--button-primary-active-color);
}
.zw-checkbox-group--button .zw-checkbox.zw-checkbox--checked.zw-checkbox--disabled {
opacity: var(--button-disabled-opacity);
cursor: not-allowed;
}
.zw-checkbox-group--button .zw-checkbox.zw-checkbox--checked.zw-checkbox--shadow {
box-shadow: 0 3px 3px 0 var(--button-primary-shadow-color);
}
.zw-checkbox-group--button.zw-checkbox-group--block .zw-checkbox {
flex: 1;
}
.zw-checkbox-group--button.zw-checkbox-group--rect .zw-checkbox {
border-width: 1px;
border-style: solid;
border-radius: 0;
}
.zw-checkbox-group--button.zw-checkbox-group--radius .zw-checkbox {
border-width: 1px;
border-style: solid;
border-radius: var(--radius-md);
}
.zw-checkbox-group--button.zw-checkbox-group--round .zw-checkbox {
border-width: 1px;
border-style: solid;
border-radius: var(--radius-round);
}
.zw-checkbox-group--button.zw-checkbox-group--circle .zw-checkbox {
border-width: 1px;
border-style: solid;
border-radius: var(--radius-circle);
}
.zw-checkbox-group--button.zw-checkbox-group--lg .zw-checkbox {
padding: 0 var(--button-padding-h-lg);
font-size: var(--button-font-size-lg);
height: var(--button-height-lg);
line-height: 1.5;
}
.zw-checkbox-group--button.zw-checkbox-group--lg .zw-checkbox.zw-checkbox--circle {
width: var(--button-height-lg);
padding: 0;
}
.zw-checkbox-group--button.zw-checkbox-group--lg .zw-checkbox .zw-icon {
font-size: var(--button-icon-size-lg);
}
.zw-checkbox-group--button.zw-checkbox-group--lg .zw-checkbox * + span {
margin-left: calc(var(--button-padding-h-lg) / 2);
}
.zw-checkbox-group--button.zw-checkbox-group--md .zw-checkbox {
padding: 0 var(--button-padding-h-md);
font-size: var(--button-font-size-md);
height: var(--button-height-md);
line-height: 1.5;
}
.zw-checkbox-group--button.zw-checkbox-group--md .zw-checkbox.zw-checkbox--circle {
width: var(--button-height-md);
padding: 0;
}
.zw-checkbox-group--button.zw-checkbox-group--md .zw-checkbox .zw-icon {
font-size: var(--button-icon-size-md);
}
.zw-checkbox-group--button.zw-checkbox-group--md .zw-checkbox * + span {
margin-left: calc(var(--button-padding-h-md) / 2);
}
.zw-checkbox-group--button.zw-checkbox-group--sm .zw-checkbox {
padding: 0 var(--button-padding-h-sm);
font-size: var(--button-font-size-sm);
height: var(--button-height-sm);
line-height: 1.5;
}
.zw-checkbox-group--button.zw-checkbox-group--sm .zw-checkbox.zw-checkbox--circle {
width: var(--button-height-sm);
padding: 0;
}
.zw-checkbox-group--button.zw-checkbox-group--sm .zw-checkbox .zw-icon {
font-size: var(--button-icon-size-sm);
}
.zw-checkbox-group--button.zw-checkbox-group--sm .zw-checkbox * + span {
margin-left: calc(var(--button-padding-h-sm) / 2);
}
.zw-checkbox-group--button.zw-checkbox-group--xs .zw-checkbox {
padding: 0 var(--button-padding-h-xs);
font-size: var(--button-font-size-xs);
height: var(--button-height-xs);
line-height: 1.5;
}
.zw-checkbox-group--button.zw-checkbox-group--xs .zw-checkbox.zw-checkbox--circle {
width: var(--button-height-xs);
padding: 0;
}
.zw-checkbox-group--button.zw-checkbox-group--xs .zw-checkbox .zw-icon {
font-size: var(--button-icon-size-xs);
}
.zw-checkbox-group--button.zw-checkbox-group--xs .zw-checkbox * + span {
margin-left: calc(var(--button-padding-h-xs) / 2);
}
.zw-checkbox-group--ghost .zw-checkbox.zw-checkbox--checked, .zw-checkbox-group--ghost .zw-checkbox.zw-checkbox--checked:hover {
background-color: transparent;
border-color: var(--theme-primary);
color: var(--theme-primary);
}
.zw-checkbox-group--ghost .zw-checkbox.zw-checkbox--checked:active {
background-color: transparent;
border-color: var(--theme-primary);
color: var(--theme-primary);
}
.zw-checkbox-group--ghost .zw-checkbox.zw-checkbox--checked.zw-checkbox--disabled, .zw-checkbox-group--ghost .zw-checkbox.zw-checkbox--checked.zw-checkbox--disabled:active, .zw-checkbox-group--ghost .zw-checkbox.zw-checkbox--checked.zw-checkbox--disabled:hover, .zw-checkbox-group--ghost .zw-checkbox.zw-checkbox--checked.zw-checkbox--disabled:focus, .zw-checkbox-group--ghost .zw-checkbox.zw-checkbox--checked.zw-checkbox--disabled:visited {
background-color: transparent;
border-color: var(--theme-primary);
color: var(--theme-primary);
cursor: not-allowed;
}
.zw-checkbox-group--compact .zw-checkbox:not(:last-child) {
margin-right: -1px;
}
.zw-checkbox-group--compact .zw-checkbox:first-child {
border-top-right-radius: 0;
border-bottom-right-radius: 0;
}
.zw-checkbox-group--compact .zw-checkbox:last-child {
border-top-left-radius: 0;
border-bottom-left-radius: 0;
}
.zw-checkbox-group--compact .zw-checkbox:not(:first-child):not(:last-child) {
border-radius: 0;
}
.zw-checkbox-group--compact .zw-checkbox.zw-checkbox--checked {
z-index: 1;
}
.zw-checkbox-group--cell {
display: block;
overflow: visible;
}
.zw-checkbox-group--cell .zw-checkbox-group__inner {
margin-right: 0;
margin-bottom: 0;
}
.zw-checkbox-group--cell .zw-checkbox {
position: static;
margin-right: 0;
margin-bottom: 0;
}
.zw-checkbox--disabled .zw-checkbox__inner {
opacity: 1;
background-color: var(--background-disabled);
}
.zw-checkbox--disabled.zw-checkbox--checked .zw-checkbox__inner {
border-color: var(--checkbox-border-color);
background-color: var(--background-disabled);
}
.zw-checkbox--disabled.zw-checkbox--checked .zw-checkbox__inner:before {
border-color: var(--checkbox-border-color);
}