UNPKG

react-native-swipe-left

Version:

a RN swipe-left component for listView.(左滑解决方案)

175 lines (157 loc) 5.4 kB
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);