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

Другие вопросы по тегам