modernisation code ; simplification affichage

FossilOrigin-Name: e1b162c4d12b471d8f71c44e29fcce22c466ce789434c6780d2439bb14f3b761
This commit is contained in:
engel 2022-04-27 13:49:23 +00:00
parent 3bbe2e4ac9
commit 1888314fa7
5 changed files with 109 additions and 77 deletions

View File

@ -2,7 +2,7 @@ nom="Reçus fiscaux"
description="Génération de reçus fiscaux pour les dons des membres" description="Génération de reçus fiscaux pour les dons des membres"
auteur="jce" auteur="jce"
url="https://git.roflcopter.fr/lesanges/recus-fiscaux-garradin" url="https://git.roflcopter.fr/lesanges/recus-fiscaux-garradin"
version="0.6" version="0.6.4"
menu=1 menu=1
config=1 config=1
min_version="1.1" min_version="1.1"

View File

@ -4,11 +4,14 @@
<h2>Versements par personne</h2> <h2>Versements par personne</h2>
<fieldset class="noprint"> <fieldset class="noprint">
<input type="checkbox" class="check_global" id="check_global" <input type="checkbox" class="check_global" id="check_global"
onclick="cocherDecocherToutesLesPersonnes(check_global)" /> onclick="cocherDecocherToutesLesPersonnes(check_global)" />
<label for="check_global">Cliquer pour cocher toutes les lignes</label> <label for="check_global">Cliquer pour cocher toutes les lignes</label>
<button type="button" data-icon="↑" class="icn-btn" id="close_details_personne" onclick="montrerMasquerDetails(this.id, 'details.personne', 'toutes les personnes')">Replier toutes les personnes</button> <button type="button" data-icon="↑" class="icn-btn" id="close_details_personne"
<input type="submit" value="Générer les reçus" form="versements_personnes" onclick="return verifierChoix(this.form)"> onclick="montrerMasquerDetails(this.id, 'details.personne', 'toutes les personnes')">Replier toutes les
personnes</button>
<input type="submit" value="Générer les reçus" form="versements_personnes"
onclick="return verifierChoix(this.form)">
</fieldset> </fieldset>
<form method="post" id="versements_personnes" action="generer_recus.php?type=personne"> <form method="post" id="versements_personnes" action="generer_recus.php?type=personne">
@ -19,7 +22,7 @@
{if $rang == 0} {if $rang == 0}
{* 1ère personne *} {* 1ère personne *}
<?php <?php
$personneCourante = $versement->idUser; $personneCourante = $versement->idUser;
?> ?>
{afficher_debut_personne user=$personneCourante idVersement=$personneCourante} {afficher_debut_personne user=$personneCourante idVersement=$personneCourante}
{afficher_versement versement=$versement idVersement=$personneCourante rang=$rang} {afficher_versement versement=$versement idVersement=$personneCourante rang=$rang}
@ -29,7 +32,7 @@
</fieldset> </fieldset>
</details> </details>
<?php <?php
$personneCourante = $versement->idUser; $personneCourante = $versement->idUser;
?> ?>
{afficher_debut_personne user=$personneCourante idVersement=$personneCourante} {afficher_debut_personne user=$personneCourante idVersement=$personneCourante}
{afficher_versement versement=$versement idVersement=$personneCourante rang=$rang} {afficher_versement versement=$versement idVersement=$personneCourante rang=$rang}

View File

@ -71,14 +71,8 @@ $tpl->register_function('afficher_debut_personne', function ($params)
$personne = $_SESSION['membresDonateurs'][$idUser]; $personne = $_SESSION['membresDonateurs'][$idUser];
$out = '<details class="personne" open="open"> $out = '<details class="personne" open="open">
<summary class="personne">'; <summary class="personne">
$out .= sprintf('<h4 class="personne">Versements de %s : <span class="total" id="total_%s">0,00 €</span></h4>', <h4 class="personne">';
$personne->nomPrenom,
$idVersement);
$out .= '</summary>';
$out .= sprintf('
<fieldset class="versements" id="versements_%s">',
$idVersement);
$out .= sprintf(' $out .= sprintf('
<input type="checkbox" id="check_%s"', <input type="checkbox" id="check_%s"',
$idVersement); $idVersement);
@ -86,10 +80,15 @@ $tpl->register_function('afficher_debut_personne', function ($params)
$idVersement, $idVersement,
$idVersement); $idVersement);
$out .= sprintf(' $out .= sprintf('
<label for="check_%s">Cliquer pour cocher toutes les lignes</label>', <label for="check_%s"></label>',
$idVersement);
$out .= sprintf('%s : <span class="total" id="total_%s">0,00 €</span>',
$personne->nomPrenom,
$idVersement);
$out .= '</h4></summary>';
$out .= sprintf('
<fieldset class="versements" id="versements_%s">',
$idVersement); $idVersement);
$out .= '<br />
<hr>';
return $out; return $out;
}); });

View File

@ -1,16 +1,18 @@
"use strict";
/** /**
* Fonction appelée quand on ()coche la case de sélection globale * Fonction appelée quand on ()coche la case de sélection globale
* ()sélectionner toutes les cases à cocher de toutes les activités * ()sélectionner toutes les cases à cocher de toutes les activités
* @param id de la case globale * @param {HTMLInputElement} idCaseGlobale id de la case globale
*/ */
function cocherDecocherTout(idCaseGlobale) function cocherDecocherTout(idCaseGlobale)
{ {
// itérer sur la liste des éléments détails : 1 par couple <activité, tarif> // itérer sur la liste des éléments détails : 1 par couple <activité, tarif>
var lesDetails = document.querySelectorAll("details.activite"); let lesDetails = document.querySelectorAll("details.activite");
for (var i = 0; i < lesDetails.length; ++i) for (let i = 0; i < lesDetails.length; ++i)
{ {
// itérer sur les personnes // itérer sur les personnes
var lesPersonnes = lesDetails[i].querySelectorAll("h4.personne"); let lesPersonnes = lesDetails[i].querySelectorAll("h4.personne");
cocherDecocherLesPersonnes(idCaseGlobale, lesPersonnes); cocherDecocherLesPersonnes(idCaseGlobale, lesPersonnes);
} }
// changer le message // changer le message
@ -19,26 +21,30 @@ function cocherDecocherTout(idCaseGlobale)
/** /**
* idem dans le cas des versements des personnes * idem dans le cas des versements des personnes
*/ * @param {HTMLInputElement} idCaseGlobale id de la case globale
*/
function cocherDecocherToutesLesPersonnes(idCaseGlobale) function cocherDecocherToutesLesPersonnes(idCaseGlobale)
{ {
var lesPersonnes = document.querySelectorAll("h4.personne"); let lesPersonnes = document.querySelectorAll("h4.personne");
cocherDecocherLesPersonnes(idCaseGlobale, lesPersonnes); cocherDecocherLesPersonnes(idCaseGlobale, lesPersonnes);
changerMessage(idCaseGlobale.nextElementSibling, idCaseGlobale); changerMessage(idCaseGlobale.nextElementSibling, idCaseGlobale);
} }
/**
* @param {HTMLInputElement} idCaseGlobale
* @param {NodeListOf<Element>} lesPersonnes
*/
function cocherDecocherLesPersonnes(idCaseGlobale, lesPersonnes) function cocherDecocherLesPersonnes(idCaseGlobale, lesPersonnes)
{ {
for (var j = 0; j < lesPersonnes.length; ++j) for (let j = 0; j < lesPersonnes.length; ++j)
{ {
// trouver l'élément total de la personne // trouver l'élément total de la personne
var idTotal = lesPersonnes[j].querySelector("span"); let idTotal = lesPersonnes[j].querySelector("span");
// puis la case à cocher // puis la case à cocher
var fieldset = lesPersonnes[j].closest("details").querySelector("fieldset"); let idCase = lesPersonnes[j].closest("summary").querySelector("input");
var idCase = fieldset.querySelector("input");
idCase.checked = idCaseGlobale.checked; idCase.checked = idCaseGlobale.checked;
// puis traiter toutes les cases de la personne // puis traiter toutes les cases de la personne
cocherDecocherPersonne(idCase, idTotal, false); cocherDecocherPersonne(idCase, idTotal);
} }
} }
@ -46,58 +52,54 @@ function cocherDecocherLesPersonnes(idCaseGlobale, lesPersonnes)
* Fonction appelée quand on ()coche la case globale d'une personne * Fonction appelée quand on ()coche la case globale d'une personne
* - ()sélectionner toutes les cases à cocher * - ()sélectionner toutes les cases à cocher
* - faire le total des cases cochées et l'afficher * - faire le total des cases cochées et l'afficher
* * @param {HTMLInputElement} idCase id de la case qui a été cochée
* @param id de la case qui a été cochée * @param {HTMLSpanElement} idTotal id de l'élément afficher le total
* @param id de l'élément afficher le total
* @param changer : vrai, s'il faut changer le message de la personne
*/ */
function cocherDecocherPersonne(idCase, idTotal, changer = true) function cocherDecocherPersonne(idCase, idTotal)
{ {
// chercher le fieldset des versements // chercher le fieldset des versements
var fieldset = idCase.closest("details").querySelector("fieldset"); let fieldset = idCase.closest("details").querySelector("fieldset");
var listeCases = fieldset.querySelectorAll("input[type=checkbox]"); let listeCases = fieldset.querySelectorAll("input[type=checkbox]");
for (var i = 0; i < listeCases.length; ++i) for (let i = 0; i < listeCases.length; ++i)
{ {
listeCases[i].checked = idCase.checked; listeCases[i].checked = idCase.checked;
} }
// calculer et afficher le total // calculer et afficher le total
var listeMontants = fieldset.querySelectorAll("span.montant"); let listeMontants = fieldset.querySelectorAll("span.montant");
calculerTotal(listeCases, listeMontants, idTotal); calculerTotal(listeCases, listeMontants, idTotal);
// changer le message
if (changer) { changerMessage(idCase.nextElementSibling, idCase); }
} }
/** /**
* Fonction appelée quand on ()coche la case d'un versement * Fonction appelée quand on ()coche la case d'un versement
* Faire le total des cases cochées et l'afficher * Faire le total des cases cochées et l'afficher
* *
* @param id de la case qui a été cochée * @param {HTMLInputElement} idCase id de la case qui a été cochée
* @param id de l'élément afficher le total * @param {HTMLSpanElement} idTotal id de l'élément afficher le total
*/ */
function cocherDecocherVersement(idCase, idTotal) function cocherDecocherVersement(idCase, idTotal)
{ {
var fieldset = idCase.closest("fieldset"); let fieldset = idCase.closest("fieldset");
var listeCases = fieldset.querySelectorAll("input[type=checkbox]"); let listeCases = fieldset.querySelectorAll("input[type=checkbox]");
var listeMontants = fieldset.querySelectorAll("span.montant"); let listeMontants = fieldset.querySelectorAll("span.montant");
calculerTotal(listeCases, listeMontants, idTotal); calculerTotal(listeCases, listeMontants, idTotal);
} }
/** /**
* Faire le total des cases cochées et l'afficher * Faire le total des cases cochées et l'afficher
* @param listes des cases * @param {NodeListOf<Element>} listeCases liste des cases
* @param listes des montants associés * @param {NodeListOf<Element>} listeMontants liste des montants associés
* @param id de l'élément afficher le total * @param {HTMLSpanElement} idTotal id de l'élément afficher le total
*/ */
function calculerTotal(listeCases, listeMontants, idTotal) function calculerTotal(listeCases, listeMontants, idTotal)
{ {
var total = 0; let total = 0;
for (var i = 1; i < listeCases.length; ++i) for (let i = 0; i < listeCases.length; ++i)
{ {
if (listeCases[i].checked) { if (listeCases[i].checked) {
total += parseFloat(listeMontants[i-1].textContent.replace(/\s/g, "")); total += parseFloat(listeMontants[i].textContent.replace(/\s/g, ""));
} }
} }
// "afficher" le total // afficher le total
idTotal.innerHTML = idTotal.innerHTML =
total.toLocaleString('fr-FR', {style: 'currency', currency: 'EUR', total.toLocaleString('fr-FR', {style: 'currency', currency: 'EUR',
minimumFractionDigits: 2}); minimumFractionDigits: 2});
@ -105,7 +107,9 @@ function calculerTotal(listeCases, listeMontants, idTotal)
/** /**
* changer le message en fonction de l'état coché de la case * changer le message en fonction de l'état coché de la case
*/ * @param {Element} message
* @param {HTMLInputElement} idCase
*/
function changerMessage(message, idCase) function changerMessage(message, idCase)
{ {
if (idCase.checked) { if (idCase.checked) {
@ -118,13 +122,13 @@ function changerMessage(message, idCase)
/** /**
* fonction appelée lors de la validation du formulaire * fonction appelée lors de la validation du formulaire
* @return vrai si au moins un choix a été fait * @return vrai si au moins un choix a été fait
* @param : formulaire * @param {HTMLFormElement} formulaire
*/ */
function verifierChoix(formulaire) function verifierChoix(formulaire)
{ {
var listeCheck = formulaire.getElementsByTagName("input"); let listeCheck = formulaire.getElementsByTagName("input");
var ok = false; let ok = false;
for (var i = 1; i < listeCheck.length; ++i) for (let i = 1; i < listeCheck.length; ++i)
{ {
if (listeCheck[i].checked) if (listeCheck[i].checked)
{ {
@ -139,39 +143,55 @@ function verifierChoix(formulaire)
return ok; return ok;
} }
/**
* afficher et masquer des portions de formulaire selon l'action
* @param {HTMLFormElement} formulaire
* @param {string} action après envoi du formulaire
* @param {any} nomClasse1 classe des éléments à afficher
* @param {any} nomClasse2 classe des éléments à masquer
*/
function choixMethodeGeneration(formulaire, action, nomClasse1, nomClasse2) function choixMethodeGeneration(formulaire, action, nomClasse1, nomClasse2)
{ {
formulaire.setAttribute('action', 'action.php?action=' + action); formulaire.setAttribute('action', 'action.php?action=' + action);
afficherMasquer(formulaire, nomClasse1, nomClasse2); afficherMasquer(formulaire, nomClasse1, nomClasse2);
} }
/**
* afficher et masquer des portions de formulaire
* @param {HTMLFormElement} formulaire
* @param {any} nomClasse1 classe des éléments à afficher
* @param {any} nomClasse2 classe des éléments à masquer
*/
function afficherMasquer(formulaire, nomClasse1, nomClasse2) function afficherMasquer(formulaire, nomClasse1, nomClasse2)
{ {
for (var elem of formulaire.querySelectorAll(nomClasse1)) { for (let elem of formulaire.querySelectorAll(nomClasse1)) {
elem.classList.remove('hidden'); elem.classList.remove('hidden');
} }
for (var elem of formulaire.querySelectorAll(nomClasse2)) { for (let elem of formulaire.querySelectorAll(nomClasse2)) {
elem.classList.add('hidden'); elem.classList.add('hidden');
} }
} }
// vérifier /**
// - qu'au moins une activité/tarif est sélectionnée * vérifier
// - qu'un radio de chaque activité/tarif sélectionné a été sélectionné :) * - qu'au moins une activité/tarif est sélectionnée
* - qu'un radio de chaque activité/tarif sélectionné a été sélectionné :)
* @param {string} idElem id du conteneur des cases à vérifier
*/
function verifierCases(idElem) function verifierCases(idElem)
{ {
var div = document.getElementById(idElem); let div = document.getElementById(idElem);
var nbChoix = 0; let nbChoix = 0;
// parcourir les cases à cocher // parcourir les cases à cocher
for (var idCase of div.querySelectorAll("input[type=checkbox]")) for (let idCase of div.querySelectorAll("input[type=checkbox]"))
{ {
if (idCase.checked) { if (idCase.checked) {
++nbChoix; ++nbChoix;
// vérifier qu'un radio de la même ligne est sélectionné // vérifier qu'un radio de la même ligne est sélectionné
var ligneCorrecte = false; let ligneCorrecte = false;
// trouver la ligne englobante // trouver la ligne englobante
var ligne = idCase.closest("tr"); let ligne = idCase.closest("tr");
for (var idRadio of ligne.querySelectorAll('input[type=radio]')) for (let idRadio of ligne.querySelectorAll('input[type=radio]'))
{ {
if (idRadio.checked) { ligneCorrecte = true; break; } if (idRadio.checked) { ligneCorrecte = true; break; }
} }
@ -187,11 +207,14 @@ function verifierCases(idElem)
return nbChoix != 0; return nbChoix != 0;
} }
// vérifier qu'un radio a été sélectionné dans la div paramètre /**
* vérifier qu'un radio a été sélectionné dans la div paramètre
* @param {string} idElem id du conteneur des radios à vérifier
*/
function verifierRadio(idElem) function verifierRadio(idElem)
{ {
var div = document.getElementById(idElem); let div = document.getElementById(idElem);
for (var idRadio of div.querySelectorAll('input[type=radio]')) for (let idRadio of div.querySelectorAll('input[type=radio]'))
{ {
if (idRadio.checked) { return true; } if (idRadio.checked) { return true; }
} }
@ -199,12 +222,18 @@ function verifierRadio(idElem)
return false; return false;
} }
/**
* 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) function montrerMasquerDetails(idElem, classe, texte)
{ {
var lesDetails = document.querySelectorAll(classe); let lesDetails = document.querySelectorAll(classe);
if (lesDetails.length > 0) if (lesDetails.length > 0)
{ {
var leBouton = document.getElementById(idElem); let leBouton = document.getElementById(idElem);
if (leBouton.textContent.startsWith('Replier')) if (leBouton.textContent.startsWith('Replier'))
{ {
// masquer // masquer

View File

@ -32,7 +32,8 @@ summary.personne
padding-top : 0; padding-top : 0;
padding-bottom : 0; padding-bottom : 0;
} }
h3.personne, h4.personne { h3.personne, h4.personne
{
font-weight : normal; font-weight : normal;
background: rgba(var(--gSecondColor), 0.25); background: rgba(var(--gSecondColor), 0.25);
} }