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