BlueWallet/screen/wallets/buyBitcoin.js

118 lines
3.3 KiB
JavaScript
Raw Normal View History

2018-10-28 11:13:28 +01:00
import React, { Component } from 'react';
import { StyleSheet, StatusBar, Linking } from 'react-native';
import { BlueNavigationStyle, BlueLoading, SafeBlueArea } from '../../BlueComponents';
2018-10-28 11:13:28 +01:00
import PropTypes from 'prop-types';
import { WebView } from 'react-native-webview';
import { getSystemName } from 'react-native-device-info';
import { AppStorage, LightningCustodianWallet, WatchOnlyWallet } from '../../class';
2020-06-09 16:08:18 +02:00
const currency = require('../../blue_modules/currency');
const BlueApp: AppStorage = require('../../BlueApp');
2018-10-28 11:13:28 +01:00
const styles = StyleSheet.create({
root: {
flex: 1,
},
});
2018-10-28 11:13:28 +01:00
export default class BuyBitcoin extends Component {
constructor(props) {
super(props);
const wallet = props.route.params.wallet;
2020-04-29 14:37:09 +02:00
if (!wallet) console.warn('wallet was not passed to buyBitcoin');
2018-10-28 11:13:28 +01:00
this.state = {
isLoading: true,
wallet,
address: '',
uri: '',
2018-10-28 11:13:28 +01:00
};
}
async componentDidMount() {
console.log('buyBitcoin - componentDidMount');
2018-10-28 11:13:28 +01:00
let preferredCurrency = await currency.getPreferredCurrency();
preferredCurrency = preferredCurrency.endPointKey;
/** @type {AbstractHDWallet|WatchOnlyWallet|LightningCustodianWallet} */
const wallet = this.state.wallet;
let address = '';
2018-10-28 11:13:28 +01:00
if (WatchOnlyWallet.type === wallet.type && !wallet.isHd()) {
// plain watchonly - just get the address
address = wallet.getAddress();
} else {
// otherwise, lets call widely-used getAddressAsync()
try {
address = await Promise.race([wallet.getAddressAsync(), BlueApp.sleep(2000)]);
} catch (_) {}
if (!address) {
// either sleep expired or getAddressAsync threw an exception
if (LightningCustodianWallet.type === wallet.type) {
// not much we can do, lets hope refill address was cached previously
address = wallet.getAddress() || '';
} else {
// plain hd wallet (either HD or watchonly-wrapped). trying next free address
address = wallet._getExternalAddressByIndex(wallet.getNextFreeAddressIndex());
}
}
2018-10-28 11:13:28 +01:00
}
const { safelloStateToken } = this.props.route.params;
let uri = 'https://bluewallet.io/buy-bitcoin-redirect.html?address=' + address;
if (safelloStateToken) {
uri += '&safelloStateToken=' + safelloStateToken;
}
if (preferredCurrency) {
uri += '&currency=' + preferredCurrency;
}
if (getSystemName() === 'Mac OS X') {
Linking.openURL(uri).finally(() => this.props.navigation.goBack(null));
} else {
this.setState({ uri, isLoading: false, address });
}
2018-10-28 11:13:28 +01:00
}
render() {
if (this.state.isLoading) {
return <BlueLoading />;
}
2019-05-12 22:50:08 +02:00
return (
<SafeBlueArea style={styles.root}>
2020-07-15 19:32:59 +02:00
<StatusBar barStyle="default" />
<WebView
source={{
uri: this.state.uri,
}}
/>
</SafeBlueArea>
2019-05-12 22:50:08 +02:00
);
2018-10-28 11:13:28 +01:00
}
}
BuyBitcoin.propTypes = {
2020-05-27 13:12:17 +02:00
route: PropTypes.shape({
name: PropTypes.string,
params: PropTypes.shape({
wallet: PropTypes.object.isRequired,
safelloStateToken: PropTypes.string,
2018-10-28 11:13:28 +01:00
}),
}),
navigation: PropTypes.shape({
goBack: PropTypes.func,
}),
2018-10-28 11:13:28 +01:00
};
2020-07-15 19:32:59 +02:00
BuyBitcoin.navigationOptions = ({ navigation }) => ({
...BlueNavigationStyle(navigation, true),
title: '',
headerLeft: null,
});