В настоящее время я прохожу учебное пособие по повышению квалификации «Курс Essential Web Developer» (в настоящее время на уроке 162), где я пытаюсь подключить Stripe с оплатой за премиум-членство.Это руководство работает со старыми версиями гемов, библиотек и т. Д., Поэтому я говорю вам об этом.
Проблема в том, что после того, как Stripe отправит мне токен покупателя.Он не будет храниться в моей базе данных и не будет входить в членство.Вместо этого моя кнопка отправки останется отключенной и отображает строку «Обработка».
На консоли разработчика отображается сообщение: «Uncaught TypeError: Невозможно прочитать свойство« отправить »из неопределенного» сообщения.
Чтомне нужно изменить?Имеет этоделать с моим методом save_with_subscription?
attr_accessor :stripe_card_token
def save_with_subscription
if valid?
customer = Stripe::Customer.create(description: email, plan: plan_id, card: stripe_card_token)
self.stripe_customer_token = customer.id
save!
end
Файл js для него:
/* global $, Stripe */
//Document ready.
$(document).on('turbolinks:load', function(){
var theForm = $('#pro_form');
var submitBtn = $('#form-signup-btn');
//Set Stripe public key.
Stripe.setPublishableKey( $('meta[name="stripe-key"]').attr('content') );
//When user clicks form submit btn,
submitBtn.click(function(event){
//prevent default submission behavior.
event.preventDefault();
submitBtn.val("Processing").prop('disabled', true);
//Collect the credit card fields.
var ccNum = $('#card_number').val(),
cvcNum = $('#card_code').val(),
expMonth = $('#card_month').val(),
expYear = $('#card_year').val();
//Use Stripe JS library to check for card errors.
var error = false;
//Validate card number.
if(!Stripe.card.validateCardNumber(ccNum)) {
error = true;
alert('The credit card number appears to be invalid');
}
//Validate CVC number.
if(!Stripe.card.validateCVC(cvcNum)) {
error = true;
alert('The CVC number appears to be invalid');
}
//Validate expiration date.
if(!Stripe.card.validateExpiry(expMonth, expYear)) {
error = true;
alert('The expiration date appears to be invalid');
}
if (error) {
//If there are card errors, don't send to Stripe.
submitBtn.prop('disabled', false).val("Sign Up");
} else {
//Send the card info to Stripe.
Stripe.createToken({
number: ccNum,
cvc: cvcNum,
exp_month: expMonth,
exp_year: expYear
}, stripeResponseHandler);
}
return false;
});
//Stripe will return a card token.
function stripeResponseHandler(status, response) {
//Get the token from the response.
var token = response.id;
//Inject the card token in a hidden field.
theForm.append( $('<input type="hidden" name="user[stripe_card_token]">').val(token) );
//Submit form to our Rails app.
theForm.get(0).submit();
}
});
Весь мой код можно найти на https://github.com/JakkSwords/upskill_saas_tutorial/tree/user_memberships