Actualiser test.html
CI / PHP Syntax Check (push) Has been cancelled
CI / JavaScript Lint (push) Has been cancelled
CI / Docker Build Test (push) Has been cancelled
CI / Validate Translation Files (push) Has been cancelled
CI / Auto-merge develop → main (push) Has been cancelled
CI / Create GitHub Release (push) Has been cancelled
CI / PHP Syntax Check (push) Has been cancelled
CI / JavaScript Lint (push) Has been cancelled
CI / Docker Build Test (push) Has been cancelled
CI / Validate Translation Files (push) Has been cancelled
CI / Auto-merge develop → main (push) Has been cancelled
CI / Create GitHub Release (push) Has been cancelled
This commit is contained in:
@@ -90,37 +90,35 @@
|
||||
let successCount = 0;
|
||||
let errorCount = 0;
|
||||
|
||||
// --- TENTATIVE DE RÉCUPÉRATION DU JETON ---
|
||||
// Regarde le nom du champ "name" dans le Payload de ta requête qui marche
|
||||
// Ici on essaie les plus courants
|
||||
let token = document.querySelector('input[name="csrf_token"]')?.value ||
|
||||
document.querySelector('input[name="_token"]')?.value || "";
|
||||
|
||||
for (const checkbox of checkedBoxes) {
|
||||
let p = fullProductList[checkbox.dataset.index];
|
||||
let p = { ...fullProductList[checkbox.dataset.index] };
|
||||
|
||||
let formData = new FormData();
|
||||
for (let key in p) {
|
||||
formData.append(key, p[key]);
|
||||
}
|
||||
for (let key in p) { formData.append(key, p[key]); }
|
||||
formData.set('category', newCat);
|
||||
if (token) formData.append('csrf_token', token); // Ajuste 'csrf_token' si besoin
|
||||
|
||||
try {
|
||||
// On ajoute l'en-tête X-Requested-With qui est souvent le verrou du 403
|
||||
let res = await fetch('api/index.php?action=product_save', {
|
||||
method: 'POST',
|
||||
body: formData,
|
||||
headers: {
|
||||
'X-Requested-With': 'XMLHttpRequest'
|
||||
}
|
||||
headers: { 'X-Requested-With': 'XMLHttpRequest' }
|
||||
});
|
||||
|
||||
// On récupère le texte pour voir ce que le serveur dit vraiment en cas d'erreur
|
||||
let resultText = await res.text();
|
||||
|
||||
if (res.ok) {
|
||||
successCount++;
|
||||
} else {
|
||||
console.error("Échec sur " + p.name + " (Code " + res.status + "):", resultText);
|
||||
if (res.ok) successCount++;
|
||||
else {
|
||||
let text = await res.text();
|
||||
console.error("Échec:", text);
|
||||
errorCount++;
|
||||
}
|
||||
await new Promise(r => setTimeout(r, 300));
|
||||
} catch (e) {
|
||||
console.error("Erreur critique sur " + p.name, e);
|
||||
errorCount++;
|
||||
}
|
||||
}
|
||||
@@ -128,7 +126,7 @@
|
||||
await loadData();
|
||||
btn.disabled = false;
|
||||
btn.textContent = "APPLIQUER AUX COCHÉS";
|
||||
alert(`Traitement terminé :\n- Succès : ${successCount}\n- Erreurs : ${errorCount}\n\n(Vérifie la console F12 pour le détail des erreurs)`);
|
||||
alert(`Terminé :\n- Succès : ${successCount}\n- Erreurs : ${errorCount}`);
|
||||
}
|
||||
</script>
|
||||
</body>
|
||||
|
||||
Reference in New Issue
Block a user