-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
82 lines (71 loc) · 3.35 KB
/
index.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
import React, { Component } from 'react';
import { View, Text, TouchableOpacity, Image } from 'react-native';
const Icon = () => (
<Image
style={{width: 14, height: 14, margin: 2}}
source={{uri: ''}}
/>
);
const Checked = () => (
<View style={{width: 20, height: 20, backgroundColor: 'transparent', borderColor: '#006DF0', borderWidth: 1}}>
<Icon />
</View>
);
const NotChecked = () => (
<View style={{width: 20, height: 20, backgroundColor: 'transparent', borderColor: '#ccc', borderWidth: 1}}></View>
);
export default class CheckBox extends Component {
constructor (props) {
super(props);
this.state = {
checked: props.checked ? props.checked : false,
value: props.value ? props.value : '',
name: props.name ? props.name : '',
disabled: props.disabled ? props.disabled : false,
onChange: props.onChange ? props.onChange : () => {},
content: (props.content && ['append', 'prepend'].includes(props.content)) ? props.content : 'append'
};
}
componentWillReceiveProps(props) {
let changed = false;
if ( this.state.checked != props.checked )
changed = true;
this.setState({
checked: props.checked ? props.checked : false,
value: props.value ? props.value : '',
name: props.name ? props.name : '',
disabled: props.disabled ? props.disabled : false,
onChange: props.onChange ? props.onChange : () => {},
content: (props.content && ['append', 'prepend'].includes(props.content)) ? props.content : 'append'
}, () => {
if (changed)
this.state.onChange({
'name': this.state.name,
'checked': this.state.checked,
'value': this.state.value
});
});
}
toggle () {
if ( !this.state.disabled ) {
this.setState({
checked: !this.state.checked
}, () => {
this.state.onChange({
'name': this.state.name,
'checked': this.state.checked,
'value': this.state.value
});
});
}
}
render () {
return (
<TouchableOpacity style={[{padding: 20, alignItems: 'center', opacity: this.state.disabled ? .5 : 1}, this.props.style]} onPress={this.toggle.bind(this)} activeOpacity={this.state.disabled ? .5 : 1}>
{ this.state.content == 'prepend' && this.props.children }
{ this.state.checked ? this.props.componentChecked ? this.props.componentChecked : <Checked /> : this.props.componentNotChecked ? this.props.componentNotChecked : <NotChecked /> }
{ this.state.content == 'append' && this.props.children }
</TouchableOpacity>
);
}
}