From 3713e31c9720610c8911bc0cd281a66b9c9e6615 Mon Sep 17 00:00:00 2001 From: Jean-Philippe Metivier <jean-philippe.metivier@unicaen.fr> Date: Wed, 4 Dec 2024 09:39:58 +0100 Subject: [PATCH] Emargement as template --- module/Agent/src/Entity/Db/Agent.php | 11 ++++ .../document/pdf/entete-logo-ccc.phtml | 2 +- .../formation-instance-document.config.php | 22 ++----- .../FormationInstanceDocumentController.php | 58 ++++++++++++----- .../src/Formation/Entity/Db/Seance.php | 20 ++++++ .../src/Formation/Entity/Db/Session.php | 65 ++++++++++++++++++- .../Provider/Template/PdfTemplates.php | 1 + .../Service/Seance/SeanceService.php | 2 +- .../view/formation/session/afficher.phtml | 8 +-- 9 files changed, 150 insertions(+), 39 deletions(-) diff --git a/module/Agent/src/Entity/Db/Agent.php b/module/Agent/src/Entity/Db/Agent.php index 407dd1f6..750fd318 100644 --- a/module/Agent/src/Entity/Db/Agent.php +++ b/module/Agent/src/Entity/Db/Agent.php @@ -204,6 +204,17 @@ class Agent implements return null; } + public function getStructure(): string + { + $affectation = $this->getAffectationPrincipale(); + if ($affectation === null) return 'Aucune structure connue'; + + $structure = $affectation->getStructure(); + $niveau2 = $structure->getNiv2(); + if ($structure === $niveau2) { return $structure->getLibelleLong(); } + return $niveau2->getLibelleLong() . " > ". $structure->getLibelleLong(); + } + /** @return AgentEchelon[] */ public function getEchelons(?DateTime $date = null, bool $histo = false): array { diff --git a/module/Application/view/application/document/pdf/entete-logo-ccc.phtml b/module/Application/view/application/document/pdf/entete-logo-ccc.phtml index 2fd7deef..f1d18a18 100644 --- a/module/Application/view/application/document/pdf/entete-logo-ccc.phtml +++ b/module/Application/view/application/document/pdf/entete-logo-ccc.phtml @@ -11,7 +11,7 @@ <tr> <td> <img style='height:3cm;' src='' /> - <img style='height:3cm;' src='<?php echo $image; ?>' /> + <img style='height:3cm;' src='<?php echo $image; ?>' alt="logo de l'établissement"/> </td> <td> <div style="display: inline-block; margin-right: 0;"> diff --git a/module/Formation/config/merged/formation-instance-document.config.php b/module/Formation/config/merged/formation-instance-document.config.php index 57cb7aaf..81813b31 100644 --- a/module/Formation/config/merged/formation-instance-document.config.php +++ b/module/Formation/config/merged/formation-instance-document.config.php @@ -52,8 +52,7 @@ return [ [ 'controller' => FormationInstanceDocumentController::class, 'action' => [ - 'export-emargement', - 'export-tous-emargements', + 'generer-emargement', ], 'privileges' => [ FormationinstancedocumentPrivileges::FORMATIONINSTANCEDOCUMENT_EMARGEMENT @@ -116,25 +115,14 @@ return [ ], ], ], - 'export-emargement' => [ + 'generer-emargement' => [ 'type' => Segment::class, 'options' => [ - 'route' => '/export-emargement/:journee', + 'route' => '/generer-emargement/:session[/:seance]', 'defaults' => [ - /** @see FormationInstanceDocumentController::exportEmargementAction() */ + /** @see FormationInstanceDocumentController::genererEmargementAction() */ 'controller' => FormationInstanceDocumentController::class, - 'action' => 'export-emargement', - ], - ], - ], - 'export-tous-emargements' => [ - 'type' => Segment::class, - 'options' => [ - 'route' => '/export-tous-emargements/:session', - 'defaults' => [ - /** @see FormationInstanceDocumentController::exportTousEmargementsAction() */ - 'controller' => FormationInstanceDocumentController::class, - 'action' => 'export-tous-emargements', + 'action' => 'generer-emargement', ], ], ], diff --git a/module/Formation/src/Formation/Controller/FormationInstanceDocumentController.php b/module/Formation/src/Formation/Controller/FormationInstanceDocumentController.php index 6848e465..218e494b 100644 --- a/module/Formation/src/Formation/Controller/FormationInstanceDocumentController.php +++ b/module/Formation/src/Formation/Controller/FormationInstanceDocumentController.php @@ -49,6 +49,49 @@ class FormationInstanceDocumentController extends AbstractActionController $this->etablissementInfos[$clef] = $valeur; } + /** + * @throws MpdfException + */ + public function genererEmargementAction(): ?string + { + $session = $this->getSessionService()->getRequestedSession($this); + $seance = $this->getSeanceService()->getRequestedSeance($this, 'seance'); + + if ($seance !== null) { + $seances = [$seance]; + $title = "Emargement_Session_" . $session->getId() . "_" . $seance->getId(); + } else { + $seances = $session->getSeances(); + $seances = array_filter($seances, function (Seance $seance) { + return $seance->estNonHistorise(); + }); + $title = "Emargement_Session_" . $session->getId(); + } + + + $rendus = []; + foreach ($seances as $seance) { + $vars = [ + 'session' => $session, + 'seance' => $seance, + 'MacroService' => $this->getMacroService(), + 'UrlService' => $this->getUrlService(), + ]; + $rendus[$seance->getId()] = $this->getRenduService()->generateRenduByTemplateCode(PdfTemplates::FORMATION_EMARGEMENT, $vars, false); + } + + $exporter = new PdfExporter(); + $exporter->setRenderer($this->renderer); + $exporter->getMpdf()->SetTitle($title); + $exporter->setHeaderScript('/application/document/pdf/entete-logo-ccc', null, $this->etablissementInfos); + $exporter->setFooterScript('/application/document/pdf/pied-vide'); + $exporter->getMpdf()->SetMargins(0, 0, 50); + foreach ($seances as $seance) { + $exporter->addBodyHtml($rendus[$seance->getId()]->getCorps()); + } + return $exporter->export($title); + } + public function exportEmargementAction(): void { $journee = $this->getSeanceService()->getRequestedSeance($this); @@ -76,21 +119,6 @@ class FormationInstanceDocumentController extends AbstractActionController exit; } - #[NoReturn] public function exportTousEmargementsAction(): void - { - $instance = $this->getSessionService()->getRequestedSession($this); - $journees = $instance->getSeances(); - $journees = array_filter($journees, function (Seance $a) { - return $a->estNonHistorise(); - }); - - $exporter = new EmargementPdfExporter($this->renderer, 'A4'); - $exporter->setVars([]); - $filemane = "formation_" . $instance->getFormation()->getId() . "_du_" . str_replace("/", "-", $instance->getDebut()) . "_au_" . str_replace("/", "-", $instance->getFin()) . "_emargements.pdf"; - $exporter->exportAll($journees, $filemane); - exit; - } - /** * @throws MpdfException */ diff --git a/module/Formation/src/Formation/Entity/Db/Seance.php b/module/Formation/src/Formation/Entity/Db/Seance.php index e302b841..f6c3aac5 100644 --- a/module/Formation/src/Formation/Entity/Db/Seance.php +++ b/module/Formation/src/Formation/Entity/Db/Seance.php @@ -221,4 +221,24 @@ class Seance implements HistoriqueAwareInterface, HasSourceInterface $session = $this->getInstance(); return ($session->getSeances() === null OR $session->getSeances() === [] OR $this->getDateFin()->format('d/m/Y H:i') === $session->getFin()); } + + /** + * @noinspection PhpUnused + * MACRO SEANCE#lieu + */ + public function toStringLieu(): string + { + if ($this->getLieu() === null) return "Aucun lieu connu"; + return $this->getLieu()->getBatiment(). " " .$this->getLieu()->getLibelle() . " - " . $this->getLieu()->getCampus() . " - " . $this->getLieu()->getVille(); + } + + /** + * @noinspection PhpUnused + * MACRO SEANCE#periode + */ + public function getPeriode() : string + { + if (!$this->getDateDebut() OR !$this->getDateFin()) return "Aucune période connue"; + return $this->getDateDebut()->format("d/m/Y H:i"). " au " .$this->getDateFin()->format("d/m/Y H:i"); + } } \ No newline at end of file diff --git a/module/Formation/src/Formation/Entity/Db/Session.php b/module/Formation/src/Formation/Entity/Db/Session.php index c60a72df..ab9612bc 100644 --- a/module/Formation/src/Formation/Entity/Db/Session.php +++ b/module/Formation/src/Formation/Entity/Db/Session.php @@ -638,7 +638,38 @@ class Session implements return $this->getFormation()->getId() . "/" . $this->getId(); } - /** @noinspection PhpUnused */ + /** @noinspection PhpUnused + * MACRO SESSION#inscrits */ + public function getArrayListePrincipales(): string + { + $stagiaiares = array_map(function (Inscription $i) { return $i->getIndividu(); } , $this->getListePrincipale()); + usort($stagiaiares, function ($a, $b) { return $a->getDenomination(false) <=> $b->getDenomination(false); }); + + $text = "<table class='bordered' style='width:100%;'>"; + $text .= "<thead>"; + $text .= "<tr style='border-bottom:1px solid black;'>"; + $text .= "<th style='width: 50%;'>Stagiaires </th>"; + $text .= "<th style='width: 50%;'>Signature </th>"; + $text .= "</tr>"; + $text .= "</thead>"; + $text .= "<tbody>"; + foreach ($stagiaiares as $stagiaire) { + $text .= "<tr>"; + $text .= "<td>"; + $text .= $stagiaire->getDenomination() . "<br>"; + $text .= $stagiaire->getStructure() ; + $text .= "</td>"; + $text .= "<td>" . "</td>"; + $text .= "</tr>"; + } + $text .= "</tbody>"; + $text .= "</table>"; + + return $text; + } + + /** @noinspection PhpUnused + * MACRO SESSION#formateurs*/ public function getListeFormateurs(): string { /** @var Formateur[] $formateurs */ @@ -667,6 +698,38 @@ class Session implements return $text; } + /** @noinspection PhpUnused + * MACRO SESSION#FormateursAvecSignature + **/ + public function getArrayFormateurs(): string + { + /** @var Formateur[] $formateurs */ + $formateurs = $this->getFormateurs(); + + $text = "<table class='bordered' style='width:100%;'>"; + $text .= "<thead>"; + $text .= "<tr style='border-bottom:1px solid black;'>"; + $text .= "<th style='width:50%'> Dénomination </th>"; + $text .= "<th style='width:50%'> Signature </th>"; + $text .= "</tr>"; + $text .= "</thead>"; + $text .= "<tbody>"; + foreach ($formateurs as $formateur) { + $text .= "<tr>"; + $text .= "<td>"; + $text .= $formateur->getPrenom() . " " . $formateur->getNom() . " <br>"; + $text .= $formateur->getAttachement(); + $text .= "</td>"; + $text .= "<td>"; + $text .= "</td>"; + $text .= "</tr>"; + } + $text .= "</tbody>"; + $text .= "</table>"; + + return $text; + } + /** @noinspection PhpUnused */ public function getListeJournees(): string { diff --git a/module/Formation/src/Formation/Provider/Template/PdfTemplates.php b/module/Formation/src/Formation/Provider/Template/PdfTemplates.php index 99d0026b..7542c1a4 100644 --- a/module/Formation/src/Formation/Provider/Template/PdfTemplates.php +++ b/module/Formation/src/Formation/Provider/Template/PdfTemplates.php @@ -8,4 +8,5 @@ class PdfTemplates { const FORMATION_ATTESTATION = "FORMATION_ATTESTATION"; const FORMATION_HISTORIQUE = "FORMATION_HISTORIQUE"; const FORMATION_ABSENCE = "FORMATION_ABSENCE"; + const FORMATION_EMARGEMENT = "FORMATION_EMARGEMENT"; } \ No newline at end of file diff --git a/module/Formation/src/Formation/Service/Seance/SeanceService.php b/module/Formation/src/Formation/Service/Seance/SeanceService.php index 885848e9..1d8b3d92 100644 --- a/module/Formation/src/Formation/Service/Seance/SeanceService.php +++ b/module/Formation/src/Formation/Service/Seance/SeanceService.php @@ -99,7 +99,7 @@ class SeanceService * @param integer $id * @return Seance|null */ - public function getSeance(int $id): ?Seance + public function getSeance(?int $id): ?Seance { $qb = $this->createQueryBuilder() ->andWhere('journee.id = :id') diff --git a/module/Formation/view/formation/session/afficher.phtml b/module/Formation/view/formation/session/afficher.phtml index c3544a07..7efeedee 100644 --- a/module/Formation/view/formation/session/afficher.phtml +++ b/module/Formation/view/formation/session/afficher.phtml @@ -342,8 +342,8 @@ $canMesSessions = $this->isAllowed(FormateurPrivileges::getResourceId(FormateurP <br/> <?php endif; ?> <?php if ($canEmargement): ?> - <?php /** @see FormationInstanceDocumentController::exportTousEmargementsAction() */ ?> - <a href="<?php echo $this->url('session/export-tous-emargements', ['session' => $session->getId()], [], true); ?>" + <?php /** @see FormationInstanceDocumentController::genererEmargementAction() */ ?> + <a href="<?php echo $this->url('session/generer-emargement', ['session' => $session->getId()], [], true); ?>" class="btn btn-primary" target="_blank"> <span class="icon icon-pdf"></span> Exporter les émargements @@ -415,8 +415,8 @@ $canMesSessions = $this->isAllowed(FormateurPrivileges::getResourceId(FormateurP </td> <td> <?php if ($canEmargement) : ?> - <?php /** @see FormationInstanceDocumentController::exportEmargementAction() */ ?> - <a href="<?php echo $this->url('session/export-emargement', ['journee' => $journee->getId()], [], true); ?>" + <?php /** @see FormationInstanceDocumentController::genererEmargementAction() */ ?> + <a href="<?php echo $this->url('session/generer-emargement', ['session' => $session->getId(), 'seance' => $journee->getId()], [], true); ?>" title="Exporter l'émargement de la séance de formation" target="_blank"> <span class="icon icon-pdf"></span><span class="lettrine">E</span></a> <?php endif; ?> -- GitLab