modernisation code

FossilOrigin-Name: 3f69a7f4de9baf3dec9ba1b83b2affdfaaa5337c424d31a5298dfc39913e1cd7
This commit is contained in:
engel 2022-04-27 11:42:45 +00:00
parent 4b4cd91110
commit 9b20a54f43
2 changed files with 113 additions and 69 deletions

View File

@ -9,9 +9,9 @@ class Utils
{ {
/** /**
* @return tarifs demandés * @return tarifs demandés
* @param array $tarifs * @param $tarifs
*/ */
public static function getTarifs($tarifs) public static function getTarifs(array $tarifs) : array
{ {
$db = DB::getInstance(); $db = DB::getInstance();
$sql = sprintf( $sql = sprintf(
@ -24,9 +24,9 @@ class Utils
/** /**
* @return activités correspondant aux tarifs demandés * @return activités correspondant aux tarifs demandés
* @param array $tarifs * @param $tarifs
*/ */
public static function getActivites($tarifs) public static function getActivites(array $tarifs) : array
{ {
$db = DB::getInstance(); $db = DB::getInstance();
$sql = sprintf( $sql = sprintf(
@ -42,9 +42,9 @@ class Utils
/** /**
* @return versements correspondants à l'année donnée * @return versements correspondants à l'année donnée
* @param $annee * @param $annee
* @param array $champsNom : liste non vide des champs de nom/prénom * @param $champsNom : liste non vide des champs de nom/prénom
*/ */
public static function getVersementsPersonnes($annee, $champsNom) public static function getVersementsPersonnes($annee, array $champsNom) : array
{ {
$db = DB::getInstance(); $db = DB::getInstance();
$tri = Utils::combinerTri($champsNom); $tri = Utils::combinerTri($champsNom);
@ -74,10 +74,12 @@ class Utils
* @return versements correspondants à l'année et aux tarifs donnés * @return versements correspondants à l'année et aux tarifs donnés
* triés par tarif, nom, date * triés par tarif, nom, date
* @param $annee * @param $annee
* @param array $tarifs * @param $tarifs
* @param array $champsNom : liste non vide des champs de nom/prénom * @param $champsNom : liste non vide des champs de nom/prénom
*/ */
public static function getVersementsTarifs($annee, $tarifs, $champsNom) public static function getVersementsTarifs($annee,
array $tarifs,
array $champsNom) : array
{ {
$db = DB::getInstance(); $db = DB::getInstance();
$tri = Utils::combinerTri($champsNom); $tri = Utils::combinerTri($champsNom);
@ -111,10 +113,12 @@ class Utils
/** /**
* @return versements correspondants à l'année et aux comptes donnés * @return versements correspondants à l'année et aux comptes donnés
* @param $annee * @param $annee
* @param array $comptes * @param $comptes
* @param array $champsNom : liste non vide des champs de nom/prénom * @param $champsNom : liste non vide des champs de nom/prénom
*/ */
public static function getVersementsComptes($annee, $comptes, $champsNom) public static function getVersementsComptes($annee,
array $comptes,
array $champsNom) : array
{ {
$db = DB::getInstance(); $db = DB::getInstance();
$tri = Utils::combinerTri($champsNom); $tri = Utils::combinerTri($champsNom);
@ -147,9 +151,9 @@ class Utils
/** /**
* Versements totaux par personne pour une année donnée * Versements totaux par personne pour une année donnée
* @param année * @param année
* @param array $champsNom : liste non vide des champs de nom/prénom * @param $champsNom : liste non vide des champs de nom/prénom
*/ */
public static function getVersementsTotaux($annee, $champsNom) public static function getVersementsTotaux($annee, array $champsNom) : array
{ {
$tri = Utils::combinerTri($champsNom); $tri = Utils::combinerTri($champsNom);
$sql = sprintf( $sql = sprintf(
@ -181,10 +185,10 @@ class Utils
/** /**
* combiner les champs avec un opérateur * combiner les champs avec un opérateur
* @param array $champs : liste (non vide) de champs * @param $champs : liste (non vide) de champs
* @return chaîne combinée * @return chaîne combinée
*/ */
private static function combinerChamps($champs) private static function combinerChamps(array $champs) : string
{ {
$op = ' || " " || '; $op = ' || " " || ';
$result = 'ifnull(membres.' . $champs[0] . ', "")'; $result = 'ifnull(membres.' . $champs[0] . ', "")';
@ -195,7 +199,12 @@ class Utils
return $result; return $result;
} }
private static function combinerTri($champs) /**
* combiner les clés de tri
* @param clés de tri
* @return chaîne combinée
*/
private static function combinerTri(array $champs) : string
{ {
$tri = 'membres.' . $champs[0]; $tri = 'membres.' . $champs[0];
for ($i = 1; $i < count($champs); ++$i) for ($i = 1; $i < count($champs); ++$i)
@ -208,9 +217,9 @@ class Utils
/** /**
* @return personnes ayant versé des dons pour une année donnée * @return personnes ayant versé des dons pour une année donnée
* @param $annee * @param $annee
* @param array $champsNom : champs qui définissent le nom et le prénom d'une personne * @param $champsNom : champs qui définissent le nom et le prénom d'une personne
*/ */
public static function getDonateurs($annee, $champsNom) : array public static function getDonateurs($annee, array $champsNom) : array
{ {
// concaténer les champs nom/prénoms pour la sélection // concaténer les champs nom/prénoms pour la sélection
$nom = 'trim(' . Utils::combinerChamps($champsNom) . ') as nom,'; $nom = 'trim(' . Utils::combinerChamps($champsNom) . ') as nom,';
@ -254,7 +263,10 @@ class Utils
return $donateurs; return $donateurs;
} }
public static function getLignesReduction($lesTaux) /**
* renvoie un tableau avec les remarques de chaque taux de réduction
*/
public static function getLignesReduction(array $lesTaux) : array
{ {
foreach ($lesTaux as $elem) foreach ($lesTaux as $elem)
{ {
@ -269,13 +281,14 @@ class Utils
} }
return $lignes; return $lignes;
} }
public static function getLigneReduction($taux) public static function getLigneReduction($taux)
{ {
return $_SESSION['ligneReduction'][$taux]; return $_SESSION['ligneReduction'][$taux];
} }
/** /**
* @return liste de toutes les activités, tarifs et comptes associés * @return array liste de toutes les activités, tarifs et comptes associés
*/ */
public static function getActivitesTarifsEtComptes() public static function getActivitesTarifsEtComptes()
{ {
@ -297,7 +310,7 @@ class Utils
} }
/** /**
* @return liste des années fiscales * @return array liste des années fiscales
*/ */
public static function getAnneesFiscales() : array public static function getAnneesFiscales() : array
{ {
@ -317,7 +330,7 @@ class Utils
* récupérer dans la config du plugin les champs des membres * récupérer dans la config du plugin les champs des membres
* utilisés pour le nom et le prénom ; ajouter/supprimer les * utilisés pour le nom et le prénom ; ajouter/supprimer les
* modifications par rapport à la config garradin * modifications par rapport à la config garradin
* @return tableau des champs : clé = nom, valeur = { titre, position } * @return array tableau des champs : clé = nom, valeur = { titre, position }
*/ */
public static function getChampsNom($config, $plugin) : array public static function getChampsNom($config, $plugin) : array
{ {

View File

@ -3,16 +3,16 @@
/** /**
* 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
@ -21,22 +21,27 @@ 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 idCase = lesPersonnes[j].closest("summary").querySelector("input"); let idCase = lesPersonnes[j].closest("summary").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); cocherDecocherPersonne(idCase, idTotal);
@ -47,21 +52,20 @@ 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
*/ */
function cocherDecocherPersonne(idCase, idTotal) 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);
} }
@ -69,27 +73,27 @@ function cocherDecocherPersonne(idCase, idTotal)
* 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 = 0; i < listeCases.length; ++i) for (let i = 0; i < listeCases.length; ++i)
{ {
if (listeCases[i].checked) { if (listeCases[i].checked) {
total += parseFloat(listeMontants[i].textContent.replace(/\s/g, "")); total += parseFloat(listeMontants[i].textContent.replace(/\s/g, ""));
@ -103,6 +107,8 @@ 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)
{ {
@ -116,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)
{ {
@ -137,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; }
} }
@ -185,24 +207,33 @@ 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; }
} }
alert("Erreur : il faut sélectionner un taux de réduction"); alert("Erreur : il faut sélectionner un taux de réduction");
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