zarm-web
Version:
基于 React 的桌面端UI库
442 lines (400 loc) • 12.2 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);
}
.ui-tree {
margin: 0;
padding: 5px;
}
.ui-tree li {
padding: 3px 0;
margin: 0;
list-style: none;
white-space: nowrap;
outline: 0;
}
.ui-tree li .collapse {
overflow: hidden;
display: block;
}
.ui-tree li .collapse-active {
transition: height 0.2s ease-out;
}
.ui-tree li ul {
margin: 0;
padding: 0 0 0 18px;
}
.ui-tree li .ui-tree-node-content-wrapper {
display: inline-block;
cursor: pointer;
text-decoration: none;
vertical-align: top;
}
.ui-tree li span.ui-tree-switcher {
width: 24px;
height: 24px;
line-height: 24px;
display: inline-block;
vertical-align: top;
cursor: pointer;
}
.ui-tree li span.ui-tree-switcher.ui-tree-switcher-open:after, .ui-tree li span.ui-tree-switcher.ui-tree-switcher-close:after {
width: 0;
height: 0;
content: "";
display: inline-block;
border: 4px solid #000;
border-color: rgba(0, 0, 0, 0.65) transparent transparent;
transition: transform 0.3s;
}
.ui-tree li span.ui-tree-switcher.ui-tree-switcher-open:after {
transform: translate(8px, 0) rotate(0deg);
}
.ui-tree li span.ui-tree-switcher.ui-tree-switcher-close:after {
transform: translate(10px, -2px) rotate(-90deg);
}
.ui-tree li span.ui-tree-switcher.ui-tree-switcher-noop {
cursor: default;
}
.ui-tree li span.ui-tree-checkbox {
width: 20px;
height: 24px;
line-height: 24px;
display: inline-block;
vertical-align: top;
cursor: pointer;
text-align: center;
}
.ui-tree li span.ui-tree-node-content-wrapper {
line-height: 24px;
height: 24px;
display: inline-block;
color: rgba(0, 0, 0, 0.65);
font-size: 12px;
}
.ui-tree li-child-tree {
display: none;
}
.ui-tree li-child-tree-open {
display: block;
}
.ui-tree li-treenode-disabled > span:not(.ui-tree-switcher),
.ui-tree li-treenode-disabled > a,
.ui-tree li-treenode-disabled > a span {
color: #767676;
cursor: not-allowed;
}