mirror of
https://github.com/BlueWallet/BlueWallet.git
synced 2025-02-23 23:27:26 +01:00
* OPS: randombytes work * OPS: porting to RN android: added prompt, refactoring * OPS: better android prompt * FIX: scan qr callback * FIX: correct fee sat calculation for HD & classic segwit wallets * FIX: Fixed height for button in empty transaction list * FIX: keyboard issue on fee selection modal * FIX: slow QR code generation for HD backup screen * ADD: wallet reorder * FIX: TypeError: undefined is not an object (evaluating 'recommendedFees.halfHourFee') #133 * FIX: android appstore link * OPS: Code to Migrate Expo json * REF: renamed blitzhub to lndhub * OPS: Migration: move expo files instead of parsing * FIX: lndhub uri usage * FIX: no security alert on android (it was ios specific) * REF: better tx list rendering and sorting * ADD: verify tx on coinb.in * FIX: Tap to dismiss is not working #137 * REF: Removed Wallet gradients duplication. * REF: about screen * FIX: bech32 qr scan in send screen * FIX: better bip21 handling * Use of dayjs for transaction details * REF: QR code content follows BIP21 * ADD: fee in local currency when send * FIX: Refresh wallet info on page focus
76 lines
2.2 KiB
JavaScript
76 lines
2.2 KiB
JavaScript
/* global alert */
|
|
import React from 'react';
|
|
import { ActivityIndicator, Image, View, TouchableOpacity } from 'react-native';
|
|
import PropTypes from 'prop-types';
|
|
import Camera from 'react-native-camera';
|
|
import Permissions from 'react-native-permissions';
|
|
import { SafeBlueArea } from '../../BlueComponents';
|
|
let EV = require('../../events');
|
|
|
|
export default class CameraExample extends React.Component {
|
|
static navigationOptions = {
|
|
header: null,
|
|
};
|
|
|
|
state = {
|
|
isLoading: false,
|
|
hasCameraPermission: null,
|
|
};
|
|
|
|
async onBarCodeScanned(ret) {
|
|
if (this.ignoreRead) return;
|
|
this.ignoreRead = true;
|
|
setTimeout(() => {
|
|
this.ignoreRead = false;
|
|
}, 2000);
|
|
|
|
this.props.navigation.goBack();
|
|
EV(EV.enum.CREATE_TRANSACTION_NEW_DESTINATION_ADDRESS, ret.data);
|
|
} // end
|
|
|
|
async componentDidMount() {
|
|
Permissions.request('camera').then(response => {
|
|
// Response is one of: 'authorized', 'denied', 'restricted', or 'undetermined'
|
|
this.setState({ hasCameraPermission: response === 'authorized' });
|
|
});
|
|
}
|
|
|
|
render() {
|
|
if (this.state.isLoading) {
|
|
return (
|
|
<View style={{ flex: 1, paddingTop: 20 }}>
|
|
<ActivityIndicator />
|
|
</View>
|
|
);
|
|
}
|
|
|
|
const { hasCameraPermission } = this.state;
|
|
if (hasCameraPermission === null) {
|
|
return <View />;
|
|
} else if (hasCameraPermission === false) {
|
|
alert('BlueWallet does not have permission to use your camera.');
|
|
this.props.navigation.goBack(null);
|
|
return <View />;
|
|
} else {
|
|
return (
|
|
<SafeBlueArea style={{ flex: 1 }}>
|
|
<Camera style={{ flex: 1 }} onBarCodeRead={ret => this.onBarCodeScanned(ret)}>
|
|
<TouchableOpacity
|
|
style={{ width: 40, height: 80, padding: 14, marginTop: 32 }}
|
|
onPress={() => this.props.navigation.goBack(null)}
|
|
>
|
|
<Image style={{ alignSelf: 'center' }} source={require('../../img/close.png')} />
|
|
</TouchableOpacity>
|
|
</Camera>
|
|
</SafeBlueArea>
|
|
);
|
|
}
|
|
}
|
|
}
|
|
|
|
CameraExample.propTypes = {
|
|
navigation: PropTypes.shape({
|
|
goBack: PropTypes.function,
|
|
dismiss: PropTypes.function,
|
|
}),
|
|
};
|