2022-01-29 15:03:41 +01:00
|
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
namespace Garradin;
|
|
|
|
|
|
2022-02-22 10:47:54 +01:00
|
|
|
|
use Garradin\Plugin\RecusFiscaux\RecusHTML;
|
2022-01-29 15:03:41 +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-01-29 15:03:41 +01:00
|
|
|
|
$versementsSelectionnes[] = $_SESSION['lesVersements'][$ligne];
|
|
|
|
|
}
|
|
|
|
|
// cumuler les versements d'une personne
|
|
|
|
|
$totalPersonnes = cumulerVersements($versementsSelectionnes);
|
|
|
|
|
|
2022-03-10 18:23:34 +01:00
|
|
|
|
// informations de l'association
|
2022-01-29 15:03:41 +01:00
|
|
|
|
$nomAsso = Utils::getNomAsso();
|
|
|
|
|
$adresseAsso = Utils::getAdresseAsso();
|
2022-02-25 13:23:30 +01:00
|
|
|
|
$signature =
|
|
|
|
|
(null !== $plugin->getConfig('signature')) ?
|
|
|
|
|
\Garradin\Files\Files::get($plugin->getConfig('signature'))->fullpath() :
|
2022-03-04 11:11:00 +01:00
|
|
|
|
"";
|
2022-03-10 18:23:34 +01:00
|
|
|
|
$objetAsso = $plugin->getConfig('objet_asso');
|
|
|
|
|
$nomResponsable = $plugin->getConfig('nom_responsable');
|
|
|
|
|
$fonctionResponsable = $plugin->getConfig('fonction_responsable');
|
2022-02-25 13:23:30 +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-10 18:23:34 +01:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* insérer une feuille de style
|
|
|
|
|
*/
|
|
|
|
|
$tpl->register_function('ajouter_style', function()
|
|
|
|
|
{
|
|
|
|
|
$out = '
|
|
|
|
|
@page
|
|
|
|
|
{
|
|
|
|
|
size: A4 portrait;
|
|
|
|
|
margin: 1cm;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
body
|
|
|
|
|
{
|
|
|
|
|
font-family: Serif;
|
|
|
|
|
font-size: 11pt;
|
|
|
|
|
background-color: white;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#logoCerfa
|
|
|
|
|
{
|
|
|
|
|
line-height: 40px;
|
|
|
|
|
width: 100px;
|
|
|
|
|
background-color: rgb(0, 0, 128);
|
|
|
|
|
border-radius : 50%;
|
|
|
|
|
text-align : center;
|
|
|
|
|
margin : 2mm;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.centre
|
|
|
|
|
{
|
|
|
|
|
display : inline-block;
|
|
|
|
|
vertical-align : middle;
|
|
|
|
|
line-height: 20px; /* moitié de la hauteur du logo */
|
|
|
|
|
color : white;
|
|
|
|
|
font-weight: bold;
|
|
|
|
|
font-size : 14pt;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#numCerfa
|
|
|
|
|
{
|
|
|
|
|
width: 100px; /* largeur du logo */
|
|
|
|
|
text-align: center;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#titre
|
|
|
|
|
{
|
|
|
|
|
margin : 0 4cm 0 4cm;
|
|
|
|
|
text-align : center;
|
|
|
|
|
font-size : 14pt;
|
|
|
|
|
font-weight: bold;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#articles
|
|
|
|
|
{
|
|
|
|
|
margin : 0 4cm 0 4cm; /* idem titre */
|
|
|
|
|
text-align : center;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#numRecu
|
|
|
|
|
{
|
|
|
|
|
text-align : right;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#final
|
|
|
|
|
{
|
|
|
|
|
height : 5cm;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.rubrique
|
|
|
|
|
{
|
|
|
|
|
background-color : rgb(200, 200, 250);
|
|
|
|
|
padding : 2mm;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.cartouche
|
|
|
|
|
{
|
|
|
|
|
margin : 2mm auto;
|
|
|
|
|
padding : 0 2mm;
|
|
|
|
|
border : 1px solid rgb(0, 0, 128);
|
|
|
|
|
border-radius : 8px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.titre, .important
|
|
|
|
|
{
|
|
|
|
|
font-weight:bold;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#signature
|
|
|
|
|
{
|
|
|
|
|
display: block;
|
|
|
|
|
max-width : 7cm;
|
|
|
|
|
max-height : 2cm;
|
|
|
|
|
margin: 0 auto;
|
|
|
|
|
padding-bottom : 2mm;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#fonction, #nom
|
|
|
|
|
{
|
|
|
|
|
text-align : center;
|
|
|
|
|
}
|
|
|
|
|
';
|
|
|
|
|
return $out;
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* imprimer un montant et le taux de réduction associé
|
|
|
|
|
* @param montant
|
|
|
|
|
* @param taux
|
|
|
|
|
*/
|
|
|
|
|
$tpl->register_function('imprimer_montant', function ($params)
|
|
|
|
|
{
|
|
|
|
|
$montant = $params['montant'];
|
|
|
|
|
$taux = $params['taux'];
|
|
|
|
|
$valeur = number_format($montant, 2, ',', '');
|
|
|
|
|
$libelle = Utils::getLigneReduction($taux);
|
|
|
|
|
$out = sprintf('
|
|
|
|
|
<li>la somme de <b>%s euros</b>',
|
|
|
|
|
$valeur);
|
|
|
|
|
if ($libelle != "") {
|
|
|
|
|
$out .= sprintf(' (%s)', $libelle);
|
|
|
|
|
}
|
|
|
|
|
$out .= '
|
|
|
|
|
</li>
|
|
|
|
|
';
|
|
|
|
|
return $out;
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* imprimer les articles du code général des impôts concernés
|
|
|
|
|
* @param articles
|
|
|
|
|
*/
|
|
|
|
|
$tpl->register_function('imprimer_articles', function ($params)
|
|
|
|
|
{
|
|
|
|
|
$articlesCGI = $params['articles'];
|
|
|
|
|
$nbArticles = count($articlesCGI);
|
|
|
|
|
$out = "<p>Le bénéficiaire certifie sur l’honneur que les dons et versements qu’il reçoit ouvrent droit à la réduction d'impôt prévue";
|
|
|
|
|
if ($nbArticles == 1)
|
|
|
|
|
{
|
|
|
|
|
$out .= sprintf(' à l’article %s du code général des impôts</p>', articlesCGI[0]);
|
|
|
|
|
}
|
|
|
|
|
else if ($nbArticles > 1)
|
|
|
|
|
{
|
|
|
|
|
$out .= " aux articles ";
|
|
|
|
|
for ($i = 0; $i < $nbArticles; ++$i) {
|
|
|
|
|
$out .= sprintf("%s", $articlesCGI[$i]);
|
|
|
|
|
if ($i < $nbArticles - 2) {
|
|
|
|
|
$out .= ", ";
|
|
|
|
|
}
|
|
|
|
|
else if ($i == $nbArticles - 2) {
|
|
|
|
|
$out .= " et ";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
$out .= " du code général des impôts.</p>";
|
|
|
|
|
}
|
|
|
|
|
return $out;
|
|
|
|
|
});
|
|
|
|
|
|
2022-02-25 15:51:48 +01:00
|
|
|
|
$listeFichiers = array(); // fichiers pdf générés
|
2022-02-22 10:47:54 +01:00
|
|
|
|
foreach ($totalPersonnes as $idPersonne => $personne)
|
|
|
|
|
{
|
2022-01-29 15:03:41 +01:00
|
|
|
|
// extraire les montants des versements
|
|
|
|
|
$lesMontants = array();
|
2022-02-18 12:51:13 +01:00
|
|
|
|
foreach ($personne->versements as $versement)
|
|
|
|
|
{
|
|
|
|
|
if (array_key_exists($versement->tauxReduction, $lesMontants)) {
|
|
|
|
|
$lesMontants[$versement->tauxReduction] += $versement->montant;
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
$lesMontants[$versement->tauxReduction] = $versement->montant;
|
|
|
|
|
}
|
2022-01-29 15:03:41 +01:00
|
|
|
|
}
|
2022-03-10 18:23:34 +01:00
|
|
|
|
$tpl->assign(compact('nomAsso',
|
|
|
|
|
'adresseAsso',
|
|
|
|
|
'objetAsso',
|
|
|
|
|
'nomResponsable',
|
|
|
|
|
'fonctionResponsable',
|
|
|
|
|
'articlesCGI',
|
|
|
|
|
'signature'
|
|
|
|
|
));
|
|
|
|
|
|
|
|
|
|
$tpl->assign('anneeRecu', $_SESSION['annee_recu']);
|
|
|
|
|
$tpl->assign('numero', $personne->id);
|
|
|
|
|
$tpl->assign('nom', $personne->nomPrenom);
|
|
|
|
|
$tpl->assign('lesMontants', $lesMontants);
|
|
|
|
|
$tpl->assign('adresse', $personne->adresse);
|
|
|
|
|
$tpl->assign('codePostal', $personne->codePostal);
|
|
|
|
|
$tpl->assign('ville', $personne->ville);
|
|
|
|
|
// $tpl->assign('styleSheet', 'pdf.css');
|
|
|
|
|
|
|
|
|
|
ob_start();
|
|
|
|
|
$tpl->display(PLUGIN_ROOT . '/templates/recuHTML.tpl');
|
|
|
|
|
$html = ob_get_clean();
|
|
|
|
|
|
2022-02-19 20:06:22 +01:00
|
|
|
|
// fabriquer le fichier PDF
|
2022-03-10 18:23:34 +01:00
|
|
|
|
$nomPDF = \Garradin\Utils::filePDF($html);
|
2022-02-22 10:47:54 +01:00
|
|
|
|
// changer le nom du fichier
|
|
|
|
|
$nom = str_replace(' ', '_', $personne->nomPrenom);
|
|
|
|
|
$nom = str_replace("'", "", $nom);
|
|
|
|
|
$nomFichier = "recu_" . $_SESSION['annee_recu'] . "_" . $nom . ".pdf";
|
|
|
|
|
rename($nomPDF, $nomFichier);
|
2022-01-29 15:03:41 +01:00
|
|
|
|
// ajouter le nom du fichier à la liste pour mettre dans une archive
|
|
|
|
|
$listeFichiers[] = $nomFichier;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// faire une archive zip
|
|
|
|
|
$fichierZip = Utils::makeArchive(
|
|
|
|
|
$listeFichiers,
|
|
|
|
|
$_SESSION['annee_recu'],
|
|
|
|
|
PLUGIN_ROOT . "/zip"
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
/**
|
2022-02-10 17:05:24 +01:00
|
|
|
|
* Cumuler les versements de chaque personne par tarif
|
2022-02-17 10:21:33 +01:00
|
|
|
|
* @param tableau des versements triés par idTarif, idUser, date
|
|
|
|
|
* @return tableau des versements cumulés : id => Personne
|
2022-01-29 15:03:41 +01:00
|
|
|
|
*/
|
|
|
|
|
function cumulerVersements($versements)
|
|
|
|
|
{
|
|
|
|
|
$totalPersonnes = array();
|
|
|
|
|
$idTarif_courant = -1;
|
|
|
|
|
$idPersonne_courant = -1;
|
|
|
|
|
$totalVersements = 0;
|
2022-02-18 12:51:13 +01:00
|
|
|
|
foreach ($versements as $ligne)
|
|
|
|
|
{
|
2022-01-29 15:03:41 +01:00
|
|
|
|
if (
|
|
|
|
|
$ligne->idTarif != $idTarif_courant ||
|
|
|
|
|
$ligne->idUser != $idPersonne_courant
|
2022-02-18 12:51:13 +01:00
|
|
|
|
)
|
|
|
|
|
{
|
2022-02-10 17:05:24 +01:00
|
|
|
|
if ($idTarif_courant != -1) {
|
2022-02-18 12:51:13 +01:00
|
|
|
|
$totalPersonnes[$idPersonne_courant]->ajouterVersement(
|
2022-02-10 17:05:24 +01:00
|
|
|
|
$_SESSION['lesTarifs'][$idTarif_courant]->idActivite,
|
2022-01-29 15:03:41 +01:00
|
|
|
|
$idTarif_courant,
|
2022-02-18 12:51:13 +01:00
|
|
|
|
$totalVersements/100,
|
|
|
|
|
$_SESSION['tauxSelectionnes'][$idTarif_courant]
|
2022-01-29 15:03:41 +01:00
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
$idTarif_courant = $ligne->idTarif;
|
|
|
|
|
$idPersonne_courant = $ligne->idUser;
|
|
|
|
|
$totalVersements = $ligne->versement;
|
|
|
|
|
// créer les infos de la personne, sauf si elle est déjà présente
|
2022-02-10 17:05:24 +01:00
|
|
|
|
if (!array_key_exists($idPersonne_courant, $totalPersonnes))
|
|
|
|
|
{
|
2022-02-19 14:31:04 +01:00
|
|
|
|
$totalPersonnes["$idPersonne_courant"] = $_SESSION['membresDonateurs'][$ligne->idUser]->clone();
|
2022-01-29 15:03:41 +01:00
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
// cumuler versements
|
|
|
|
|
$totalVersements += $ligne->versement;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
// et le dernier
|
2022-02-18 12:51:13 +01:00
|
|
|
|
$totalPersonnes[$idPersonne_courant]->ajouterVersement(
|
|
|
|
|
$_SESSION['lesTarifs'][$idTarif_courant]->idActivite,
|
|
|
|
|
$idTarif_courant,
|
|
|
|
|
$totalVersements/100,
|
|
|
|
|
$_SESSION['tauxSelectionnes'][$idTarif_courant]
|
|
|
|
|
);
|
2022-01-29 15:03:41 +01:00
|
|
|
|
|
|
|
|
|
return $totalPersonnes;
|
|
|
|
|
}
|