2022-04-25 08:53:47 +02:00
|
|
|
"use strict";
|
|
|
|
|
2023-01-24 14:08:47 +01:00
|
|
|
// ------------------------------------------------------------------------
|
|
|
|
// actions sur la liste des versements
|
|
|
|
// ------------------------------------------------------------------------
|
|
|
|
|
2022-01-25 20:18:00 +01:00
|
|
|
/**
|
2022-05-04 13:53:12 +02:00
|
|
|
* Fonction appelée quand on (dé)coche la case globale
|
|
|
|
* (dé)sélectionner toutes les cases de toutes les activités
|
2022-04-27 13:42:45 +02:00
|
|
|
* @param {HTMLInputElement} idCaseGlobale id de la case globale
|
2022-01-25 20:18:00 +01:00
|
|
|
*/
|
2022-02-18 10:37:39 +01:00
|
|
|
function cocherDecocherTout(idCaseGlobale)
|
|
|
|
{
|
2022-01-25 20:18:00 +01:00
|
|
|
// itérer sur la liste des éléments détails : 1 par couple <activité, tarif>
|
2022-04-27 13:42:45 +02:00
|
|
|
let lesDetails = document.querySelectorAll("details.activite");
|
|
|
|
for (let i = 0; i < lesDetails.length; ++i)
|
2022-03-24 19:00:39 +01:00
|
|
|
{
|
2022-05-04 13:53:12 +02:00
|
|
|
let idCase = lesDetails[i].querySelector("input[type=checkbox]");
|
|
|
|
idCase.checked = idCaseGlobale.checked;
|
|
|
|
cocherDecocherTarif(idCase);
|
2022-01-25 20:18:00 +01:00
|
|
|
}
|
|
|
|
// changer le message
|
2022-03-24 19:00:39 +01:00
|
|
|
changerMessage(idCaseGlobale.nextElementSibling, idCaseGlobale);
|
|
|
|
}
|
|
|
|
|
2022-05-04 13:53:12 +02:00
|
|
|
/**
|
|
|
|
* Fonction appelée quand on (dé)coche la case d'activité
|
2022-05-21 10:02:48 +02:00
|
|
|
* (dé)sélectionner toutes les cases de cette activité
|
2022-05-04 13:53:12 +02:00
|
|
|
* @param {HTMLInputElement} idCaseGlobale id de la case d'activité
|
|
|
|
*/
|
|
|
|
function cocherDecocherTarif(idCaseGlobale)
|
|
|
|
{
|
|
|
|
let lesPersonnes = idCaseGlobale.closest("details").querySelectorAll("div.personne");
|
|
|
|
cocherDecocherLesPersonnes(idCaseGlobale, lesPersonnes);
|
|
|
|
}
|
|
|
|
|
2022-03-24 19:00:39 +01:00
|
|
|
/**
|
|
|
|
* idem dans le cas des versements des personnes
|
2022-05-04 13:53:12 +02:00
|
|
|
* @param {HTMLInputElement} idCaseGlobale id case à cocher d'une personne
|
2022-04-25 08:53:47 +02:00
|
|
|
*/
|
2022-03-29 14:50:25 +02:00
|
|
|
function cocherDecocherToutesLesPersonnes(idCaseGlobale)
|
2022-03-24 19:00:39 +01:00
|
|
|
{
|
2022-05-04 13:53:12 +02:00
|
|
|
let lesPersonnes = document.querySelectorAll("div.personne");
|
2022-04-04 11:37:17 +02:00
|
|
|
cocherDecocherLesPersonnes(idCaseGlobale, lesPersonnes);
|
2022-03-24 19:00:39 +01:00
|
|
|
changerMessage(idCaseGlobale.nextElementSibling, idCaseGlobale);
|
|
|
|
}
|
|
|
|
|
2022-04-27 13:42:45 +02:00
|
|
|
/**
|
|
|
|
* @param {HTMLInputElement} idCaseGlobale
|
|
|
|
* @param {NodeListOf<Element>} lesPersonnes
|
|
|
|
*/
|
2022-03-24 19:00:39 +01:00
|
|
|
function cocherDecocherLesPersonnes(idCaseGlobale, lesPersonnes)
|
|
|
|
{
|
2022-04-27 13:42:45 +02:00
|
|
|
for (let j = 0; j < lesPersonnes.length; ++j)
|
2022-03-24 19:00:39 +01:00
|
|
|
{
|
|
|
|
// trouver l'élément total de la personne
|
2022-04-27 13:42:45 +02:00
|
|
|
let idTotal = lesPersonnes[j].querySelector("span");
|
2022-03-24 19:00:39 +01:00
|
|
|
// puis la case à cocher
|
2022-04-27 13:42:45 +02:00
|
|
|
let idCase = lesPersonnes[j].closest("summary").querySelector("input");
|
2022-03-24 19:00:39 +01:00
|
|
|
idCase.checked = idCaseGlobale.checked;
|
|
|
|
// puis traiter toutes les cases de la personne
|
2022-04-25 08:53:47 +02:00
|
|
|
cocherDecocherPersonne(idCase, idTotal);
|
2022-01-25 20:18:00 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-01-14 18:59:18 +01:00
|
|
|
/**
|
2022-05-04 13:53:12 +02:00
|
|
|
* Fonction appelée quand on (dé)coche la case d'une personne
|
2022-01-14 18:59:18 +01:00
|
|
|
* - (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-04-27 13:42:45 +02:00
|
|
|
* @param {HTMLInputElement} idCase id de la case qui a été cochée
|
|
|
|
* @param {HTMLSpanElement} idTotal id de l'élément où afficher le total
|
2022-01-14 18:59:18 +01:00
|
|
|
*/
|
2022-04-25 08:53:47 +02:00
|
|
|
function cocherDecocherPersonne(idCase, idTotal)
|
2022-02-18 10:37:39 +01:00
|
|
|
{
|
2022-03-29 14:50:25 +02:00
|
|
|
// chercher le fieldset des versements
|
2022-05-18 12:30:10 +02:00
|
|
|
let fieldset = idCase.closest("details").querySelector("div.versements");
|
2022-04-27 13:42:45 +02:00
|
|
|
let listeCases = fieldset.querySelectorAll("input[type=checkbox]");
|
|
|
|
for (let i = 0; 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-05-04 13:53:12 +02:00
|
|
|
cocherDecocherVersement(listeCases[i], idTotal);
|
2022-01-14 20:26:00 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fonction appelée quand on (dé)coche la case d'un versement
|
2022-03-29 14:50:25 +02:00
|
|
|
* Faire le total des cases cochées et l'afficher
|
2022-01-28 15:40:21 +01:00
|
|
|
*
|
2022-04-27 13:42:45 +02:00
|
|
|
* @param {HTMLInputElement} idCase id de la case qui a été cochée
|
|
|
|
* @param {HTMLSpanElement} idTotal id de l'élément où afficher le total
|
2022-01-14 20:26:00 +01:00
|
|
|
*/
|
2022-02-18 10:37:39 +01:00
|
|
|
function cocherDecocherVersement(idCase, idTotal)
|
|
|
|
{
|
2022-05-18 12:30:10 +02:00
|
|
|
let fieldset = idCase.closest("div.versements");
|
2022-04-27 13:42:45 +02:00
|
|
|
let listeCases = fieldset.querySelectorAll("input[type=checkbox]");
|
|
|
|
let 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
|
2022-04-27 13:42:45 +02:00
|
|
|
* @param {NodeListOf<Element>} listeCases liste des cases
|
|
|
|
* @param {NodeListOf<Element>} listeMontants liste des montants associés
|
|
|
|
* @param {HTMLSpanElement} idTotal id de l'élément où afficher le total
|
2022-04-25 08:53:47 +02:00
|
|
|
*/
|
2022-02-18 10:37:39 +01:00
|
|
|
function calculerTotal(listeCases, listeMontants, idTotal)
|
|
|
|
{
|
2022-04-27 13:42:45 +02:00
|
|
|
let total = 0;
|
|
|
|
for (let i = 0; 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-05-17 10:41:55 +02:00
|
|
|
total += parseFloat(listeMontants[i].textContent.replace(/\s/g, "").replace(",", "."));
|
2022-01-14 18:59:18 +01:00
|
|
|
}
|
|
|
|
}
|
2022-04-25 08:53:47 +02:00
|
|
|
// afficher le total
|
2022-01-14 18:59:18 +01:00
|
|
|
idTotal.innerHTML =
|
|
|
|
total.toLocaleString('fr-FR', {style: 'currency', currency: 'EUR',
|
|
|
|
minimumFractionDigits: 2});
|
|
|
|
}
|
|
|
|
|
2022-03-24 19:00:39 +01:00
|
|
|
/**
|
|
|
|
* changer le message en fonction de l'état coché de la case
|
2022-04-27 13:42:45 +02:00
|
|
|
* @param {Element} message
|
|
|
|
* @param {HTMLInputElement} idCase
|
2022-04-25 08:53:47 +02:00
|
|
|
*/
|
2022-03-24 19:00:39 +01:00
|
|
|
function changerMessage(message, idCase)
|
|
|
|
{
|
|
|
|
if (idCase.checked) {
|
|
|
|
message.innerHTML = "Cliquer pour dé-cocher toutes les lignes";
|
|
|
|
} else {
|
|
|
|
message.innerHTML = "Cliquer pour cocher toutes les lignes";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-01-19 16:04:42 +01:00
|
|
|
/**
|
2023-01-24 14:08:47 +01:00
|
|
|
* afficher/masquer les détails
|
|
|
|
* @param {string} idElem bouton de masquage/affichage
|
|
|
|
* @param {string} classe des détails à afficher/masquer
|
|
|
|
* @param {string} texte du bouton
|
|
|
|
*/
|
|
|
|
function montrerMasquerDetails(idElem, classe, texte)
|
|
|
|
{
|
|
|
|
let lesDetails = document.querySelectorAll(classe);
|
|
|
|
if (lesDetails.length > 0)
|
|
|
|
{
|
|
|
|
let leBouton = document.getElementById(idElem);
|
2023-01-31 09:46:51 +01:00
|
|
|
if (leBouton.textContent.includes('Replier'))
|
2023-01-24 14:08:47 +01:00
|
|
|
{
|
|
|
|
// masquer
|
|
|
|
lesDetails.forEach((e) => {
|
|
|
|
e.removeAttribute('open');
|
|
|
|
});
|
|
|
|
leBouton.textContent = "Déplier " + texte;
|
|
|
|
leBouton.setAttribute('data-icon', '↓');
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// montrer
|
|
|
|
lesDetails.forEach((e) => {
|
|
|
|
e.setAttribute('open', 'open');
|
|
|
|
});
|
|
|
|
leBouton.textContent = "Replier " + texte;
|
|
|
|
leBouton.setAttribute('data-icon', '↑');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* fonction appelée lors de la demande de génération des reçus
|
|
|
|
* vérifier qu'au moins un versement a été sélectionné
|
2022-01-19 16:04:42 +01:00
|
|
|
* @return vrai si au moins un choix a été fait
|
2022-04-27 13:42:45 +02:00
|
|
|
* @param {HTMLFormElement} formulaire
|
2022-04-25 08:53:47 +02:00
|
|
|
*/
|
2022-01-19 16:04:42 +01:00
|
|
|
function verifierChoix(formulaire)
|
|
|
|
{
|
2023-01-24 14:08:47 +01:00
|
|
|
return verifierCases(formulaire, 'checkbox', "au moins un versement");
|
2022-01-19 16:04:42 +01:00
|
|
|
}
|
2022-01-26 12:12:42 +01:00
|
|
|
|
2023-01-24 14:08:47 +01:00
|
|
|
// ------------------------------------------------------------------------
|
|
|
|
// actions sur la page d'accueil
|
|
|
|
// ------------------------------------------------------------------------
|
|
|
|
|
2022-04-27 13:42:45 +02:00
|
|
|
/**
|
2022-05-18 12:30:10 +02:00
|
|
|
* positionner l'action déclenchée par l'envoi du formulaire
|
2022-04-27 13:42:45 +02:00
|
|
|
* afficher et masquer des portions de formulaire selon l'action
|
|
|
|
* @param {HTMLFormElement} formulaire
|
|
|
|
* @param {string} action après envoi du formulaire
|
2022-05-18 12:30:10 +02:00
|
|
|
* @param {any} idElem id de l'élément à afficher
|
|
|
|
* @param {any} nomClasse classe des éléments à masquer (sauf idElem)
|
2022-04-27 13:42:45 +02:00
|
|
|
*/
|
2022-05-18 12:30:10 +02:00
|
|
|
function choixMethodeGeneration(formulaire, action, idElem, nomClasse)
|
2022-03-31 11:43:23 +02:00
|
|
|
{
|
|
|
|
formulaire.setAttribute('action', 'action.php?action=' + action);
|
2022-05-18 12:30:10 +02:00
|
|
|
for (let elem of formulaire.querySelectorAll(nomClasse))
|
|
|
|
{
|
|
|
|
if (elem.id == idElem)
|
|
|
|
{
|
|
|
|
elem.classList.remove('hidden');
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
elem.classList.add('hidden');
|
|
|
|
}
|
2022-01-28 15:40:21 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-04-27 13:42:45 +02: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é :)
|
2023-01-24 14:08:47 +01:00
|
|
|
* @param conteneur des cases à vérifier
|
2022-04-27 13:42:45 +02:00
|
|
|
*/
|
2023-01-24 14:08:47 +01:00
|
|
|
function verifierActivitésTaux(conteneur)
|
2022-02-18 10:37:39 +01:00
|
|
|
{
|
2022-04-27 13:42:45 +02:00
|
|
|
let nbChoix = 0;
|
2022-02-18 10:37:39 +01:00
|
|
|
// parcourir les cases à cocher
|
2023-01-24 14:08:47 +01:00
|
|
|
for (let idCase of conteneur.querySelectorAll("input[type=checkbox]"))
|
2022-02-18 10:37:39 +01:00
|
|
|
{
|
|
|
|
if (idCase.checked) {
|
|
|
|
++nbChoix;
|
|
|
|
// vérifier qu'un radio de la même ligne est sélectionné
|
2022-04-27 13:42:45 +02:00
|
|
|
let ligneCorrecte = false;
|
2022-02-18 10:37:39 +01:00
|
|
|
// trouver la ligne englobante
|
2022-05-18 12:30:10 +02:00
|
|
|
let ligne = idCase.closest("li");
|
2022-04-27 13:42:45 +02:00
|
|
|
for (let idRadio of ligne.querySelectorAll('input[type=radio]'))
|
2022-02-18 10:37:39 +01:00
|
|
|
{
|
|
|
|
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) {
|
2022-05-18 12:30:10 +02:00
|
|
|
alert("Erreur : il faut sélectionner au moins une ligne");
|
2022-02-18 10:37:39 +01:00
|
|
|
}
|
|
|
|
return nbChoix != 0;
|
|
|
|
}
|
|
|
|
|
2022-04-27 13:42:45 +02:00
|
|
|
/**
|
2023-01-24 14:08:47 +01:00
|
|
|
* vérifier qu'un taux a été sélectionné dans le conteneur paramètre
|
2022-04-27 13:42:45 +02:00
|
|
|
*/
|
2023-01-24 14:08:47 +01:00
|
|
|
function verifierTaux(conteneur)
|
2022-02-18 10:37:39 +01:00
|
|
|
{
|
2023-01-24 14:08:47 +01:00
|
|
|
return verifierCases(conteneur, 'radio', "un taux de réduction");
|
2022-02-08 11:25:54 +01:00
|
|
|
}
|
2022-03-30 09:52:19 +02:00
|
|
|
|
2023-01-24 14:08:47 +01:00
|
|
|
// ------------------------------------------------------------------------
|
|
|
|
// actions sur la config
|
|
|
|
// ------------------------------------------------------------------------
|
2023-01-23 18:53:53 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* vérifier les données saisies dans le formulaire de configuration
|
2023-01-24 14:08:47 +01:00
|
|
|
*/
|
|
|
|
function verifierConfig(divArticles, divTauxReduc)
|
2023-01-23 18:53:53 +01:00
|
|
|
{
|
|
|
|
// articles
|
2023-01-24 14:08:47 +01:00
|
|
|
if (! verifierCases(divArticles, "checkbox", "au moins un article")) { return false; }
|
2023-01-23 18:53:53 +01:00
|
|
|
|
|
|
|
// taux de réduction
|
2023-01-24 14:08:47 +01:00
|
|
|
if (! verifierCases(divTauxReduc, "checkbox", "au moins un taux de réduction")) { return false; }
|
2023-01-23 18:53:53 +01:00
|
|
|
|
|
|
|
// Nom, fonction, signature
|
|
|
|
|
|
|
|
|
|
|
|
// alert("Erreur : il faut sélectionner au moins un versement");
|
|
|
|
return true;
|
|
|
|
}
|
2023-01-24 14:08:47 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Vérifier qu'au moins une case est cochée dans le conteneur
|
|
|
|
* @param conteneur
|
|
|
|
* @param type de case à vérifier (radio, checkbox)
|
|
|
|
* @param message à afficher si erreur
|
|
|
|
*/
|
|
|
|
function verifierCases(conteneur, type, message)
|
|
|
|
{
|
|
|
|
let selecteur = "input[type=" + type + "]";
|
|
|
|
let listeCheck = conteneur.querySelectorAll(selecteur);
|
|
|
|
for (let elem of listeCheck)
|
|
|
|
{
|
|
|
|
if (elem.checked) { return true; }
|
|
|
|
}
|
|
|
|
alert("Erreur : il faut sélectionner " + message);
|
|
|
|
return false;
|
|
|
|
}
|