const React = require('react'); const Component = React.Component; const { View, TouchableOpacity } = require('react-native'); import { RNCamera } from 'react-native-camera'; const Icon = require('react-native-vector-icons/Ionicons').default; const { _ } = require('lib/locale.js'); class CameraView extends Component { constructor() { super(); this.state = { snapping: false, camera: RNCamera.Constants.Type.back, }; this.back_onPress = this.back_onPress.bind(this); this.photo_onPress = this.photo_onPress.bind(this); this.reverse_onPress = this.reverse_onPress.bind(this); } back_onPress() { if (this.props.onCancel) this.props.onCancel(); } reverse_onPress() { if (this.state.camera == RNCamera.Constants.Type.back) { this.setState({ camera: RNCamera.Constants.Type.front, }); } else if (this.state.camera == RNCamera.Constants.Type.front) { this.setState({ camera: RNCamera.Constants.Type.back, }); } } async photo_onPress() { if (!this.camera || !this.props.onPhoto) return; this.setState({ snapping: true }); const result = await this.camera.takePictureAsync({ quality: 0.8, exif: true, fixOrientation: true, }); if (this.props.onPhoto) this.props.onPhoto(result); this.setState({ snapping: false }); } render() { const photoIcon = this.state.snapping ? 'md-checkmark' : 'md-camera'; return ( { this.camera = ref; }} type={this.state.camera} captureAudio={false} androidCameraPermissionOptions={{ title: _('Permission to use camera'), message: _('Your permission to use your camera is required.'), buttonPositive: _('OK'), buttonNegative: _('Cancel'), }} > ); } } module.exports = CameraView;