import * as React from 'react'; const Component = React.Component; const { View, TouchableHighlight } = require('react-native'); const Icon = require('react-native-vector-icons/Ionicons').default; Icon.loadFont(); interface Style { [key: string]: any; } interface Props { style: Style; checked: boolean; onChange: (checked: boolean)=> void; accessibilityLabel?: string; } interface State { checked: boolean; } const styles: Style = { checkboxIcon: { fontSize: 20, height: 22, // marginRight: 10, }, }; class Checkbox extends Component { public constructor(props: Props) { super(props); this.state = { checked: false, }; } public UNSAFE_componentWillMount() { this.setState({ checked: this.props.checked }); } public UNSAFE_componentWillReceiveProps(newProps: Props) { if ('checked' in newProps) { this.setState({ checked: newProps.checked }); } } private onPress() { const newChecked = !this.state.checked; this.setState({ checked: newChecked }); if (this.props.onChange) this.props.onChange(newChecked); } public render() { const iconName = this.state.checked ? 'md-checkbox-outline' : 'md-square-outline'; const style: Style = this.props.style ? Object.assign({}, this.props.style) : {}; style.justifyContent = 'center'; style.alignItems = 'center'; const checkboxIconStyle = Object.assign({}, styles.checkboxIcon); if (style.color) checkboxIconStyle.color = style.color; if (style.paddingTop) checkboxIconStyle.marginTop = style.paddingTop; if (style.paddingBottom) checkboxIconStyle.marginBottom = style.paddingBottom; if (style.paddingLeft) checkboxIconStyle.marginLeft = style.paddingLeft; if (style.paddingRight) checkboxIconStyle.marginRight = style.paddingRight; const thStyle = { justifyContent: 'center', alignItems: 'center', }; if (style && style.display === 'none') return ; // if (style.display) thStyle.display = style.display; return ( this.onPress()} style={thStyle} accessibilityRole="checkbox" accessibilityState={{ checked: this.state.checked, }} accessibilityLabel={this.props.accessibilityLabel ?? ''}> ); } } export default Checkbox;