diff --git a/tienda/templates/tienda/checkout.html b/tienda/templates/tienda/checkout.html
index f51eb42..b1135e5 100644
--- a/tienda/templates/tienda/checkout.html
+++ b/tienda/templates/tienda/checkout.html
@@ -200,6 +200,7 @@
Guardar esta cuenta de PayPal para futuras compras
+
{% if not addresses or stock_issues %}
Selecciona una dirección de envío válida para activar el pago.
@@ -288,10 +289,13 @@ document.getElementById('pay-card-btn').addEventListener('click', async () => {
const addressId = document.getElementById('shipping-address').value;
if (!addressId) {
- alert('Selecciona una dirección de envío para continuar.');
+ const cardErrors = document.getElementById('card-errors');
+ if (cardErrors) cardErrors.textContent = 'Selecciona una dirección de envío para continuar.';
return;
}
+ const cardErrorsEl = document.getElementById('card-errors');
+ if (cardErrorsEl) cardErrorsEl.textContent = '';
const btn = document.getElementById('pay-card-btn');
const spinner = document.getElementById('card-spinner');
btn.disabled = true;
@@ -369,9 +373,15 @@ paypal.Buttons({
createOrder: async () => {
const addressId = document.getElementById('shipping-address').value;
if (!addressId) {
- alert('Selecciona una dirección de envío para continuar.');
+ const paypalErrors = document.getElementById('paypal-errors');
+ if (paypalErrors) {
+ paypalErrors.textContent = 'Selecciona una dirección de envío para continuar.';
+ paypalErrors.classList.remove('d-none');
+ }
return Promise.reject(new Error('Sin dirección'));
}
+ const paypalErrorsEl = document.getElementById('paypal-errors');
+ if (paypalErrorsEl) paypalErrorsEl.classList.add('d-none');
const resp = await fetch('{% url "crear_orden_paypal" %}', {
method: 'POST',
headers: { 'Content-Type': 'application/json', 'X-CSRFToken': CSRF_TOKEN },
@@ -393,7 +403,11 @@ paypal.Buttons({
showSuccess(result.transaction_code);
},
onError: (err) => {
- alert('Error en el pago con PayPal: ' + err);
+ const paypalErrors = document.getElementById('paypal-errors');
+ if (paypalErrors) {
+ paypalErrors.textContent = 'Error en el pago con PayPal: ' + err;
+ paypalErrors.classList.remove('d-none');
+ }
},
}).render('#paypal-button-container');
{% endif %}