Я не понимаю, почему мой WebView ничего не отображает.
Я попытался добавить flex: 1 , как я видел по некоторым вопросам о Stackoverflow, но он ничего не отображал.
Это может быть связано с этой ошибкой:
Возможен необработанный отказ от обещания (id: 0):
Ошибка: невозможно открыть URL
Я предполагаю, что источник моего WebView неверен.
Где моя ошибка?
import React, { Component } from 'react';
import { WebView, Platform, View, ViewPropTypes } from 'react-native';
import { PropTypes } from 'prop-types';
class StripeCheckout extends Component {
onPaymentSuccess = (token) => {
// Backend
}
onClose = () => {
//Go To OtherScreen
}
render() {
const {
publicKey,
amount,
allowRememberMe,
currency,
description,
imageUrl,
storeName,
prepopulatedEmail,
style,
onPaymentSuccess,
onClose
} = this.props;
const jsCode = `(function() {
var originalPostMessage = window.postMessage;
var patchedPostMessage = function(message, targetOrigin, transfer) {
originalPostMessage(message, targetOrigin, transfer);
};
patchedPostMessage.toString = function() {
return String(Object.hasOwnProperty).replace('hasOwnProperty', 'postMessage');
};
window.postMessage = patchedPostMessage;
})();`;
return (
<WebView
javaScriptEnabled={true}
scrollEnabled={false}
bounces={false}
injectedJavaScript={jsCode}
source={{ html: `<script src="https://checkout.stripe.com/checkout.js"></script>
<script>
var handler = StripeCheckout.configure({
key: '${publicKey}',
image: '${imageUrl}',
locale: 'auto',
token: function(token) {
window.postMessage(token.id, token.id);
},
});
window.onload = function() {
handler.open({
image: '${imageUrl}',
name: '${storeName}',
description: '${description}',
amount: ${amount},
currency: '${currency}',
allowRememberMe: ${allowRememberMe},
email: '${prepopulatedEmail}',
closed: function() {
window.postMessage("WINDOW_CLOSED", "*");
}
});
};
</script>`, baseUrl: ''}}
onMessage={event => event.nativeEvent.data === 'WINDOW_CLOSED' ? onClose() : onPaymentSuccess(event.nativeEvent.data)}
style={[{ flex: 1 }, style]}
scalesPageToFit={Platform.OS === 'android'}
/>
);
}
}
StripeCheckout.propTypes = {
publicKey: PropTypes.string.isRequired,
amount: PropTypes.number.isRequired,
imageUrl: PropTypes.string.isRequired,
storeName: PropTypes.string.isRequired,
description: PropTypes.string.isRequired,
allowRememberMe: PropTypes.bool.isRequired,
onPaymentSuccess: PropTypes.func.isRequired,
onClose: PropTypes.func.isRequired,
currency: PropTypes.string,
prepopulatedEmail: PropTypes.string,
style: ViewPropTypes.style
};
StripeCheckout.defaultProps = {
prepopulatedEmail: '',
currency: 'USD',
};
export default StripeCheckout;
Надеюсь, кто-то может помочь 101
С уважением