Uncaught ReferenceError: paypal не определен (в реакции)
Я следую инструкции по настройке PayPal, но проблема в том, что я продолжаю получать эту ошибку Uncaught ReferenceError: PayPal is not defined
, Вот ссылка на учебник, по которому я следую, чтобы настроить Paypal https://developers.braintreepayments.com/guides/paypal/client-side/javascript/v3.
Я пытался включить checkout.js
файл, но он продолжал давать мне ошибку. Затем я попытался включить Braintree.paypall
но это также продолжает давать мне ошибку. Может кто-нибудь сказать мне, что я делаю не так?
import React, { PropTypes, Component } from 'react';
import { browserHistory } from 'react-router';
import moment from 'moment';
import Gravatar from 'react-gravatar';
import { injectIntl, defineMessages } from 'react-intl';
import CSSModules from 'react-css-modules';
import styles from './index.sass';
import BrainTree from 'braintree-web';
const messages = defineMessages({
// some messages over here
});
@CSSModules(styles, { allowMultiple: true })
export class Payment extends Component {
state = {
paymentValue: 10,
paymentMethodNounce: '',
isPopUpShown: false,
};
componentWillMount() {
this.props.getClientTokenForPayment();
}
// certain code over here
componentWillReceiveProps(nextProps) {
const token = nextProps.user.clientToken;
if (token && token != null && token !== this.props.user.clientToken) {
debugger;
console.log(BrainTree.paypalCheckout.isSupported());
BrainTree.client.create({
authorization: token
}, function (clientErr, clientInstance) {
// Stop if there was a problem creating the client.
// This could happen if there is a network error or if the authorization
// is invalid.
if (clientErr) {
console.error('Error creating client:', clientErr);
return;
}
// Create a PayPal Checkout component.
BrainTree.paypalCheckout.create({
client: clientInstance
}, function (paypalCheckoutErr, paypalCheckoutInstance) {
// Stop if there was a problem creating PayPal Checkout.
// This could happen if there was a network error or if it's incorrectly
// configured.
if (paypalCheckoutErr) {
console.error('Error creating PayPal Checkout:', paypalCheckoutErr);
return;
}
// Set up PayPal with the checkout.js library
paypal.Button.render({ // THIS IS WHERE THE ERROR IS COMING
env: 'sandbox', // or 'sandbox'
payment: function () {
return paypalCheckoutInstance.createPayment({
// Your PayPal options here. For available options, see
// http://braintree.github.io/braintree-web/current/PayPalCheckout.html#createPayment
});
},
onAuthorize: function (data, actions) {
return paypalCheckoutInstance.tokenizePayment(data)
.then(function (payload) {
// Submit `payload.nonce` to your server.
});
},
onCancel: function (data) {
console.log('checkout.js payment cancelled', JSON.stringify(data, 0, 2));
},
onError: function (err) {
console.error('checkout.js error', err);
}
}, '#paypal-button').then(function () {
// The PayPal button will be rendered in an html element with the id
// `paypal-button`. This function will be called when the PayPal button
// is set up and ready to be used.
});
});
});
}
}
handleChange = (field, value) => {
this.setState({
[field]: value,
});
};
render() {
return (
<div id="paypal-button"></div>
);
}
}
Payment.propTypes = {};
Payment.defaultProps = {};
export default injectIntl(Payment);
Ошибка, которую я получаю в Braintree.paypal.button.render
,
1 ответ
Решение
Моя вина. paypal.Button.render является частью checkout.js. и так как я использую npm, я могу получить его здесь https://www.npmjs.com/package/paypal-checkout