mirror of
https://github.com/status-im/react-native.git
synced 2025-01-22 23:41:49 +00:00
44f7a00e95
Summary: Both iOS and Android currently support some sort of native pull to refresh control but the API was very different. I tried implementing a component based on PullToRefreshViewAndroid but that works on both platforms. I liked the idea of wrapping the ListView or ScrollView with the PullToRefreshView component and allow styling the refresh view with platform specific props if needed. I also like the fact that 'refreshing' is a controlled prop so there is no need to keep a ref to the component or to the stopRefreshing function. It is a pretty rough start so I'm looking for feedback and ideas to improve on the API before cleaning up everything. On iOS we could probably deprecate the onRefreshStart property of the ScrollView and implement the native stuff in a PullToRefreshViewManager. We could then add props to customize the look of the UIRefreshControl (tintColor). We could also deprecate the Android only component and remove it later. Closes https://github.com/facebook/react-native/pull/4915 Reviewed By: svcscm Differential Revision: D2799246 Pulled By: nicklockwood fb-gh-sync-id: 75872c12143ddbc05cc91900ab4612e477ca5765
126 lines
2.9 KiB
JavaScript
126 lines
2.9 KiB
JavaScript
/**
|
|
* The examples provided by Facebook are for non-commercial testing and
|
|
* evaluation purposes only.
|
|
*
|
|
* Facebook reserves all rights not expressly granted.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
|
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NON INFRINGEMENT. IN NO EVENT SHALL
|
|
* FACEBOOK BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
|
|
* AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
*
|
|
*/
|
|
'use strict';
|
|
|
|
const React = require('react-native');
|
|
const {
|
|
ScrollView,
|
|
StyleSheet,
|
|
RefreshControl,
|
|
Text,
|
|
TouchableWithoutFeedback,
|
|
View,
|
|
} = React;
|
|
|
|
const styles = StyleSheet.create({
|
|
row: {
|
|
borderColor: 'grey',
|
|
borderWidth: 1,
|
|
padding: 20,
|
|
backgroundColor: '#3a5795',
|
|
margin: 5,
|
|
},
|
|
text: {
|
|
alignSelf: 'center',
|
|
color: '#fff',
|
|
},
|
|
scrollview: {
|
|
flex: 1,
|
|
},
|
|
});
|
|
|
|
const Row = React.createClass({
|
|
_onClick: function() {
|
|
this.props.onClick(this.props.data);
|
|
},
|
|
render: function() {
|
|
return (
|
|
<TouchableWithoutFeedback onPress={this._onClick} >
|
|
<View style={styles.row}>
|
|
<Text style={styles.text}>
|
|
{this.props.data.text + ' (' + this.props.data.clicks + ' clicks)'}
|
|
</Text>
|
|
</View>
|
|
</TouchableWithoutFeedback>
|
|
);
|
|
},
|
|
});
|
|
|
|
const RefreshControlExample = React.createClass({
|
|
statics: {
|
|
title: '<RefreshControl>',
|
|
description: 'Adds pull-to-refresh support to a scrollview.'
|
|
},
|
|
|
|
getInitialState() {
|
|
return {
|
|
isRefreshing: false,
|
|
loaded: 0,
|
|
rowData: Array.from(new Array(20)).map(
|
|
(val, i) => ({text: 'Initial row' + i, clicks: 0})),
|
|
};
|
|
},
|
|
|
|
_onClick(row) {
|
|
row.clicks++;
|
|
this.setState({
|
|
rowData: this.state.rowData,
|
|
});
|
|
},
|
|
|
|
render() {
|
|
const rows = this.state.rowData.map((row, ii) => {
|
|
return <Row key={ii} data={row} onClick={this._onClick}/>;
|
|
});
|
|
return (
|
|
<ScrollView
|
|
style={styles.scrollview}
|
|
refreshControl={
|
|
<RefreshControl
|
|
refreshing={this.state.isRefreshing}
|
|
onRefresh={this._onRefresh}
|
|
tintColor="#ff0000"
|
|
title="Loading..."
|
|
colors={['#ff0000', '#00ff00', '#0000ff']}
|
|
progressBackgroundColor="#ffff00"
|
|
/>
|
|
}>
|
|
{rows}
|
|
</ScrollView>
|
|
);
|
|
},
|
|
|
|
_onRefresh() {
|
|
this.setState({isRefreshing: true});
|
|
setTimeout(() => {
|
|
// prepend 10 items
|
|
const rowData = Array.from(new Array(10))
|
|
.map((val, i) => ({
|
|
text: 'Loaded row' + (+this.state.loaded + i),
|
|
clicks: 0,
|
|
}))
|
|
.concat(this.state.rowData);
|
|
|
|
this.setState({
|
|
loaded: this.state.loaded + 10,
|
|
isRefreshing: false,
|
|
rowData: rowData,
|
|
});
|
|
}, 5000);
|
|
},
|
|
});
|
|
|
|
module.exports = RefreshControlExample;
|