react-native-swipe-left
Version:
a RN swipe-left component for listView.(左滑解决方案)
175 lines (157 loc) • 5.4 kB
JavaScript
import React, { Component } from 'react';
import {
AppRegistry,
ListView,
TouchableHighlight,
ScrollView,
StyleSheet,
PanResponder,
Image,
Text,
View,
RefreshControl,
} from 'react-native';
import Platform from 'Platform';
//swipt
import SwipeitemView from 'react-native-swipe-left';
//ios第三方下拉组件
import PullDownRefreshView from './components/PullDown';
class AresRn extends Component {
constructor(props) {
super(props);
var ds = new ListView.DataSource({rowHasChanged: (r1, r2) => r1 !== r2});
this._dataRow = {};
this.openRowId = '';
this.state = {
dataSource: ds.cloneWithRows(['row 1', 'row 2', 'row 3', 'row 4', 'row 5', 'row 6', 'row 7', 'row 8', 'row 9', 'row 10', 'row 11', 'row 12', 'row 13', 'row 14', 'row 15']),
isShowToTop: false,
isReFresh: false,
scrollEnable: true,
hasIdOpen: false
};
}
_listView() {
/*
* android,ios都使用原生下拉刷新组件:
*/
return (
<ListView
style={styles.listview}
dataSource={this.state.dataSource}
renderFooter={this._renderFooter.bind(this)}
renderRow={this.rowRender.bind(this)}
onEndReachedThreshold = {10}
ref="listview"
renderScrollComponent={(props)=>{
return <ScrollView scrollEnabled={this.state.scrollEnable} {...props}/>
}}
refreshControl={
<RefreshControl
refreshing={this.state.isReFresh}
onRefresh={this.PullDownRefresh.bind(this)}
colors={['#ffffff', '#ffffff', '#ffffff']}
progressBackgroundColor="#099fde"/>
}/>
);
}
PullDownRefresh() {
let self = this;
this.setState({
isReFresh: true
});
setTimeout(function() {
self.setState({
isReFresh: false
})
}, 2000);
}
render() {
let listView = this._listView();
return (
<View style={{flex:1}}>
<View style={styles.header}>
<Text style={styles.headerText}>消息列表</Text>
</View>
{listView}
{this.state.isShowToTop?<ScrollTopView root={this} scrollname='helloworld'></ScrollTopView>:null}
</View>
);
}
rowRender(data, a, b) {
let rightBtn = this._rightButtons();
let id = '' + a + b;
return (
<SwipeitemView
root={this}
ref={(row)=>this._dataRow[id] = row}
id={id}
data={data}
rightBtn={rightBtn}>
<View style={{height: 54}}>
<TouchableHighlight
onPress={
()=>{
alert('hi!');
}}>
<Text>hello world</Text>
</TouchableHighlight>
</View>
</SwipeitemView>
);
}
_rightButtons() {
return [{
id: 1,
text: 'button',
width: 80,
bgColor: 'red',
underlayColor: '#ffffff',
onPress: ()=>{alert('delete1!');},
}, {
id: 2,
image: '',
width: 80,
bgColor: null,
onPress: ()=>{alert('delete2!')}
}, {
id: 3,
text: 'button',
width: 80,
bgColor: 'yellow',
onPress: ()=>{alert('delete3!');},
}]
}
}
const styles = StyleSheet.create({
listview:{
flex: 1,
backgroundColor: '#eeeeee'
},
header: {
height : 50,
paddingTop:15,
justifyContent:'center',
alignItems:'center',
backgroundColor : '#099fde'
},
headerText: {
color: '#ffffff'
},
deletebtn: {
flex: 1,
width: 80,
height: 74,
backgroundColor: 'red',
alignItems: 'center',
justifyContent: 'center'
},
btntext: {
color: '#ffffff'
},
deleteBut: {
flex: 1,
justifyContent: 'center',
alignItems: 'center',
},
});
AppRegistry.registerComponent('AresRn', () => AresRn);