Files
torebki-fabiola.pl/wp-content/plugins/przelewy24-2/assets/js/payment.js
2026-03-05 13:07:40 +01:00

635 lines
24 KiB
JavaScript

function onResize() {
if (jQuery(window).width() <= 640) {
jQuery('.payMethodList').addClass('mobile');
} else {
jQuery('.payMethodList').removeClass('mobile');
}
}
onResize();
jQuery(window).resize(function () {
onResize();
});
function setP24method(method) {
method = parseInt(method);
jQuery('input[name=p24_method]').val(method > 0 ? method : "");
}
function choosePaymentMethod() {
var checkedPayment = false;
var setP24channel = function (paymentIdRaw) {
var paymentId = Number(paymentIdRaw);
if (266 === paymentId) {
jQuery('input[name=p24_channel]').val('2048');
} else {
jQuery('input[name=p24_channel]').val('');
}
};
jQuery('.bank-box').click(function () {
jQuery('.bank-box').removeClass('selected').addClass('inactive');
jQuery(this).addClass('selected').removeClass('inactive');
jQuery('.extra-promoted-box').removeClass('selected').addClass('inactive');
if (jQuery(this).parents('.payMethodList').hasClass('checkoutView')) {
var inputs = jQuery(this).parents('.checkoutView').find('input[type="checkbox"]');
jQuery(inputs).removeAttr('checked');
jQuery(inputs).prop('checked', false);
var input = jQuery(this).find('input[type="checkbox"]');
jQuery(input).attr('checked', 'checked');
jQuery(input).prop('checked', true);
checkedPayment = true;
jQuery('#payment_method_przelewy24_payment').trigger('change');
}
setP24method(jQuery(this).attr('data-id'));
setP24channel(jQuery(this).data('id'));
setP24recurringId(jQuery(this).attr('data-cc'));
});
jQuery('.bank-item input').change(function () {
setP24method(jQuery(this).closest('.bank-item').attr('data-id'));
setP24recurringId(jQuery(this).attr('data-cc'));
});
jQuery('#payment_method_przelewy24_payment').trigger('change');
jQuery('input[name=payment_method_id]:checked:first').closest('.input-box.bank-item').each(function () {
setP24method(jQuery(this).attr('data-id'));
});
jQuery(".box-wrapper").click(function () {
const $thisElement = jQuery(this);
if($thisElement.hasClass('selected')){
jQuery('input[name=p24_channel]').val('');
}else{
jQuery('.bank-box').removeClass('selected').addClass('inactive');
jQuery("#p24-now-box").addClass('selected').removeClass('inactive');
jQuery('input[name=p24_channel]').val('2048');
setP24method(jQuery(this).data('id'));
setP24channel(jQuery(this).data('id'));
setP24recurringId('');
}
});
}
jQuery('<style>.moreStuff.translated:before{content:"' + p24_payment_php_vars.payments_msg4js + '"} </style>').appendTo('head');
jQuery('.moreStuff').toggleClass('translated');
var sessionId = false;
var sign = false;
function requestJsAjaxCard() {
var subFunction = function (data, $form) {
data['action'] = 'cardPay';
jQuery.ajax(jQuery('#p24_ajax_url').val(), {
method: 'POST', type: 'POST',
data: data,
success: function (resultJson) {
let result = jQuery.parseJSON(resultJson);
if (result.success && result.redirect && result.redirectUrl) {
setTimeout(function () {
window.location.href = result.redirectUrl;
}, 1000);
} else if (result.success) {
setTimeout(function () {
window.location.href = jQuery('[name=p24_url_return]').val();
}, 1000);
} else {
hidePayJsPopup();
}
},
done: function () {
$form.find('button').removeAttr('disabled');
}
});
}
return p24CardPayment(subFunction);
}
function p24CardPayment(subFunction) {
var getForm = function () {
var formHtml = '<form id="przelewy24RPCCardForm"><p id="przelewy24RPCCardFormDescription" class="italic"></p>'+
'<p><label for="P24_cardHolder"></label><input name="P24_cardHolder" id="P24_cardHolder"/></p>'+
'<p><label for="P24_cardNumber"></label><input name="P24_cardNumber" id="P24_cardNumber"/></p>'+
'<p><label for="P24_cardCVV"></label><input name="P24_cardCVV" id="P24_cardCVV" size="3" maxlength="4"/></p>'+
'<p><label for="P24_expMonth"></label><input name="P24_expMonth" id="P24_expMonth" size="2" maxlength="2" placeholder="mm"/>'+
'/<input name="P24_expYear" id="P24_expYear" size="2" maxlength="2" placeholder="yy"/></p>'+
'<p><input type="checkbox" id="P24_registerCard" name="P24_registerCard"/><label for="P24_registerCard" id="register-text"></label></p>'+
'<p><input type="checkbox" id="P24_acceptTerms" name="P24_acceptTerms"/><label for="P24_acceptTerms"></label></p>'+
'<button type="submit" ></button></form>';
var dict = JSON.parse(jQuery('#p24_dictionary').val());
var $formHtml = jQuery(formHtml);
var $acceptTermsLabel = $formHtml.find('label[for=P24_acceptTerms]');
$acceptTermsLabel.text(dict['acceptTermsLabelPrefix'] + ' ');
jQuery('<a>').attr('href', 'http://www.przelewy24.pl/regulamin.htm').attr('target','__blank').text(dict['acceptTermsLinkLabel']).appendTo($acceptTermsLabel);
jQuery('<span>.</span>').appendTo($acceptTermsLabel);
$formHtml.find('label[for=P24_registerCard]').text(dict['registerCardLabel']);
$formHtml.find('label[for=P24_cardHolder]').text(dict['cardHolderLabel']);
$formHtml.find('label[for=P24_cardNumber]').text(dict['cardNumberLabel']);
$formHtml.find('label[for=P24_cardCVV]').text(dict['cvvLabel']);
$formHtml.find('label[for=P24_expMonth]').text(dict['expDateLabel']);
$formHtml.find('#przelewy24RPCCardFormDescription').text(dict['description']);
$formHtml.find('button').text(dict['payButtonCaption']);
return $formHtml;
};
var $formArea = jQuery('#P24FormArea');
$formArea.html("");
var $formContainer = jQuery("<div></div>");
$formContainer
.attr('id', 'P24FormContainer')
.appendTo($formArea)
.parent().slideDown()
;
$formContainer.append(getForm());
var armForm = function() {
var $cardHolder = $formContainer.find('#P24_cardHolder');
var $cardNumber = $formContainer.find('#P24_cardNumber');
var $cardCVV = $formContainer.find('#P24_cardCVV');
var $cardMonth = $formContainer.find('#P24_expMonth');
var $cardYear = $formContainer.find('#P24_expYear');
var $acceptTerms = $formContainer.find('#P24_acceptTerms');
if (!$formArea.data('terms')) {
$acceptTerms.prop('checked', true).parent().hide();
}
var setButton = function() {
var $button = $formContainer.find('button');
if ($cardHolder.val() && $cardNumber.val() && $cardCVV.val() && $cardMonth.val() && $cardYear.val() && $acceptTerms.prop('checked')) {
$button.show();
} else {
$button.hide();
}
};
$cardHolder.on('change', setButton);
$cardNumber.on('change', setButton);
$cardCVV.on('change', setButton);
$cardMonth.on('change', setButton);
$cardYear.on('change', setButton);
$acceptTerms.on('change', setButton);
setButton();
};
armForm();
var $form = jQuery('#przelewy24RPCCardForm');
$form.on('submit', function (e) {
e.preventDefault();
if ($form.find('button').attr('disabled')) {
return;
}
$form.find('button').attr('disabled', 'disabled');
var data = {
p24sessionId: jQuery('[name=p24_session_id]').val(),
orderId: jQuery('#p24_woo_order_id').val(),
hashedOrderId: jQuery('#p24_woo_hashed_order_id').val(),
cardNumber: jQuery('#P24_cardNumber').val(),
cvv: jQuery('#P24_cardCVV').val(),
cardMonth: jQuery('#P24_expMonth').val(),
cardYear: jQuery('#P24_expYear').val(),
clientName: jQuery('#P24_cardHolder').val()
};
subFunction(data, $form);
})
}
function showPayJsPopup() {
$termsAcceptanceCheckbox = jQuery('[name=p24_regulation_accept][type=checkbox]');
if (0 !== $termsAcceptanceCheckbox.length && !$termsAcceptanceCheckbox.prop('checked')) {
jQuery('#place_order').click();
return;
}
if (jQuery('#P24FormAreaHolder:visible').length == 0) {
setP24method("");
jQuery('#P24FormAreaHolder').appendTo('body');
jQuery('#proceedPaymentLink').closest('a').fadeOut();
jQuery('#P24FormAreaHolder').fadeIn();
if (typeof P24_Transaction != 'object') {
requestJsAjaxCard();
}
}
}
function hidePayJsPopup() {
jQuery('#P24FormAreaHolder').fadeOut();
jQuery('#proceedPaymentLink:not(:visible)').closest('a').fadeIn();
}
function payInShopSuccess(orderId, oneclickOrderId) {
jQuery.ajax(jQuery('#p24_ajax_url').val(), {
method: 'POST', type: 'POST',
data: {
action: 'rememberOrderId',
sessionId: jQuery('[name=p24_session_id]').val(),
orderId: orderId,
oneclickOrderId: oneclickOrderId,
sign: jQuery('[name=p24_sign]').val()
}
});
window.setTimeout(function () {
window.location = jQuery('[name=p24_url_return]').val();
}, 1000);
}
function setP24recurringId(id,name) {
id = parseInt(id);
if (name == undefined) name = jQuery('[data-cc='+id+'] .bank-name').text().trim() + ' - ' + jQuery('[data-cc='+id+'] .bank-logo span').text().trim();
jQuery('input[name=p24_cc]').val( id > 0 ? id : "" );
if (id > 0) setP24method(0);
}
function p24_processPayment() {
console.log('processPayment');
var ccid = parseInt(jQuery('input[name=p24_cc]').val());
var fullCardData = jQuery('#p24-combined-cart-data').data('combined');
var $additionalOrderData = jQuery('#p24-additional-order-data');
var url = $additionalOrderData.data('ajax-url');
var payByCard = function (data) {
data['action'] = 'cardPay';
data['orderId'] = $additionalOrderData.data('order-id');
data['hashedOrderId'] = $additionalOrderData.data('hashed-order-id');
data['p24sessionId'] = jQuery('input[name=p24_session_id]').val(),
jQuery.ajax({
url: url,
method: 'POST', type: 'POST',
data: data,
success: function (resultJson) {
let result = jQuery.parseJSON(resultJson);
if (result.success && result.redirect && result.redirectUrl) {
setTimeout(function () {
window.location.href = result.redirectUrl;
}, 1000);
} else if (result.success) {
setTimeout(function () {
window.location.href = jQuery('[name=p24_url_return]').val();
}, 1000);
} else {
payInShopFailure();
}
}
});
}
if (fullCardData) {
payByCard(fullCardData);
} else if (isNaN(ccid) || ccid == 0) {
var myform = document.getElementById("przelewy_payment_form");
var fd = new FormData(myform );
jQuery("#przelewy_payment_form :input").prop("disabled", true);
jQuery.ajax({
url: jQuery("#przelewy_payment_form input[name=p24_api_url]").val(),
data: fd,
cache: false,
processData: false,
contentType: false,
type: 'POST',
success: function(data) {
window.location.replace(data.url);
},
error: function () {
alert('internal error');
}
});
} else if (ccid > 0) { // recuring
var ra = jQuery('#przelewy_payment_form [name=p24_regulation_accept]').prop('checked') ? '1' : '';
jQuery('#przelewy24FormRecuring [name=p24_regulation_accept]').val(ra);
jQuery('#przelewy24FormRecuring').submit();
}
return false;
}
function removecc(ccid) {
jQuery('form#cardrm input[name=cardrm]').val(ccid).closest('form').submit();
}
// payinshop
function payInShopFailure() {
//wyświetlamy odpowiedź
jQuery('#P24FormArea').html("<span class='info'>" + p24_payment_php_vars.error_msg4js + "</span>"); //'Wystąpił błąd. Spróbuj ponownie lub wybierz inną metodę płatności.'
P24_Transaction = undefined;
window.location = jQuery('[name=p24_url_return]').val();
}
var selector = '#P24_registerCard';
var waitForEl = function(selector, callback) {
if (jQuery(selector).length) {
jQuery('#P24_registerCard').prop('checked', (p24_payment_php_vars.forget_card == 1 ? false : true));
if (!parseInt(p24_payment_php_vars.show_save_card)) {
jQuery(jQuery(selector).parents('p')).hide();
}
jQuery(selector).on('change', function () {
var payload = jQuery(this).prop('checked') ? 0 : 1;
var url = jQuery('#p24-link-to-my-account').data('link');
jQuery.ajax({
method: 'POST',
url: url,
data: {
act: 'cc_forget',
cc_forget: payload
}
});
})
} else {
setTimeout(function() {
waitForEl(selector, callback);
}, 100);
}
};
waitForEl(selector, function() {
});
var p24TryUseCards = function() {
var tryArmCheckout = function() {
var subFunction = function (data, $form) {
jQuery('#p24-card-combined-field').val(JSON.stringify(data));
var $checkoutForm = jQuery('form.woocommerce-checkout');
$checkoutForm.submit();
};
var tryUseCardsInternal = function(id) {
/* There is a lot of magic in WooCommerce JavaScript. */
var $radioBox = jQuery('#payment_method_przelewy24_extra_' + id);
if ($radioBox.length) {
$radioBox.prop('checked', false);
jQuery("body").on("change", ".wc_payment_methods input[name='payment_method']", function () {
var $elm = jQuery(this);
if ($elm.prop('checked') && $elm.val() === 'przelewy24_extra_' + id) {
var $holder = jQuery('#P24FormAreaHolder');
var hasModal = jQuery('#P24FormAreaHolder').length;
if (hasModal) {
$holder.on('click', function (e) {
if (jQuery(e.target).attr('id') !== $holder.attr('id')) {
/* Nothing to do. */
return;
}
$holder.hide();
$elm.prop('checked', false);
});
$holder.appendTo('body').fadeIn();
$holder.find('button').removeAttr('disabled');
p24CardPayment(subFunction)
}
}
});
}
}
tryUseCardsInternal(218);
tryUseCardsInternal(241);
tryUseCardsInternal(242);
};
tryArmCheckout();
};
var tryArmBlikBox = function() {
var $additional_order_data = jQuery('#p24-additional-order-data')
var $termsAcceptanceCheckbox = jQuery('[name="p24_regulation_accept"]');
var url = jQuery('#p24_ajax_url').val();
if (!url) {
url = $additional_order_data.data('ajax-url');
}
var blikModalError = function() {
var $modal = jQuery('#p24-blik-modal');
$modal.removeClass('loading');
$modal.find('.error').show();
};
var executePaymentByBlikCode = function(trnData, blikCode, onError) {
jQuery.ajax({
url: url,
method: 'POST', type: 'POST',
dataType: 'json',
data: {
'action': 'executePaymentByBlikCode',
'token': trnData.token,
'blikCode': blikCode
}
}).success(function (response) {
if (response.success) {
setTimeout(function () {
location = jQuery('#przelewy_payment_form input[name=p24_url_return]').val();
}, 3000 /* Few seconds to accept transaction. */ );
} else {
onError();
}
}).error(onError);
};
var prepareModal = function ( onClose ) {
var $modal = jQuery('#p24-blik-modal');
if (!$modal.length) {
return false;
}
$modal.addClass('loading');
$modalBg = jQuery('#p24-blik-modal-background');
if ( onClose ) {
$modal.find('.close-modal').on('click', function (e) {
e.preventDefault();
onClose();
});
}
$modalBg.show();
return true;
};
var displayModal = function (nextSteep) {
var $modal = jQuery('#p24-blik-modal');
$modal.removeClass('loading');
var $button = $modal.find('button');
$button.on('click', function (e) {
e.preventDefault();
var $codeInput = $modal.find('input[type=text]');
var code = $codeInput.val();
var $acceptedInput = $modal.find('input[type=checkbox]');
if ($acceptedInput.length && !$acceptedInput.prop('checked')) {
$modal.find('.error-terms').show();
} else if (/^\d{6}$/.test(code)) {
$modal.addClass('loading');
nextSteep(code);
} else {
$modal.find('.error-common').show();
}
});
};
var trnRegisterPromise = function () {
var p24_session_id = jQuery('[name=p24_session_id]').val();
var order_id = jQuery('#p24_woo_order_id').val();
var hashed_order_id = jQuery('#p24_woo_hashed_order_id').val();
if (!order_id) {
order_id = $additional_order_data.data('order-id');
hashed_order_id = $additional_order_data.data('hashed-order-id');
}
return jQuery.ajax({
url: url,
method: 'POST', type: 'POST',
dataType: 'json',
data: {
action: 'trnRegister',
p24_session_id: p24_session_id,
order_id: order_id,
hashed_order_id: hashed_order_id
}
});
};
var trnRegisterLong = function () {
trnRegisterPromise().fail(payInShopFailure).done(function (data) {
var nextSteep = function (code) {
executePaymentByBlikCode(data, code, blikModalError);
};
displayModal(nextSteep)
});
};
var trnRegisterIfTerms = function() {
if ($termsAcceptanceCheckbox.attr('type') === 'checkbox' && !$termsAcceptanceCheckbox.is(':checked')) {
jQuery('#place_order').click();
return;
}
var hasModal = prepareModal(false);
if (hasModal) {
trnRegisterLong();
}
};
var tryArmBlikBoxConfirmation = function () {
/* Tile mode. */
var $logoBox = jQuery('#p24-bank-grid a.bank-box[data-id=181]');
if ($logoBox.length) {
$logoBox.on('click', function (e) {
e.preventDefault();
trnRegisterIfTerms();
});
}
/* Text mode. */
var $ourRadioInput = jQuery('#przelewy_method_id_181-');
if ($ourRadioInput.length) {
$ourRadioInput.on('change', function (e) {
if (!$ourRadioInput.prop('checked')) {
/* Nothing to do. */
return;
}
trnRegisterIfTerms();
});
}
/* There is a lot of magic in WooCommerce JavaScript. */
var $radioBox = jQuery('#payment_method_przelewy24_extra_181');
if ($radioBox.length) {
$radioBox.prop('checked', false);
jQuery("body").on("change", ".wc_payment_methods input[name='payment_method']", function () {
var $elm = jQuery(this);
if ($elm.prop('checked') && $elm.val() === 'przelewy24_extra_181') {
var hasModal = jQuery('#p24-blik-modal').length;
if (hasModal) {
var $checkoutButton = jQuery('.woocommerce-checkout');
var $terms = jQuery('#terms');
if ($terms.length && !$terms.prop('checked')) {
$checkoutButton.submit();
$elm.prop('checked', false)
} else {
var nextSteep = function (code) {
jQuery('#p24-blik-code-input').val(code);
$checkoutButton.submit();
}
prepareModal(false);
displayModal(nextSteep);
}
}
}
});
}
};
var tryExecuteBlik = function () {
var $input = jQuery('#przelewy_payment_form input[name=p24_provided_blik_code]');
if ($input.length) {
var code = $input.val();
if (code) {
var onError = function () {
var href = jQuery('#przelewy_payment_form a.button.cancel').attr('href');
location = href;
};
var hasModal = prepareModal(onError);
if (hasModal) {
if ($termsAcceptanceCheckbox.attr('type') === 'checkbox') {
/* We assume the the terms has been accepted on screen before. */
$termsAcceptanceCheckbox.prop('checked', true);
}
trnRegisterPromise().fail(onError).done(function (data) {
executePaymentByBlikCode(data, code, onError);
});
}
}
}
};
tryArmBlikBoxConfirmation();
tryExecuteBlik();
};
jQuery(function () {
var $bgLayer = jQuery('#p24-dynamic-whole-background');
if ($bgLayer.length) {
jQuery('body').append($bgLayer);
$bgLayer.css('display', 'block');
jQuery('#przelewy_payment_form input[name=p24_regulation_accept]').prop("required", false);
p24_processPayment();
}
});
jQuery(document).ready(function () {
choosePaymentMethod();
jQuery('body').on('change', '[name="p24_regulation_accept"]:checked', function() {
var $selectedCreditCardPayment = jQuery('.bank-box.bank-item.selected[onclick^="showPayJsPopup"]');
if ($selectedCreditCardPayment.length) {
$selectedCreditCardPayment.click();
}
});
p24TryUseCards();
tryArmBlikBox();
});
/* Hide Apple Pay if not configured or not available. */
jQuery(document).ready(function () {
//alert('ok, hit, p24');
var onCheckout = function() {
jQuery('li.payment_method_przelewy24_extra_232').css('display', 'none');
};
var hasApplePay = window.ApplePaySession && window.ApplePaySession.canMakePayments();
if (!hasApplePay) {
/* There are different places and modes the payment can be displayed. */
onCheckout();
jQuery(document.body).on('updated_checkout', onCheckout);
jQuery('#p24-bank-grid a.bank-box.bank-item[data-id=232]').css('display', 'none');
jQuery('#p24-bank-grid div.input-box.bank-item[data-id=232]').parent().css('display', 'none');
}
});