2022-02-03 11:05:01 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Garradin;
|
|
|
|
|
2022-03-24 19:00:39 +01:00
|
|
|
use Garradin\Files\Files;
|
|
|
|
use Garradin\Entities\Files\File;
|
|
|
|
|
2022-02-22 10:47:54 +01:00
|
|
|
use Garradin\Plugin\RecusFiscaux\RecusHTML;
|
2022-02-03 11:05:01 +01:00
|
|
|
use Garradin\Plugin\RecusFiscaux\Utils;
|
|
|
|
use Garradin\Plugin\RecusFiscaux\Personne;
|
|
|
|
|
|
|
|
// récupérer les lignes sélectionnées
|
|
|
|
$lesLignes = f('selected');
|
|
|
|
|
|
|
|
// filtrer les versements sélectionnés
|
|
|
|
$versementsSelectionnes = array();
|
2022-02-17 10:21:33 +01:00
|
|
|
foreach ($lesLignes as $ligne) {
|
2022-03-24 19:00:39 +01:00
|
|
|
$versementsSelectionnes[] = $_SESSION['lesVersements'][$ligne];
|
2022-02-03 11:05:01 +01:00
|
|
|
}
|
|
|
|
|
2022-03-24 19:00:39 +01:00
|
|
|
// cumuler les versements d'une personne : id => Personne
|
|
|
|
$totalPersonnes = cumulerVersements($versementsSelectionnes);
|
|
|
|
|
2022-03-23 11:00:37 +01:00
|
|
|
// informations pour les reçus
|
2022-03-24 19:00:39 +01:00
|
|
|
$nomAsso = $config->get('nom_asso');
|
|
|
|
$adresseAsso = $config->get('adresse_asso');
|
2022-02-24 11:28:08 +01:00
|
|
|
$signature =
|
2022-03-24 19:00:39 +01:00
|
|
|
(null !== $plugin->getConfig('signature'))
|
|
|
|
?
|
|
|
|
Files::get($plugin->getConfig('signature'))->fullpath()
|
|
|
|
:
|
2022-03-04 11:11:00 +01:00
|
|
|
"";
|
2022-03-23 11:00:37 +01:00
|
|
|
// logo
|
2022-03-24 19:00:39 +01:00
|
|
|
$logo_file = Files::get(File::CONTEXT_CONFIG . '/logo.png');
|
2022-03-23 11:00:37 +01:00
|
|
|
$logoAsso =
|
2022-03-24 19:00:39 +01:00
|
|
|
(null !== $logo_file)
|
|
|
|
?
|
|
|
|
Files::get($logo_file->path)->fullpath()
|
|
|
|
:
|
|
|
|
"";
|
2022-02-24 11:28:08 +01:00
|
|
|
|
2022-02-25 15:51:48 +01:00
|
|
|
// articles du CGI
|
|
|
|
$articlesCGI = array();
|
|
|
|
foreach ($plugin->getConfig('articlesCGI') as $article)
|
|
|
|
{
|
|
|
|
if ($article->valeur == 1) {
|
|
|
|
$articlesCGI[] = $article->titre;
|
|
|
|
}
|
|
|
|
}
|
2022-03-24 19:00:39 +01:00
|
|
|
|
2022-02-25 15:51:48 +01:00
|
|
|
$listeFichiers = array(); // fichiers pdf générés
|
2022-03-24 19:00:39 +01:00
|
|
|
foreach ($totalPersonnes as $idPersonne => $personne)
|
2022-02-19 20:06:22 +01:00
|
|
|
{
|
2022-02-03 11:05:01 +01:00
|
|
|
// générer un fichier par reçu
|
2022-02-22 11:26:45 +01:00
|
|
|
$html = new RecusHTML(
|
2022-02-03 11:05:01 +01:00
|
|
|
$nomAsso,
|
|
|
|
$adresseAsso,
|
2022-03-23 11:00:37 +01:00
|
|
|
$logoAsso,
|
2022-02-19 20:06:22 +01:00
|
|
|
$plugin->getConfig('objet_asso'),
|
2022-02-25 15:51:48 +01:00
|
|
|
$plugin->getConfig('nom_responsable'),
|
|
|
|
$plugin->getConfig('fonction_responsable'),
|
2022-03-17 16:00:35 +01:00
|
|
|
$plugin->getConfig('ville_asso'),
|
2022-02-25 15:51:48 +01:00
|
|
|
$articlesCGI,
|
2022-02-03 11:05:01 +01:00
|
|
|
$signature
|
|
|
|
);
|
2022-02-19 20:06:22 +01:00
|
|
|
|
2022-02-03 11:05:01 +01:00
|
|
|
// extraire les montants des versements
|
2022-03-24 19:00:39 +01:00
|
|
|
$lesMontants = array();
|
|
|
|
foreach ($personne->versements as $versement)
|
|
|
|
{
|
|
|
|
if (array_key_exists($versement->tauxReduction, $lesMontants)) {
|
|
|
|
$lesMontants[$versement->tauxReduction] += $versement->montant;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$lesMontants[$versement->tauxReduction] = $versement->montant;
|
|
|
|
}
|
|
|
|
}
|
2022-02-22 11:26:45 +01:00
|
|
|
$html->imprimer_recu(
|
2022-02-03 11:05:01 +01:00
|
|
|
$_SESSION['annee_recu'],
|
2022-02-22 11:26:45 +01:00
|
|
|
$personne->id,
|
|
|
|
$personne->nomPrenom,
|
2022-02-18 12:51:13 +01:00
|
|
|
$lesMontants,
|
2022-02-22 11:26:45 +01:00
|
|
|
$personne->adresse,
|
|
|
|
$personne->codePostal,
|
|
|
|
$personne->ville
|
2022-02-03 11:05:01 +01:00
|
|
|
);
|
2022-02-19 20:06:22 +01:00
|
|
|
// fabriquer le fichier PDF
|
2022-02-22 11:26:45 +01:00
|
|
|
$nomPDF = \Garradin\Utils::filePDF($html->get());
|
2022-02-22 10:47:54 +01:00
|
|
|
// changer le nom du fichier
|
2022-02-22 11:26:45 +01:00
|
|
|
$nom = str_replace(' ', '_', $personne->nomPrenom);
|
2022-02-22 10:47:54 +01:00
|
|
|
$nom = str_replace("'", "", $nom);
|
|
|
|
$nomFichier = "recu_" . $_SESSION['annee_recu'] . "_" . $nom . ".pdf";
|
|
|
|
rename($nomPDF, $nomFichier);
|
2022-02-03 11:05:01 +01:00
|
|
|
// ajouter le nom du fichier à la liste pour mettre dans une archive
|
|
|
|
$listeFichiers[] = $nomFichier;
|
|
|
|
}
|
2022-02-19 20:06:22 +01:00
|
|
|
|
2022-02-03 11:05:01 +01:00
|
|
|
// faire une archive zip
|
|
|
|
$fichierZip = Utils::makeArchive(
|
|
|
|
$listeFichiers,
|
|
|
|
$_SESSION['annee_recu'],
|
|
|
|
PLUGIN_ROOT . "/zip"
|
|
|
|
);
|
2022-03-24 19:00:39 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Cumuler les versements de chaque personne
|
|
|
|
* @param tableau des versements triés par idUser, date
|
|
|
|
* @return tableau des versements cumulés : id => Personne
|
|
|
|
*/
|
|
|
|
function cumulerVersements($versements)
|
|
|
|
{
|
|
|
|
$totalPersonnes = array();
|
|
|
|
$idPersonneCourant = -1;
|
|
|
|
$totalVersements = 0;
|
|
|
|
foreach ($versements as $ligne)
|
|
|
|
{
|
|
|
|
if ($ligne->idUser != $idPersonneCourant)
|
|
|
|
{
|
|
|
|
// changement de personne
|
|
|
|
if ($idPersonneCourant != -1)
|
|
|
|
{
|
|
|
|
$totalPersonnes[$idPersonneCourant]->ajouterVersement(
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
$totalVersements/100,
|
|
|
|
$_SESSION['taux_reduction']
|
|
|
|
);
|
|
|
|
}
|
|
|
|
$idPersonneCourant = $ligne->idUser;
|
|
|
|
$totalVersements = $ligne->versement;
|
|
|
|
// créer les infos de la personne, sauf si elle est déjà présente
|
|
|
|
if (!array_key_exists($idPersonneCourant, $totalPersonnes))
|
|
|
|
{
|
2022-03-25 11:27:03 +01:00
|
|
|
$totalPersonnes["$idPersonneCourant"] = $_SESSION['membresDonateurs'][$ligne->idUser]->clone();
|
2022-03-24 19:00:39 +01:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
// cumuler versements
|
|
|
|
$totalVersements += $ligne->versement;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// et le dernier
|
|
|
|
$totalPersonnes[$idPersonneCourant]->ajouterVersement(
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
$totalVersements/100,
|
|
|
|
$_SESSION['taux_reduction']
|
|
|
|
);
|
|
|
|
return $totalPersonnes;
|
|
|
|
}
|