forked from Chion82/react-native-web-extended
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathindex.js
77 lines (69 loc) · 2.34 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
/* eslint-disable */
import PropTypes from 'prop-types';
import React, { Component } from 'react';
import {ActivityIndicator} from 'react-native-web';
import ReactPullToRefresh from '@piranna/react-pull-to-refresh';
const arrowIcon = '';
const css = `.ptr-element .pull-down-icon {
font-size: 34px;
transition: all .25s ease;
-webkit-transform: rotate(90deg);
transform: rotate(90deg);
margin-top: -22px;
margin-left: auto;
margin-right: auto;
display: block;
width: 22px;
height: 22px;
}
.ptr-refresh .pull-down-icon {
-webkit-transform: rotate(270deg);
transform: rotate(270deg);
}
.ptr-loading .pull-down-icon {
display: none;
}
.ptr-reset .pull-down-icon {
display: block;
}
.ptr-element .loading {
display: inline-block;
display: none;
margin-top: 5px;
}
.ptr-loading .loading {
display: block;
margin-bottom: 10px;
}`;
(function () {
const styleTag = document.createElement('style');
styleTag.innerHTML = css;
document.getElementsByTagName('head')[0].appendChild(styleTag);
}());
class RefreshControl extends Component {
static propTypes = {
children: PropTypes.any,
onRefresh: PropTypes.func.isRequired,
refreshing: PropTypes.bool.isRequired,
style: PropTypes.any
}
handleRefresh(resolve) {
this.props.onRefresh();
setInterval(() => {
if (!this.props.refreshing) {
resolve();
}
}, 1);
}
render() {
return (
<ReactPullToRefresh
icon={<img width={22} height={22} src={arrowIcon} className='pull-down-icon' />}
loading={<div className='loading'><ActivityIndicator animating /></div>}
onRefresh={this.handleRefresh.bind(this)} >
{this.props.children}
</ReactPullToRefresh>
);
}
}
export default RefreshControl;