zarm
Version:
基于 React 的移动端UI库
139 lines (125 loc) • 4.47 kB
CSS
.za-checkbox {
--icon-size: var(--za-checkbox-icon-size, 22px);
--icon-background: var(--za-checkbox-icon-background, transparent);
--icon-border-radius: var(--za-checkbox-icon-border-radius, 22px);
--icon-border-width: var(--za-checkbox-icon-border-width, 1px);
--icon-border-color: var(--za-checkbox-icon-border-color, rgb(199, 199, 204));
--tick-font-size: var(--za-checkbox-tick-font-size, 16px);
--tick-color: var(--za-checkbox-tick-color, #fff);
--tick-transition: var(--za-checkbox-tick-transition, all 0.2s cubic-bezier(0.71, -0.46, 0.88, 0.6));
--text-margin-horizontal: var(--za-checkbox-text-margin-horizontal, 8px);
--active-opacity: var(--za-checkbox-active-opacity, 0.6);
--checked-icon-background: var(--za-checkbox-checked-icon-background, var(--za-theme-primary));
--checked-icon-border-color: var(--za-checkbox-checked-icon-border-color, var(--za-theme-primary));
--checked-tick-color: var(--za-checkbox-checked-tick-color, #fff);
--disabled-icon-background: var(--za-checkbox-disabled-icon-background, #f2f2f2);
--disabled-icon-border-color: var(--za-checkbox-disabled-icon-border-color, rgba(199, 199, 204, 0.7));
--disabled-text-color: var(--za-checkbox-disabled-text-color, rgba(0, 0, 0, 0.3));
--disabled-tick-color: var(--za-checkbox-disabled-tick-color, #bcbcbc);
display: inline-flex;
vertical-align: text-bottom;
justify-content: flex-start;
align-items: center;
cursor: pointer;
}
.za-checkbox:not(.za-checkbox--disabled):active {
opacity: var(--active-opacity);
}
.za-checkbox__icon {
display: inline-block;
vertical-align: middle;
}
.za-checkbox__input {
display: none;
}
.za-checkbox__text {
vertical-align: middle;
margin: 0 var(--text-margin-horizontal);
}
.za-checkbox__tick {
display: flex;
align-items: center;
justify-content: center;
width: var(--icon-size);
height: var(--icon-size);
border: var(--icon-border-width) solid var(--icon-border-color);
border-radius: var(--icon-border-radius);
background: var(--icon-background);
}
.za-checkbox__tick .za-icon {
font-size: var(--tick-font-size);
color: var(--tick-color);
transform: scale(0);
transition: var(--tick-transition);
}
.za-checkbox--checked .za-checkbox__tick, .za-checkbox--indeterminate .za-checkbox__tick {
border-color: var(--checked-icon-border-color);
background: var(--checked-icon-background);
}
.za-checkbox--checked .za-checkbox__tick .za-icon, .za-checkbox--indeterminate .za-checkbox__tick .za-icon {
color: var(--checked-tick-color);
transform: scale(1);
}
.za-checkbox--disabled .za-checkbox__input {
cursor: not-allowed;
}
.za-checkbox--disabled .za-checkbox__text {
color: var(--disabled-text-color);
}
.za-checkbox--disabled .za-checkbox__tick {
border-color: var(--disabled-icon-border-color);
background: var(--disabled-icon-background);
}
.za-checkbox--disabled.za-checkbox--checked .za-checkbox__tick {
border-color: var(--disabled-icon-border-color);
background: var(--disabled-icon-background);
}
.za-checkbox--disabled.za-checkbox--checked .za-checkbox__tick .za-icon {
color: var(--disabled-tick-color);
}
.za-checkbox-group {
--group-spacing-vertical: var(--za-checkbox-group-group-spacing-vertical, 8px);
--group-spacing-horizontal: var(--za-checkbox-group-group-spacing-horizontal, 24px);
display: inline-block;
vertical-align: middle;
overflow: hidden;
}
.za-checkbox-group__inner {
margin-right: calc(var(--group-spacing-horizontal) * -1);
margin-bottom: calc(var(--group-spacing-vertical) * -1);
line-height: 1;
}
.za-checkbox-group .za-checkbox {
margin-right: var(--group-spacing-horizontal);
margin-bottom: var(--group-spacing-vertical);
}
.za-checkbox-group--block {
width: 100%;
}
.za-checkbox-group--block .za-checkbox-group__inner {
display: flex;
flex-wrap: wrap;
}
.za-checkbox-group--block .za-checkbox {
flex: 1;
}
.za-checkbox-group--button {
--group-spacing-vertical: var(--za-checkbox-group-group-spacing-vertical, var(--za-padding-v-xs));
--group-spacing-horizontal: var(--za-checkbox-group-group-spacing-horizontal, var(--za-padding-h-xs));
}
.za-checkbox-group--list {
display: block;
overflow: visible;
}
.za-checkbox-group--list .za-checkbox-group__inner {
margin-right: 0;
margin-bottom: 0;
}
.za-checkbox-group--list .za-checkbox {
display: flex;
margin-right: 0;
margin-bottom: 0;
}
.za-checkbox-group--list .za-checkbox .za-checkbox__text {
margin-left: 0;
}