forked from tommymarshall/Stripe-Donation-Form
-
Notifications
You must be signed in to change notification settings - Fork 0
/
script.js
116 lines (105 loc) · 2.77 KB
/
script.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
/*
Script for Simple Donation Form
Handles validation and form processing
*/
$(function() {
var $form = $('.donation-form');
var $otherAmount = $form.find('.other-amount');
var $amount = $form.find('.amount');
var outputError = function(error) {
$('.messages')
.html('<p>' + error + '</p>')
.addClass('active');
$('.submit-button')
.removeProp('disabled')
.val('Submit Donation');
};
var stripeResponseHandler = function(status, response) {
if (response.error) {
outputError(response.error.message);
} else {
var token = response['id'];
$form.append('<input type="hidden" name="stripeToken" value="' + token + '">');
$form.get(0).submit();
}
};
var disableinput = function(amount) {
$amount
.val(amount)
.blur()
.prop('disabled');
};
var enableinput = function() {
$amount
.removeProp('disabled')
.focus();
};
$('.donation-form').on('submit', function(event) {
// Disable processing button to prevent multiple submits
$('.submit-button')
.prop('disabled', true)
.val('Processing...');
// Very simple validation
if ( $('.first-name').val() === '' ) {
outputError('First name is required');
$('.first-name').focus();
return false;
}
if ( $('.last-name').val() === '' ) {
outputError('Last name is required');
$('.last-name').focus();
return false;
}
if ( $('.email').val() === '' ) {
outputError('Email is required');
$('.email').focus();
return false;
}
if ( $('.phone').val() === '' ) {
outputError('Phone is required');
$('.phone').focus();
return false;
}
if ( $('.address').val() === '' ) {
outputError('Address is required');
$('.address').focus();
return false;
}
if ( $('.city').val() === '' ) {
outputError('City is required');
$('.city').focus();
return false;
}
if ( $('.zip').val() === '' ) {
outputError('Zip code is required');
$('.zip').focus();
return false;
}
if ( $('.amount').val() === '' ) {
outputError('Please make a donation amount');
$('.other-amount').trigger('click');
return false;
}
// Create Stripe token, check if CC information correct
Stripe.createToken({
name : $('.first-name').val() + ' ' + $('.last-name').val(),
number : $('.card-number').val(),
cvc : $('.card-cvc').val(),
exp_month : $('.card-expiry-month').val(),
exp_year : $('.card-expiry-year').val()
}, stripeResponseHandler);
return false;
});
$('.form-amount label').on('click', function() {
var $label = $(this);
$label.addClass('active').parent().children('label').removeClass('active');
if ( $label.index() === 6 ) {
enableinput();
} else {
disableinput($label.find('.set-amount').val());
}
});
$amount.on('change', function() {
$otherAmount.val($(this).val());
});
});