Current File : /home/kelaby89/ap.cleaning/wp-content/plugins/woo-stripe-payment/assets/js/frontend/credit-card.js |
(function ($, wc_stripe) {
/**
* Credit card class.
*
* @constructor
*/
function CC() {
this.elementStatus = {};
wc_stripe.BaseGateway.call(this, wc_stripe_credit_card_params);
wc_stripe.CheckoutGateway.call(this);
this.message_container = this.params.notice_selector;
window.addEventListener('hashchange', this.hashchange.bind(this));
wc_stripe.credit_card = this;
this.confirmedSetupIntent = false;
this.has3DSecureParams();
this.handle_create_account_change();
$(document.body).on('change', '[name="stripe_cc_saved_method_key"]', this.maybe_initialize_installments.bind(this));
$(document.body).on('wc_stripe_saved_method_' + this.gateway_id, this.maybe_initialize_installments.bind(this));
}
var elementClasses = {
focus: 'focused',
empty: 'empty',
invalid: 'invalid'
}
CC.prototype = $.extend({}, wc_stripe.BaseGateway.prototype, wc_stripe.CheckoutGateway.prototype);
CC.prototype.mappings = {
cardNumber: '#stripe-card-number',
cardExpiry: '#stripe-exp',
cardCvc: '#stripe-cvv'
}
CC.prototype.handleActionMethod = 'confirmCardPayment';
CC.prototype.setupActionMethod = 'confirmCardSetup';
/**
*
*/
CC.prototype.initialize = function () {
$(document.body).on('click', '#place_order', this.place_order.bind(this));
$(document.body).on('change', '#createaccount', this.handle_create_account_change.bind(this));
this.setup_card();
if (this.has_gateway_data() && this.can_create_setup_intent()) {
this.create_setup_intent();
}
this.maybe_initialize_installments();
}
/**
*
*/
CC.prototype.setup_card = function () {
if (this.is_custom_form()) {
var options = $.extend(true, {
classes: elementClasses
}, this.params.cardOptions);
// create individual card sections
['cardNumber', 'cardExpiry', 'cardCvc'].forEach(function (type) {
this[type] = this.elements.create(type, $.extend(true, {}, options, this.params.customFieldOptions[type]));
this.elementStatus[type] = {};
this[type].on('change', this.on_card_element_change.bind(this));
}.bind(this));
this.cardNumber.on('change', this.card_number_change.bind(this));
this.cardNumber.on('change', this.on_input_change.bind(this));
this.cardExpiry.on('change', this.on_input_change.bind(this));
this.cardCvc.on('change', this.on_input_change.bind(this));
if (this.fields.required('billing_postcode') && '' !== this.fields.get('billing_postcode')) {
if ($('#stripe-postal-code').length > 0) {
$('#stripe-postal-code').val(this.fields.get('billing_postcode'));
this.validate_postal_field();
}
}
$(document.body).on('change', '#billing_postcode', function (e) {
var val = $('#billing_postcode').val();
$('#stripe-postal-code').val(val).trigger('keyup');
}.bind(this));
} else {
this.card = this.elements.create('card', $.extend(true, {}, {
value: {
postalCode: this.fields.get('billing_postcode', '')
},
hidePostalCode: this.fields.required('billing_postcode'),
iconStyle: 'default'
}, this.params.cardOptions));
$(document.body).on('change', '#billing_postcode', function (e) {
if (this.card) {
this.card.update({value: $('#billing_postcode').val()});
}
}.bind(this));
this.elementStatus.card = {};
this.card.on('change', this.on_card_element_change.bind(this));
}
// setup a timeout so CC element is always rendered.
setInterval(this.create_card_element.bind(this), 2000);
}
CC.prototype.validate_postal_field = function () {
if ($('#billing_postcode').length && $('#stripe-postal-code').length) {
// validate postal code
if (this.params.postal_regex[this.fields.get('billing_country')]) {
var regex = this.params.postal_regex[this.fields.get('billing_country')],
postal = $('#stripe-postal-code').val(),
regExp = new RegExp(regex, "i");
if (postal !== '') {
if (regExp.exec(postal) !== null) {
$('#stripe-postal-code').addClass('StripeElement--complete').removeClass('invalid');
} else {
$('#stripe-postal-code').removeClass('StripeElement--complete').addClass('invalid');
}
} else {
$('#stripe-postal-code').removeClass('StripeElement--complete').removeClass('invalid');
}
} else {
if ($('#stripe-postal-code').val() != 0) {
$('#stripe-postal-code').addClass('StripeElement--complete');
} else {
$('#stripe-postal-code').removeClass('StripeElement--complete');
}
}
} else if ($('#stripe-postal-code').length) {
if ($('#stripe-postal-code').val() != '') {
$('#stripe-postal-code').addClass('StripeElement--complete');
} else {
$('#stripe-postal-code').removeClass('StripeElement--complete');
}
}
}
/**
*
*/
CC.prototype.create_card_element = function () {
if (this.is_custom_form()) {
if ($('#wc-stripe-cc-custom-form').length && $('#wc-stripe-cc-custom-form').find('iframe').length == 0) {
if ($(this.mappings.cardNumber).length) {
this.cardNumber.mount(this.mappings.cardNumber);
$(this.mappings.cardNumber).prepend(this.params.html.card_brand);
}
if ($(this.mappings.cardExpiry).length) {
this.cardExpiry.mount(this.mappings.cardExpiry);
}
if ($(this.mappings.cardCvc).length) {
this.cardCvc.mount(this.mappings.cardCvc);
}
if ($('#stripe-postal-code').length) {
$('#stripe-postal-code, .postalCode').on('focus', function (e) {
$('#stripe-postal-code').addClass('focused');
}.bind(this));
$('#stripe-postal-code, .postalCode').on('blur', function (e) {
$('#stripe-postal-code').removeClass('focused').trigger('keyup');
}.bind(this));
$('#stripe-postal-code').on('keyup', function (e) {
if ($('#stripe-postal-code').val() == 0) {
$('#stripe-postal-code').addClass('empty');
} else {
$('#stripe-postal-code').removeClass('empty');
}
}.bind(this));
$('#stripe-postal-code').on('change', this.validate_postal_field.bind(this));
$('#stripe-postal-code').trigger('change');
}
}
} else {
if ($('#wc-stripe-card-element').length) {
if ($('#wc-stripe-card-element').find('iframe').length == 0) {
this.card.unmount();
this.card.mount('#wc-stripe-card-element');
this.card.update({
value: {
postalCode: this.fields.get('billing_postcode', '')
},
hidePostalCode: this.fields.required('billing_postcode')
});
}
}
}
if ($(this.container).outerWidth(true) < 450) {
$(this.container).addClass('stripe-small-container');
} else {
$(this.container).removeClass('stripe-small-container');
}
}
CC.prototype.place_order = function (e) {
if (this.is_gateway_selected()) {
this.fields.syncCheckoutFieldsWithDOM();
if (this.can_create_setup_intent() && !this.is_saved_method_selected() && this.checkout_fields_valid()) {
e.preventDefault();
if (this.confirmedSetupIntent) {
return this.on_setup_intent_received(this.confirmedSetupIntent);
}
this.stripe.confirmCardSetup(this.client_secret, {
payment_method: {
card: this.is_custom_form() ? this.cardNumber : this.card,
billing_details: (function () {
if (this.is_current_page('checkout')) {
return this.get_billing_details();
}
return $.extend({}, this.is_custom_form() ? {address: {postal_code: $('#stripe-postal-code').val()}} : {});
}.bind(this)())
}
}).then(function (result) {
if (result.error) {
this.submit_card_error(result.error);
return;
}
this.confirmedSetupIntent = result.setupIntent;
this.on_setup_intent_received(result.setupIntent);
}.bind(this))
} else {
if (!this.payment_token_received && !this.is_saved_method_selected()) {
e.preventDefault();
if (this.checkout_fields_valid()) {
this.elements.submit().then(function (response) {
this.stripe.createPaymentMethod(this.get_create_payment_method_params()).then(function (result) {
if (result.error) {
return this.submit_card_error(result.error);
}
if (this.is_current_page('order_pay')) {
this.set_nonce(result.paymentMethod.id);
this.process_order_pay();
} else {
this.on_token_received(result.paymentMethod);
}
}.bind(this))
}.bind(this));
}
}
}
}
}
/**
* @since 3.1.8 - added to ensure 3rd party plugin's can't stop the tokenization process
* if e.preventDefault is called on place_order
* @returns {boolean}
*/
CC.prototype.checkout_place_order = function () {
if (!this.is_saved_method_selected() && !this.payment_token_received) {
this.place_order.apply(this, arguments);
return false;
}
return wc_stripe.CheckoutGateway.prototype.checkout_place_order.apply(this, arguments);
}
/**
*
*/
CC.prototype.on_token_received = function (paymentMethod) {
this.payment_token_received = true;
if (paymentMethod.hasOwnProperty('id')) {
this.set_nonce(paymentMethod.id);
} else {
this.set_nonce(paymentMethod);
}
this.get_form().trigger('submit');
}
/**
*
*/
CC.prototype.on_setup_intent_received = function (setup_intent) {
this.payment_token_received = true;
this.set_nonce(setup_intent.payment_method);
this.set_intent(setup_intent.id);
this.get_form().trigger('submit');
}
/**
*
*/
CC.prototype.updated_checkout = function (e, data) {
this.create_card_element();
this.handle_create_account_change();
if (this.has_gateway_data() && this.can_create_setup_intent() && !this.client_secret) {
this.create_setup_intent();
}
}
/**
*
*/
CC.prototype.update_checkout = function () {
this.clear_card_elements();
}
CC.prototype.show_payment_button = function () {
wc_stripe.CheckoutGateway.prototype.show_place_order.apply(this, arguments);
}
/**
* [Leave empty so that the place order button is not hidden]
* @return {[type]} [description]
*/
CC.prototype.hide_place_order = function () {
}
/**
* Returns true if a custom form is being used.
* @return {Boolean} [description]
*/
CC.prototype.is_custom_form = function () {
return this.params.custom_form === "1";
}
CC.prototype.get_postal_code = function () {
if (this.is_custom_form()) {
if ($('#stripe-postal-code').length > 0) {
return $('#stripe-postal-code').val();
}
}
return this.fields.get(this.get_billing_prefix() + '_postcode', null);
}
CC.prototype.card_number_change = function (data) {
if (data.brand === "unknown") {
$('#wc-stripe-card').removeClass('active');
} else {
$('#wc-stripe-card').addClass('active');
}
$('#wc-stripe-card').attr('src', this.params.cards[data.brand]);
}
CC.prototype.on_input_change = function (event) {
if (event.complete) {
var $elements = $('#wc-stripe-cc-custom-form').find('.StripeElement, #stripe-postal-code');
var order = [];
$elements.each(function (idx, el) {
order.push('#' + $(el).attr('id'));
}.bind(this));
var selector = this.mappings[event.elementType];
var idx = order.indexOf(selector);
if (typeof order[idx + 1] !== 'undefined') {
if (order[idx + 1] === '#stripe-postal-code') {
document.getElementById('stripe-postal-code').focus();
} else {
for (var k in this.mappings) {
if (this.mappings[k] === order[idx + 1]) {
this[k].focus();
}
}
}
}
}
}
CC.prototype.clear_card_elements = function () {
var elements = ['cardNumber', 'cardExpiry', 'cardCvc'];
for (var i = 0; i < elements.length; i++) {
if (this[elements[i]]) {
this[elements[i]].clear();
}
}
}
CC.prototype.checkout_error = function () {
if (this.is_gateway_selected()) {
this.payment_token_received = false;
}
wc_stripe.CheckoutGateway.prototype.checkout_error.call(this);
}
CC.prototype.get_billing_details = function () {
var details = wc_stripe.BaseGateway.prototype.get_billing_details.call(this);
details.address.postal_code = this.get_postal_code();
return details;
}
CC.prototype.can_create_setup_intent = function () {
return this.is_add_payment_method_page() || this.is_change_payment_method() ||
(this.is_current_page('checkout') && this.cart_contains_subscription() && this.has_gateway_data() && this.get_total_price_cents() == 0) ||
(this.is_current_page(['checkout', 'product']) && typeof wc_stripe_preorder_exists !== 'undefined') ||
(this.is_current_page('order_pay') && 'pre_order' in this.get_gateway_data() && this.get_gateway_data().pre_order === true) ||
(this.is_current_page('product') && this.get_total_price_cents() == 0);
}
CC.prototype.submit_card_error = function (error) {
if (this.params.notice_location === 'bcf') {
$('.wc-stripe-card-notice').remove();
$('.wc-stripe_cc-new-method-container').append('<div class="wc-stripe-card-notice"></div>');
}
wc_stripe.BaseGateway.prototype.submit_error.call(this, error, true);
}
CC.prototype.container_styles = function () {
wc_stripe.CheckoutGateway.prototype.container_styles.apply(this, arguments);
if (this.is_custom_form()) {
$(this.container).find('.payment_box').addClass('custom-form__' + this.params.custom_form_name);
}
}
CC.prototype.checkout_fields_valid = function () {
var valid = this.is_valid_checkout();
if (!valid) {
this.submit_error(this.params.messages.terms);
}
return valid;
}
CC.prototype.is_installments_available = function () {
var data = this.get_gateway_data();
if (data) {
return !!data.installments.enabled
}
return false;
}
CC.prototype.update_element_status = function (event) {
this.elementStatus[event.elementType] = event;
}
CC.prototype.is_card_form_complete = function () {
return Object.keys(this.elementStatus).filter(function (key) {
return !!this.elementStatus[key].complete;
}.bind(this)).length == Object.keys(this.elementStatus).length;
}
CC.prototype.on_card_element_change = function (event) {
this.update_element_status(event);
if (this.is_current_page(['checkout', 'order_pay']) && this.is_card_form_complete() && this.is_installments_available()) {
this.initialize_installments();
}
}
CC.prototype.initialize_installments = function (paymentMethodId) {
if (this.installmentTimeoutId) {
clearTimeout(this.installmentTimeoutId);
}
this.installmentTimeoutId = setTimeout(function (paymentMethodId) {
if (paymentMethodId) {
this.show_installment_loader();
this.fetch_installment_plans(paymentMethodId).finally(function () {
this.hide_installment_loader();
}.bind(this));
} else {
this.elements.submit().then(function () {
this.stripe.createPaymentMethod(this.get_create_payment_method_params()).then(function (result) {
if (!result.error) {
this.show_installment_loader();
this.fetch_installment_plans(result.paymentMethod.id).finally(function () {
this.hide_installment_loader();
}.bind(this));
} else {
this.hide_installment_loader();
}
}.bind(this)).catch(this.hide_installment_loader.bind(this));
}.bind(this));
}
}.bind(this, paymentMethodId), 250);
}
CC.prototype.fetch_installment_plans = function (paymentMethodId) {
return this.fetch_payment_intent(paymentMethodId).then(function (response) {
if (response.installments_html) {
$('.wc-stripe-installment-container').replaceWith(response.installments_html);
}
}.bind(this)).catch(function (response) {
return this.submit_card_error(response);
}.bind(this)).finally(function () {
}.bind(this));
}
CC.prototype.fetch_payment_intent = function (payment_method_id) {
return new Promise(function (resolve, reject) {
var url = this.params.routes.create_payment_intent;
var order_pay = false;
if (this.is_current_page('order_pay')) {
var url = this.params.routes.order_create_payment_intent;
order_pay = true;
}
$.ajax({
url: url,
method: 'POST',
dataType: 'json',
data: !order_pay ? $.extend({}, this.serialize_fields(), {
payment_method_id: payment_method_id,
payment_method: this.gateway_id,
page_id: this.get_page()
}) : {
payment_method_id: payment_method_id,
payment_method: this.gateway_id,
order_id: this.get_gateway_data().order.id,
order_key: this.get_gateway_data().order.key
},
beforeSend: this.ajax_before_send.bind(this)
}).done(function (response) {
if (response.code) {
reject(response);
} else {
resolve(response);
}
}.bind(this)).fail(function (xhr) {
reject()
}.bind(this))
}.bind(this))
}
CC.prototype.show_installment_loader = function () {
$('.wc-stripe-installment-options').addClass('loading-installments');
var $option = $('[name="_stripe_installment_plan"] option:selected').eq(0);
$option.text(this.params.installments.loading);
$('.wc-stripe-installment-loader').show();
}
CC.prototype.hide_installment_loader = function (has_error) {
$('.wc-stripe-installment-options').removeClass('loading-installments');
$('.wc-stripe-installment-loader').hide();
}
CC.prototype.maybe_initialize_installments = function () {
if (this.is_installments_available() && this.is_saved_method_selected()) {
this.initialize_installments(this.get_selected_payment_method());
}
}
CC.prototype.get_element_options = function () {
return this.params.elementOptions;
}
CC.prototype.get_create_payment_method_params = function () {
return {
type: 'card',
card: this.is_custom_form() ? this.cardNumber : this.card,
billing_details: this.get_billing_details()
}
}
new CC();
}(jQuery, window.wc_stripe))