forked from beefe/react-native-actionsheet
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathActionSheetIOS.js
More file actions
65 lines (46 loc) · 1.2 KB
/
ActionSheetIOS.js
File metadata and controls
65 lines (46 loc) · 1.2 KB
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
'use strict';
import React, {ActionSheetIOS, PropTypes} from 'react-native';
const optionNames = [
'title',
'options',
'tintColor',
'cancelButtonIndex',
'destructiveButtonIndex'
];
function isArray(obj) {
return Object.prototype.toString.call(obj) === '[object Array]';
}
class ActionSheet extends React.Component {
constructor(props) {
super(props);
}
componentDidMount() {
let options = this.props.options;
if (!isArray(options) || options.length === 0) {
throw Error('Prop `options` must be an array and it must not be empty.');
}
}
show() {
let props = this.props;
let options = optionNames.reduce((obj, name, index) => {
if (typeof props[name] !== 'undefined') obj[name] = props[name];
return obj;
}, {});
ActionSheetIOS.showActionSheetWithOptions(options, props.onPress);
}
render() {
return null;
}
}
ActionSheet.propTypes = {
title: PropTypes.string,
options: PropTypes.array.isRequired,
tintColor: PropTypes.string,
cancelButtonIndex: PropTypes.number,
destructiveButtonIndex: PropTypes.number,
onPress: PropTypes.func
};
ActionSheet.defaultProps = {
onPress: () => {}
};
export default ActionSheet;