2022-01-25 20:18:00 +01:00
|
|
|
/**
|
|
|
|
* Fonction appelée quand on (dé)coche la case de sélection globale
|
|
|
|
* (dé)sélectionner toutes les cases à cocher de toutes les activités
|
|
|
|
* @param id de la case globale
|
|
|
|
*/
|
2022-02-18 10:37:39 +01:00
|
|
|
function cocherDecocherTout(idCaseGlobale)
|
|
|
|
{
|
2022-01-25 20:18:00 +01:00
|
|
|
// chercher le formulaire englobant
|
|
|
|
var formulaire = idCaseGlobale.closest("form");
|
|
|
|
// itérer sur la liste des éléments détails : 1 par couple <activité, tarif>
|
|
|
|
var lesDetails = formulaire.querySelectorAll("details");
|
|
|
|
for (var i = 0; i < lesDetails.length; ++i) {
|
|
|
|
// itérer sur les personnes
|
|
|
|
var lesH3 = lesDetails[i].querySelectorAll("h3.personne");
|
|
|
|
for (var j = 0; j < lesH3.length; ++j) {
|
|
|
|
// trouver l'élément total de la personne
|
|
|
|
var idTotal = lesH3[j].querySelector("span");
|
|
|
|
// puis la case à cocher
|
|
|
|
var fieldset = lesH3[j].nextElementSibling;
|
|
|
|
var idCase = fieldset.querySelector("input");
|
|
|
|
idCase.checked = idCaseGlobale.checked;
|
|
|
|
// puis traiter toutes les cases de la personne
|
|
|
|
cocherDecocherPersonne(idCase, idTotal);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// changer le message
|
|
|
|
var message = idCaseGlobale.nextElementSibling;
|
|
|
|
if (idCase.checked) {
|
|
|
|
message.innerHTML = "Cliquer pour dé-cocher toutes les lignes";
|
|
|
|
} else {
|
|
|
|
message.innerHTML = "Cliquer pour cocher toutes les lignes";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-01-14 18:59:18 +01:00
|
|
|
/**
|
|
|
|
* Fonction appelée quand on (dé)coche la case d'une personne
|
|
|
|
* - (dé)sélectionner toutes les cases à cocher
|
2022-01-14 20:26:00 +01:00
|
|
|
* - faire le total des cases cochées et l'afficher
|
2022-01-28 15:40:21 +01:00
|
|
|
*
|
2022-01-14 18:59:18 +01:00
|
|
|
* @param id de la case qui a été cochée
|
|
|
|
* @param id de l'élément où afficher le total
|
|
|
|
*/
|
2022-02-18 10:37:39 +01:00
|
|
|
function cocherDecocherPersonne(idCase, idTotal)
|
|
|
|
{
|
2022-01-14 18:59:18 +01:00
|
|
|
// chercher le fieldset englobant
|
|
|
|
var fieldset = idCase.closest("fieldset");
|
2022-01-15 19:17:18 +01:00
|
|
|
var listeCases = fieldset.querySelectorAll("input[type=checkbox]");
|
|
|
|
for (var i = 1; i < listeCases.length; ++i)
|
2022-01-14 18:59:18 +01:00
|
|
|
{
|
2022-01-15 19:17:18 +01:00
|
|
|
listeCases[i].checked = idCase.checked;
|
2022-01-14 20:26:00 +01:00
|
|
|
}
|
|
|
|
// changer le message
|
|
|
|
var message = idCase.nextElementSibling;
|
|
|
|
if (idCase.checked) {
|
2022-01-15 19:17:18 +01:00
|
|
|
message.innerHTML = "Cliquer pour dé-cocher toutes les lignes";
|
2022-01-14 20:26:00 +01:00
|
|
|
} else {
|
2022-01-15 19:17:18 +01:00
|
|
|
message.innerHTML = "Cliquer pour cocher toutes les lignes";
|
2022-01-14 20:26:00 +01:00
|
|
|
}
|
|
|
|
// calculer et afficher le total
|
2022-01-15 19:17:18 +01:00
|
|
|
var listeMontants = fieldset.querySelectorAll("span.montant");
|
|
|
|
calculerTotal(listeCases, listeMontants, idTotal);
|
2022-01-14 20:26:00 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fonction appelée quand on (dé)coche la case d'un versement
|
|
|
|
* - (dé)sélectionner cette case (?)
|
|
|
|
* - faire le total des cases cochées et l'afficher
|
2022-01-28 15:40:21 +01:00
|
|
|
*
|
2022-01-14 20:26:00 +01:00
|
|
|
* @param id de la case qui a été cochée
|
|
|
|
* @param id de l'élément où afficher le total
|
|
|
|
*/
|
2022-02-18 10:37:39 +01:00
|
|
|
function cocherDecocherVersement(idCase, idTotal)
|
|
|
|
{
|
2022-01-14 20:26:00 +01:00
|
|
|
var fieldset = idCase.closest("fieldset");
|
2022-01-15 19:17:18 +01:00
|
|
|
var listeCases = fieldset.querySelectorAll("input[type=checkbox]");
|
2022-01-14 20:26:00 +01:00
|
|
|
var listeMontants = fieldset.querySelectorAll("span.montant");
|
2022-01-15 19:17:18 +01:00
|
|
|
calculerTotal(listeCases, listeMontants, idTotal);
|
2022-01-14 20:26:00 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Faire le total des cases cochées et l'afficher
|
|
|
|
* @param listes des cases
|
|
|
|
* @param listes des montants associés
|
|
|
|
* @param id de l'élément où afficher le total
|
|
|
|
*/
|
2022-02-18 10:37:39 +01:00
|
|
|
function calculerTotal(listeCases, listeMontants, idTotal)
|
|
|
|
{
|
2022-01-14 20:26:00 +01:00
|
|
|
var total = 0;
|
2022-01-15 19:17:18 +01:00
|
|
|
for (var i = 1; i < listeCases.length; ++i)
|
2022-01-14 20:26:00 +01:00
|
|
|
{
|
2022-01-15 19:17:18 +01:00
|
|
|
if (listeCases[i].checked) {
|
2022-02-08 10:53:10 +01:00
|
|
|
total += parseFloat(listeMontants[i-1].textContent.replace(/\s/g, ""));
|
2022-01-14 18:59:18 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
// "afficher" le total
|
|
|
|
idTotal.innerHTML =
|
|
|
|
total.toLocaleString('fr-FR', {style: 'currency', currency: 'EUR',
|
|
|
|
minimumFractionDigits: 2});
|
|
|
|
}
|
|
|
|
|
2022-01-19 16:04:42 +01:00
|
|
|
/**
|
|
|
|
* fonction appelée lors de la validation du formulaire
|
|
|
|
* @return vrai si au moins un choix a été fait
|
|
|
|
* @param : formulaire
|
|
|
|
*/
|
|
|
|
function verifierChoix(formulaire)
|
|
|
|
{
|
|
|
|
var listeCheck = formulaire.getElementsByTagName("input");
|
|
|
|
var ok = false;
|
|
|
|
for (var i = 1; i < listeCheck.length; ++i)
|
|
|
|
{
|
|
|
|
if (listeCheck[i].checked)
|
|
|
|
{
|
|
|
|
ok = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (! ok)
|
|
|
|
{
|
|
|
|
alert("Erreur : il faut sélectionner au moins un versement");
|
|
|
|
}
|
|
|
|
return ok;
|
|
|
|
}
|
2022-01-26 12:12:42 +01:00
|
|
|
|
2022-02-18 10:37:39 +01:00
|
|
|
/**
|
|
|
|
* fonction appelée pour afficher et masquer des portions de formulaire
|
|
|
|
*/
|
|
|
|
function afficherMasquer(formulaire, nomClasse1, nomClasse2)
|
|
|
|
{
|
2022-01-28 15:40:21 +01:00
|
|
|
for (var elem of formulaire.querySelectorAll(nomClasse1)) {
|
|
|
|
elem.classList.remove('hidden');
|
|
|
|
}
|
|
|
|
for (var elem of formulaire.querySelectorAll(nomClasse2)) {
|
|
|
|
elem.classList.add('hidden');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-18 10:37:39 +01:00
|
|
|
// vérifier
|
|
|
|
// - qu'au moins une activité/tarif est sélectionnée
|
|
|
|
// - qu'un radio de chaque activité/tarif sélectionné a été sélectionné :)
|
|
|
|
function verifierCases(idElem)
|
|
|
|
{
|
|
|
|
var div = document.getElementById(idElem);
|
|
|
|
var nbChoix = 0;
|
|
|
|
// parcourir les cases à cocher
|
|
|
|
for (var idCase of div.querySelectorAll("input[type=checkbox]"))
|
|
|
|
{
|
|
|
|
if (idCase.checked) {
|
|
|
|
++nbChoix;
|
|
|
|
// vérifier qu'un radio de la même ligne est sélectionné
|
|
|
|
var ligneCorrecte = false;
|
|
|
|
// trouver la ligne englobante
|
|
|
|
var ligne = idCase.closest("tr");
|
|
|
|
for (var idRadio of ligne.querySelectorAll('input[type=radio]'))
|
|
|
|
{
|
|
|
|
if (idRadio.checked) { ligneCorrecte = true; break; }
|
|
|
|
}
|
|
|
|
if (! ligneCorrecte) {
|
|
|
|
alert("Erreur : il faut sélectionner un taux de réduction dans chaque ligne cochée");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (nbChoix == 0) {
|
|
|
|
alert("Erreur : il faut sélectionner au moins une activité/tarif");
|
|
|
|
}
|
|
|
|
return nbChoix != 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
// vérifier qu'un radio a été sélectionné dans la div paramètre
|
|
|
|
function verifierRadio(idElem)
|
|
|
|
{
|
|
|
|
var div = document.getElementById(idElem);
|
|
|
|
for (var idRadio of div.querySelectorAll('input[type=radio]'))
|
|
|
|
{
|
|
|
|
if (idRadio.checked) { return true; }
|
|
|
|
}
|
|
|
|
alert("Erreur : il faut sélectionner un taux de réduction");
|
|
|
|
return false;
|
2022-02-08 11:25:54 +01:00
|
|
|
}
|