-
Notifications
You must be signed in to change notification settings - Fork 253
/
Copy pathApp.js
65 lines (63 loc) · 1.66 KB
/
App.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
import React, { Component } from 'react';
import { StyleSheet, SafeAreaView } from 'react-native';
import DropdownAlert from 'react-native-dropdownalert';
import { MAIN_CUSTOM_COLOR, MAIN_BACKGROUND_COLOR } from './constants';
import List from './List';
export default class App extends Component {
constructor(props) {
super(props);
}
onSelect({ item, index }) {
switch (item.type) {
case 'close':
this._close();
break;
default:
const random = Math.floor(Math.random() * 4000 + 1);
const title = `${item.type} in ${random} milliseconds`;
this.dropDownAlertRef.alertWithType(
item.type,
title,
item.message,
{ message: 'HelloWorld', source: 'https://facebook.github.io/react-native/docs/assets/favicon.png' },
random
);
}
}
_close = () => {
this.dropdown.closeAction();
};
_onClose = data => {
console.log(data);
};
_onCancel = data => {
console.log(data);
};
_onTap = data => {
console.log(data);
};
render() {
return (
<SafeAreaView style={styles.container}>
<List onSelect={({ item, index }) => this.onSelect({ item, index })} />
<DropdownAlert
ref={ref => this.dropDownAlertRef = ref}
containerStyle={{
backgroundColor: MAIN_CUSTOM_COLOR,
}}
showCancel={true}
onCancel={this._onCancel}
onTap={this._onTap}
messageNumOfLines={0}
onClose={this._onClose}
/>
</SafeAreaView>
);
}
}
const styles = StyleSheet.create({
container: {
flex: 1,
backgroundColor: MAIN_BACKGROUND_COLOR,
},
});