123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187 |
- @import "../styles/mixins/index.less";
- @import "../styles/themes/index.less";
- .@{wux-prefix}-refresher {
- position: absolute;
- top: -60px;
- right: 0;
- left: 0;
- overflow: hidden;
- margin: auto;
- height: 50px;
- &--hidden {
- visibility: hidden;
- }
- &--visible {
- visibility: visible;
- }
- &__content {
- position: absolute;
- bottom: 5px;
- left: 0;
- width: 100%;
- color: @text-color;
- text-align: center;
- font-size: 30px;
- }
- &__content--text {
- bottom: 0;
- }
- &__text-pulling {
- font-size: @font-size-lg;
- line-height: @font-size-lg;
- }
- &__text-refreshing {
- font-size: @font-size-lg;
- line-height: @font-size-lg;
- display: none;
- }
- &__icon-pulling {
- width: 100%;
- backface-visibility: hidden;
- transform-style: preserve-3d;
- padding: 7px 0;
- animation-name: refresh-spin-back;
- animation-duration: .2s;
- animation-timing-function: linear;
- animation-fill-mode: none;
- transform: translateZ(0) rotate(0deg);
- }
- &__icon-refreshing {
- width: 100%;
- backface-visibility: hidden;
- transform-style: preserve-3d;
- padding: 7px 0;
- display: none;
- animation-duration: 1.5s;
- }
- &__icon--arrow-down {
- display: block;
- margin: 0 auto;
- width: 20px;
- height: 20px;
- background-repeat: no-repeat;
- background-position: center center;
- background-size: 20px 20px;
- background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAQAAAAAYLlVAAAABGdBTUEAALGPC/xhBQAAACBjSFJNAAB6JgAAgIQAAPoAAACA6AAAdTAAAOpgAAA6mAAAF3CculE8AAAAAmJLR0QAAKqNIzIAAAAHdElNRQfhAhQABBG6qxTZAAABVklEQVRo3u3YvUoDQRiF4ePPTZgbEGsh23sBgqWCKQe8AVvB0tJySgPah9T2CaSxkNhY6i3YaRN1J7uz+31nAmnOVJNkM++zCcyyC2hobHnslHw5HOIZA3zgJL6xa+wX8ZcAgAGW/InsFgE2MAQQQAABBBBAAAEEEEAAAQQQYOuAjtvzcIprfOImvpYEwhFucYC7OGn/PHtfH87xuJpWcZ455vt3FjPrhCFmq+lFfGo7Iv8X3P/NZmFInv1/vr6eEfBVm1OEJJ+uZwJcJa/chLX8+nr9gDjFiCc08qM49f4CiGOW0JIf547t3Ac4giffuxH5Cb68YSf0Ebx501ZsJ/jzxmuBjcDkzRejfgKXdz2sDpd4SN6oasmKyzufljcIuWHOA3sewOLl+B1nm8w7ASaCK+8G9BKceQLQSXDnKUCWQORJQCuBytOABoHMFwASAp3X0AB+AFVjfoii8X5lAAAAJXRFWHRkYXRlOmNyZWF0ZQAyMDE3LTAyLTIwVDAwOjA0OjE3KzA4OjAwenpBPAAAACV0RVh0ZGF0ZTptb2RpZnkAMjAxNy0wMi0yMFQwMDowNDoxNyswODowMAsn+YAAAAAASUVORK5CYII=");
- }
- &__icon--refresher {
- display: block;
- margin: 0 auto;
- width: 20px;
- height: 20px;
- background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20viewBox%3D'0%200%20120%20120'%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20xmlns%3Axlink%3D'http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink'%3E%3Cdefs%3E%3Cline%20id%3D'l'%20x1%3D'60'%20x2%3D'60'%20y1%3D'7'%20y2%3D'27'%20stroke%3D'%236c6c6c'%20stroke-width%3D'11'%20stroke-linecap%3D'round'%2F%3E%3C%2Fdefs%3E%3Cg%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(30%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(60%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(90%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(120%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(150%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.37'%20transform%3D'rotate(180%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.46'%20transform%3D'rotate(210%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.56'%20transform%3D'rotate(240%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.66'%20transform%3D'rotate(270%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.75'%20transform%3D'rotate(300%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.85'%20transform%3D'rotate(330%2060%2C60)'%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E");
- background-repeat: no-repeat;
- background-position: 50%;
- background-size: 100%;
- transform-origin: 50%;
- animation: refresh-spin-rotate 1s steps(12, end) infinite;
- }
- &--active {
- &.@{wux-prefix}-refresher--refreshing {
- transition: transform .2s;
- transform: scale(1);
- .@{wux-prefix}-refresher__icon-pulling,
- .@{wux-prefix}-refresher__text-pulling {
- display: none;
- }
- .@{wux-prefix}-refresher__icon-refreshing,
- .@{wux-prefix}-refresher__text-refreshing {
- display: block;
- }
- .@{wux-prefix}-refresher--refreshing-tail {
- transform: scale(0);
- }
- }
- .@{wux-prefix}-refresher__icon-pulling:not(.@{wux-prefix}-refresher__icon-pulling--disabled) {
- animation-name: refresh-spin;
- transform: translateZ(0) rotate(-180deg);
- }
- }
- }
- .@{wux-prefix}-loader {
- overflow: hidden;
- margin: auto;
- height: 50px;
- font-size: 15px;
- position: relative;
- text-align: center;
- display: none;
- .@{wux-prefix}-refresher__icon--refresher {
- display: inline-block;
- margin: 0;
- }
- &__text-loading {
- margin-left: @margin-component-base;
- }
- &--hidden {
- visibility: hidden;
- display: none;
- }
- &--visible {
- visibility: visible;
- display: block;
- }
- &--end {
- visibility: visible;
- display: block;
- }
- &__content {
- position: absolute;
- width: 100%;
- top: 50%;
- transform: translateY(-50%);
- color: @text-color;
- display: flex;
- align-items: center;
- justify-content: center;
- }
- }
- @keyframes refresh-spin {
- 0% {
- transform: translateZ(0) rotate(0);
- }
- to {
- transform: translateZ(0) rotate(180deg);
- }
- }
- @keyframes refresh-spin-back {
- 0% {
- transform: translateZ(0) rotate(180deg);
- }
- to {
- transform: translateZ(0) rotate(0);
- }
- }
- @keyframes refresh-spin-rotate {
- 100% {
- transform: rotate(360deg);
- }
- }
|