@nutui/nutui-react
Version:
京东风格的轻量级移动端 React 组件库,支持一套代码生成 H5 和小程序
510 lines (503 loc) • 14.3 kB
CSS
@charset "UTF-8";
/* #ifdef harmony */
/* #endif */
/* #ifndef harmony */
/* #endif */
.nut-overlay {
position: fixed;
top: 0;
left: 0;
bottom: 0;
right: 0;
width: 100%;
height: 100%;
background-color: var(--nutui-overlay-bg-color, var(--nutui-color-mask, rgba(0, 0, 0, 0.7)));
z-index: var(--nutui-overlay-zIndex, 1000);
}
.nut-overflow-hidden {
overflow: hidden ;
}
@keyframes nut-fade-in {
0% {
opacity: 0;
}
1% {
opacity: 0;
}
100% {
opacity: 1;
}
}
@keyframes nut-fade-out {
0% {
opacity: 1;
}
1% {
opacity: 1;
}
100% {
opacity: 0;
}
}
.nut-overlay-slide-enter-active, .nut-overlay-slide-appear-active {
animation-fill-mode: both;
animation-name: nut-fade-in;
animation-duration: var(--nutui-overlay-animation-duration, 0.3s);
}
.nut-overlay-slide-exit-active {
animation-fill-mode: both;
animation-name: nut-fade-out;
animation-duration: var(--nutui-overlay-animation-duration, 0.3s);
}
[dir=rtl] .nut-overlay,
.nut-rtl .nut-overlay {
left: auto;
right: 0;
}
.nut-popup {
position: fixed;
min-height: 26%;
max-height: 100%;
background-color: var(--nutui-overlay-content-bg-color, var(--nutui-color-background-overlay, #ffffff));
-webkit-overflow-scrolling: touch;
font-size: var(--nutui-font-size-base, 14px);
}
.nut-popup-title {
display: flex;
flex-direction: row;
align-items: center;
justify-content: center;
border-bottom: var(--nutui-popup-title-border-bottom, 0);
padding: var(--nutui-popup-title-padding, 16px);
position: relative;
}
.nut-popup-title-wrapper {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
.nut-popup-title-title {
color: var(--nutui-color-title, #1a1a1a);
font-weight: var(--nutui-font-weight-bold, 600);
font-size: var(--nutui-popup-title-font-size, var(--nutui-font-size-l, 16px));
line-height: var(--nutui-popup-title-font-size, var(--nutui-font-size-l, 16px));
}
.nut-popup-title-description {
color: var(--nutui-color-text, #505259);
font-size: var(--nutui-popup-description-font-size, var(--nutui-font-size-base, 14px));
font-weight: var(--nutui-font-weight, 400);
}
.nut-popup-title-description-gap {
margin-top: var(--nutui-popup-description-spacing, var(--nutui-spacing-base, 8px));
}
.nut-popup-title-left {
position: absolute;
top: var(--nutui-popup-title-padding, 16px);
left: var(--nutui-popup-title-padding, 16px);
}
.nut-popup-title-right {
position: absolute;
top: var(--nutui-popup-title-padding, 16px);
right: var(--nutui-popup-title-padding, 16px);
z-index: 1;
width: var(--nutui-popup-icon-size, 20px);
height: var(--nutui-popup-icon-size, 20px);
color: var(--nutui-color-title, #1a1a1a);
cursor: pointer;
}
.nut-popup-title-right:active {
opacity: 0.7;
}
.nut-popup-title-right-top-left {
top: var(--nutui-popup-title-padding, 16px);
left: var(--nutui-popup-title-padding, 16px);
}
.nut-popup-title-right-bottom-left {
bottom: var(--nutui-popup-title-padding, 16px);
left: var(--nutui-popup-title-padding, 16px);
}
.nut-popup-title-right-bottom-right {
right: var(--nutui-popup-title-padding, 16px);
bottom: var(--nutui-popup-title-padding, 16px);
}
.nut-popup-center {
top: 50%;
left: 50%;
min-height: 10%;
max-width: 295px;
transform: translate(-50%, -50%);
}
.nut-popup-center.nut-popup-round {
border-radius: var(--nutui-popup-border-radius, var(--nutui-radius-xl, 12px));
}
.nut-popup-bottom, .nut-popup-top {
max-height: 87%;
}
.nut-popup-bottom {
bottom: 0;
left: 0;
width: 100%;
}
.nut-popup-bottom.nut-popup-round {
border-radius: var(--nutui-popup-border-radius, var(--nutui-radius-xl, 12px)) var(--nutui-popup-border-radius, var(--nutui-radius-xl, 12px)) 0 0;
}
.nut-popup-right {
top: 0;
right: 0;
width: 100px;
height: 100%;
}
.nut-popup-right.nut-popup-round {
border-radius: var(--nutui-popup-border-radius, var(--nutui-radius-xl, 12px)) 0 0 var(--nutui-popup-border-radius, var(--nutui-radius-xl, 12px));
}
.nut-popup-left {
top: 0;
left: 0;
width: 100px;
height: 100%;
}
.nut-popup-left.nut-popup-round {
border-radius: 0 var(--nutui-popup-border-radius, var(--nutui-radius-xl, 12px)) var(--nutui-popup-border-radius, var(--nutui-radius-xl, 12px)) 0;
}
.nut-popup-top {
top: 0;
left: 0;
width: 100%;
}
.nut-popup-top.nut-popup-round {
border-radius: 0 0 var(--nutui-popup-border-radius, var(--nutui-radius-xl, 12px)) var(--nutui-popup-border-radius, var(--nutui-radius-xl, 12px));
}
.nut-popup-slide {
/* 从顶部滑出 */
/* 从右侧滑出 */
/* 从底部滑出 */
/* 从左侧滑出 */
}
@keyframes popup-scale-fade-in {
from {
opacity: 0;
transform: scale(0.8);
}
to {
opacity: 1;
transform: scale(1);
}
}
@keyframes popup-scale-fade-out {
from {
opacity: 1;
transform: scale(1);
}
to {
opacity: 0;
transform: scale(0.8);
}
}
.nut-popup-slide-none-enter-active {
animation-fill-mode: both;
animation-name: popup-scale-fade-in;
animation-duration: var(--nutui-popup-animation-duration, 0.3s);
}
.nut-popup-slide-none-exit-active {
animation-fill-mode: both;
animation-name: popup-scale-fade-out;
animation-duration: var(--nutui-popup-animation-duration, 0.3s);
}
@keyframes popup-fade-in {
from {
opacity: 0;
}
to {
opacity: 1;
}
}
@keyframes popup-fade-out {
from {
opacity: 1;
}
to {
opacity: 0;
}
}
.nut-popup-slide-center-enter-active {
animation-fill-mode: both;
animation-name: popup-fade-in;
animation-duration: var(--nutui-popup-animation-duration, 0.3s);
}
.nut-popup-slide-center-exit-active {
animation-fill-mode: both;
animation-name: popup-fade-out;
animation-duration: var(--nutui-popup-animation-duration, 0.3s);
}
@keyframes popup-slide-top-enter {
from {
transform: translate3d(0, -100%, 0);
}
to {
transform: translate3d(0, 0%, 0);
}
}
@keyframes popup-slide-top-exit {
to {
transform: translate3d(0, -100%, 0);
}
}
.nut-popup-slide-top-enter-active, .nut-popup-slide-top-appear-active {
transform: translate3d(0, 0%, 0);
animation-fill-mode: both;
animation-name: popup-slide-top-enter;
animation-duration: var(--nutui-popup-animation-duration, 0.3s);
}
.nut-popup-slide-top-exit-active {
animation-fill-mode: both;
animation-name: popup-slide-top-exit;
animation-duration: var(--nutui-popup-animation-duration, 0.3s);
}
@keyframes popup-slide-right-enter {
from {
transform: translate3d(100%, 0, 0);
}
to {
transform: translate3d(0%, 0, 0);
}
}
@keyframes popup-slide-right-exit {
to {
transform: translate3d(100%, 0, 0);
}
}
.nut-popup-slide-right-enter-active, .nut-popup-slide-right-appear-active {
transform: translate3d(0, 0, 0);
animation-fill-mode: both;
animation-name: popup-slide-right-enter;
animation-duration: var(--nutui-popup-animation-duration, 0.3s);
}
.nut-popup-slide-right-exit {
animation-fill-mode: both;
animation-name: popup-slide-right-exit;
animation-duration: var(--nutui-popup-animation-duration, 0.3s);
}
@keyframes popup-slide-bottom-enter {
from {
transform: translate3d(0, 100%, 0);
}
to {
transform: translate3d(0, 0%, 0);
}
}
@keyframes slide-bottom-exit {
to {
transform: translate3d(0, 100%, 0);
}
}
.nut-popup-slide-bottom-enter-active, .nut-popup-slide-bottom-appear-active {
transform: translate(0, 0);
animation-fill-mode: both;
animation-name: popup-slide-bottom-enter;
animation-duration: var(--nutui-popup-animation-duration, 0.3s);
}
.nut-popup-slide-bottom-exit {
animation-fill-mode: both;
animation-name: slide-bottom-exit;
animation-duration: var(--nutui-popup-animation-duration, 0.3s);
}
@keyframes popup-slide-left-enter {
from {
transform: translate3d(-100%, 0, 0);
}
to {
transform: translate3d(0%, 0, 0);
}
}
@keyframes popup-slide-left-exit {
to {
transform: translate3d(-100%, 0, 0);
}
}
.nut-popup-slide-left-enter-active, .nut-popup-slide-left-appear-active {
transform: translate(0, 0);
animation-fill-mode: both;
animation-name: popup-slide-left-enter;
animation-duration: var(--nutui-popup-animation-duration, 0.3s);
}
.nut-popup-slide-left-exit-active, .nut-popup-slide-left-exit-done {
animation-fill-mode: both;
animation-name: popup-slide-left-exit;
animation-duration: var(--nutui-popup-animation-duration, 0.3s);
}
.nut-popup-slide-none-exit-done.nut-popup, .nut-popup-slide-center-exit-done.nut-popup, .nut-popup-slide-left-exit-done.nut-popup, .nut-popup-slide-right-exit-done.nut-popup, .nut-popup-slide-top-exit-done.nut-popup, .nut-popup-slide-bottom-exit-done.nut-popup {
display: none;
}
.nut-popup .nut-overflow-hidden {
overflow: hidden;
}
[dir=rtl] .nut-popup-title-left,
.nut-rtl .nut-popup-title-left {
left: auto;
right: var(--nutui-popup-title-padding, 16px);
}
[dir=rtl] .nut-popup-title-right,
.nut-rtl .nut-popup-title-right {
right: auto;
left: var(--nutui-popup-title-padding, 16px);
}
[dir=rtl] .nut-popup-title-right-top-left,
.nut-rtl .nut-popup-title-right-top-left {
left: auto;
right: var(--nutui-popup-title-padding, 16px);
}
[dir=rtl] .nut-popup-title-right-bottom-left,
.nut-rtl .nut-popup-title-right-bottom-left {
left: auto;
right: var(--nutui-popup-title-padding, 16px);
}
[dir=rtl] .nut-popup-title-right-bottom-right,
.nut-rtl .nut-popup-title-right-bottom-right {
right: auto;
left: var(--nutui-popup-title-padding, 16px);
}
[dir=rtl] .nut-popup-title .nut-icon-ArrowLeft,
.nut-rtl .nut-popup-title .nut-icon-ArrowLeft {
transform: rotate(180deg);
}
[dir=rtl] .nut-popup-center,
.nut-rtl .nut-popup-center {
left: auto;
right: 50%;
transform: translate(50%, -50%);
}
[dir=rtl] .nut-popup-bottom,
.nut-rtl .nut-popup-bottom {
left: auto;
right: 0;
}
[dir=rtl] .nut-popup-top,
.nut-rtl .nut-popup-top {
left: auto;
right: 0;
}
.nut-numberkeyboard {
width: 100%;
padding: var(--nutui-numberkeyboard-padding, 0 0 22px 0);
user-select: none;
background-color: var(--nutui-numberkeyboard-background-color, var(--nutui-color-background, #f2f3f5));
}
.nut-numberkeyboard-header {
position: relative;
display: flex;
align-items: center;
justify-content: center;
box-sizing: content-box;
padding: var(--nutui-popup-title-padding, 16px);
color: var(--nutui-color-title, #1a1a1a);
font-size: var(--nutui-popup-title-font-size, var(--nutui-font-size-l, 16px));
}
.nut-numberkeyboard-header-title {
color: var(--nutui-color-title, #1a1a1a);
display: inline-block;
font-size: var(--nutui-popup-title-font-size, var(--nutui-font-size-l, 16px));
}
.nut-numberkeyboard-header-close {
position: absolute;
display: block;
right: 0;
top: 50%;
transform: translateY(-50%);
padding: var(--nutui-numberkeyboard-header-close-padding, 0 16px);
color: var(--nutui-numberkeyboard-header-close-color, var(--nutui-color-text, #505259));
font-size: var(--nutui-numberkeyboard-header-close-font-size, 14px);
background-color: var(--nutui-numberkeyboard-header-close-background-color, transparent);
border: none;
cursor: pointer;
}
.nut-numberkeyboard-body {
display: flex;
padding: 6px 0 0 6px;
}
.nut-numberkeyboard-body-keys {
display: flex;
flex: 3;
flex-wrap: wrap;
}
.nut-numberkeyboard-body-wrapper {
position: relative;
flex: 1;
/* #ifdef harmony */
width: 33%;
/* #endif */
/* #ifndef harmony */
flex-basis: 33%;
/* #endif */
box-sizing: border-box;
padding: 0 6px 6px 0;
background-color: var(--nutui-numberkeyboard-wrapper-background-color, var(--nutui-color-background-sunken, #f7f8fc));
}
.nut-numberkeyboard-body-wrapper .key {
display: flex;
align-items: center;
justify-content: center;
height: var(--nutui-numberkeyboard-key-height, 48px);
font-size: var(--nutui-numberkeyboard-key-font-size, var(--nutui-font-size-xl, 18px));
line-height: var(--nutui-numberkeyboard-key-line-height, 1.5);
background-color: var(--nutui-numberkeyboard-key-background-color, var(--nutui-color-background-overlay, #ffffff));
color: var(--nutui-numberkeyboard-key-color, var(--nutui-color-text, #505259));
border-radius: var(--nutui-numberkeyboard-key-border-radius, 8px);
border: var(--nutui-numberkeyboard-key-border, none);
font-weight: var(--nutui-font-weight-bold, 600);
cursor: pointer;
}
.nut-numberkeyboard-body-wrapper .key.active {
background-color: var(--nutui-numberkeyboard-key-active-background-color, #ebedf0);
}
.nut-numberkeyboard-sidebar {
display: flex;
flex: 1;
flex-basis: 33%;
flex-direction: column;
}
.nut-numberkeyboard-sidebar .nut-numberkeyboard-body-wrapper {
width: 100%;
}
.nut-numberkeyboard-sidebar .nut-numberkeyboard-body-wrapper .key {
position: absolute;
top: 0;
right: 6px;
bottom: 6px;
left: 0;
height: auto;
}
.nut-numberkeyboard-sidebar .nut-numberkeyboard-body-wrapper .confirm {
font-size: var(--nutui-numberkeyboard-key-confirm-font-size, var(--nutui-font-size-l, 16px));
color: var(--nutui-numberkeyboard-key-confirm-color, #fff);
background-color: var(--nutui-numberkeyboard-key-confirm-background-color, var(--nutui-color-primary, #ff0f23));
}
.nut-numberkeyboard-sidebar .nut-numberkeyboard-body-wrapper .confirm.active {
background-color: rgba(255, 0, 0, 0.7);
}
[dir=rtl] .nut-popup .nut-numberkeyboard-header-close,
.nut-rtl .nut-popup .nut-numberkeyboard-header-close {
right: auto;
left: 0;
}
[dir=rtl] .nut-popup .nut-numberkeyboard-body,
.nut-rtl .nut-popup .nut-numberkeyboard-body {
padding: 6px 6px 0 0;
}
[dir=rtl] .nut-popup .nut-numberkeyboard-body-wrapper,
.nut-rtl .nut-popup .nut-numberkeyboard-body-wrapper {
padding: 0 0 6px 6px;
}
[dir=rtl] .nut-popup .nut-numberkeyboard-body-wrapper .delete,
.nut-rtl .nut-popup .nut-numberkeyboard-body-wrapper .delete {
transform: rotate(-180deg);
}
[dir=rtl] .nut-popup .nut-numberkeyboard-sidebar .nut-numberkeyboard-body-wrapper .key,
.nut-rtl .nut-popup .nut-numberkeyboard-sidebar .nut-numberkeyboard-body-wrapper .key {
left: 6px;
right: 0;
}
[dir=rtl] .nut-popup .nut-numberkeyboard-sidebar .nut-numberkeyboard-body-wrapper .key.delete,
.nut-rtl .nut-popup .nut-numberkeyboard-sidebar .nut-numberkeyboard-body-wrapper .key.delete {
transform: rotate(-180deg);
}