forked from dancormier/react-native-swipeout
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathindex.android.js
89 lines (77 loc) · 2.36 KB
/
index.android.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
78
79
80
81
82
83
84
85
86
87
88
89
/**
* Sample React Native App
* https://github.com/facebook/react-native
*/
'use strict';
var React = require('react');
var {
AppRegistry,
StyleSheet,
ListView,
Text,
View,
} = require('react-native');
// include react-native-swipeout
var Swipeout = require('./index.js')
// example row data (see for json structure)
var rows = require('./example/data.js')
// example styles
var styles = require('./example/styles.js')
// example swipout app
var swipeout = React.createClass({
getInitialState: function() {
// datasource rerendered when change is made (used to set swipeout to active)
var ds = new ListView.DataSource({rowHasChanged: (row1, row2) => true})
return {
dataSource: ds.cloneWithRows(rows),
scrollEnabled: true
}
}
// set scrolling to true/false
, _allowScroll: function(scrollEnabled) {
this.setState({ scrollEnabled: scrollEnabled })
}
// set active swipeout item
, _handleSwipeout: function(sectionID, rowID) {
for (var i = 0; i < rows.length; i++) {
if (i != rowID) rows[i].active = false
else rows[i].active = true
}
this._updateDataSource(rows)
}
, _updateDataSource: function(data) {
this.setState({
dataSource: this.state.dataSource.cloneWithRows(data)
})
}
, _renderRow: function (rowData: string, sectionID: number, rowID: number) {
return <Swipeout
left={rowData.left}
right={rowData.right}
rowID={rowID}
sectionID={sectionID}
autoClose={rowData.autoClose}
backgroundColor={rowData.backgroundColor}
close={!rowData.active}
onOpen={(sectionID, rowID) => this._handleSwipeout(sectionID, rowID)}
scroll={event => this._allowScroll(event)}>
<View style={styles.li}>
<Text style={styles.liText}>{rowData.text}</Text>
</View>
</Swipeout>
}
, render: function() {
return (
<View style={styles.container}>
<View style={styles.statusbar}/>
<View style={styles.navbar}><Text style={styles.navbarTitle}>Swipeout</Text></View>
<ListView
scrollEnabled={this.state.scrollEnabled}
dataSource={this.state.dataSource}
renderRow={this._renderRow}
style={styles.listview}/>
</View>
)
}
})
AppRegistry.registerComponent('swipeout', () => swipeout);