Skip to content
Snippets Groups Projects
Commit 3713e31c authored by Jean-Philippe Metivier's avatar Jean-Philippe Metivier
Browse files

Emargement as template

parent 97053c80
No related branches found
No related tags found
No related merge requests found
...@@ -204,6 +204,17 @@ class Agent implements ...@@ -204,6 +204,17 @@ class Agent implements
return null; 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[] */ /** @return AgentEchelon[] */
public function getEchelons(?DateTime $date = null, bool $histo = false): array public function getEchelons(?DateTime $date = null, bool $histo = false): array
{ {
......
...@@ -11,7 +11,7 @@ ...@@ -11,7 +11,7 @@
<tr> <tr>
<td> <td>
<img style='height:3cm;' src='' /> <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>
<td> <td>
<div style="display: inline-block; margin-right: 0;"> <div style="display: inline-block; margin-right: 0;">
......
...@@ -52,8 +52,7 @@ return [ ...@@ -52,8 +52,7 @@ return [
[ [
'controller' => FormationInstanceDocumentController::class, 'controller' => FormationInstanceDocumentController::class,
'action' => [ 'action' => [
'export-emargement', 'generer-emargement',
'export-tous-emargements',
], ],
'privileges' => [ 'privileges' => [
FormationinstancedocumentPrivileges::FORMATIONINSTANCEDOCUMENT_EMARGEMENT FormationinstancedocumentPrivileges::FORMATIONINSTANCEDOCUMENT_EMARGEMENT
...@@ -116,25 +115,14 @@ return [ ...@@ -116,25 +115,14 @@ return [
], ],
], ],
], ],
'export-emargement' => [ 'generer-emargement' => [
'type' => Segment::class, 'type' => Segment::class,
'options' => [ 'options' => [
'route' => '/export-emargement/:journee', 'route' => '/generer-emargement/:session[/:seance]',
'defaults' => [ 'defaults' => [
/** @see FormationInstanceDocumentController::exportEmargementAction() */ /** @see FormationInstanceDocumentController::genererEmargementAction() */
'controller' => FormationInstanceDocumentController::class, 'controller' => FormationInstanceDocumentController::class,
'action' => 'export-emargement', 'action' => 'generer-emargement',
],
],
],
'export-tous-emargements' => [
'type' => Segment::class,
'options' => [
'route' => '/export-tous-emargements/:session',
'defaults' => [
/** @see FormationInstanceDocumentController::exportTousEmargementsAction() */
'controller' => FormationInstanceDocumentController::class,
'action' => 'export-tous-emargements',
], ],
], ],
], ],
......
...@@ -49,6 +49,49 @@ class FormationInstanceDocumentController extends AbstractActionController ...@@ -49,6 +49,49 @@ class FormationInstanceDocumentController extends AbstractActionController
$this->etablissementInfos[$clef] = $valeur; $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 public function exportEmargementAction(): void
{ {
$journee = $this->getSeanceService()->getRequestedSeance($this); $journee = $this->getSeanceService()->getRequestedSeance($this);
...@@ -76,21 +119,6 @@ class FormationInstanceDocumentController extends AbstractActionController ...@@ -76,21 +119,6 @@ class FormationInstanceDocumentController extends AbstractActionController
exit; 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 * @throws MpdfException
*/ */
......
...@@ -221,4 +221,24 @@ class Seance implements HistoriqueAwareInterface, HasSourceInterface ...@@ -221,4 +221,24 @@ class Seance implements HistoriqueAwareInterface, HasSourceInterface
$session = $this->getInstance(); $session = $this->getInstance();
return ($session->getSeances() === null OR $session->getSeances() === [] OR $this->getDateFin()->format('d/m/Y H:i') === $session->getFin()); 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
...@@ -638,7 +638,38 @@ class Session implements ...@@ -638,7 +638,38 @@ class Session implements
return $this->getFormation()->getId() . "/" . $this->getId(); 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 public function getListeFormateurs(): string
{ {
/** @var Formateur[] $formateurs */ /** @var Formateur[] $formateurs */
...@@ -667,6 +698,38 @@ class Session implements ...@@ -667,6 +698,38 @@ class Session implements
return $text; 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 */ /** @noinspection PhpUnused */
public function getListeJournees(): string public function getListeJournees(): string
{ {
......
...@@ -8,4 +8,5 @@ class PdfTemplates { ...@@ -8,4 +8,5 @@ class PdfTemplates {
const FORMATION_ATTESTATION = "FORMATION_ATTESTATION"; const FORMATION_ATTESTATION = "FORMATION_ATTESTATION";
const FORMATION_HISTORIQUE = "FORMATION_HISTORIQUE"; const FORMATION_HISTORIQUE = "FORMATION_HISTORIQUE";
const FORMATION_ABSENCE = "FORMATION_ABSENCE"; const FORMATION_ABSENCE = "FORMATION_ABSENCE";
const FORMATION_EMARGEMENT = "FORMATION_EMARGEMENT";
} }
\ No newline at end of file
...@@ -99,7 +99,7 @@ class SeanceService ...@@ -99,7 +99,7 @@ class SeanceService
* @param integer $id * @param integer $id
* @return Seance|null * @return Seance|null
*/ */
public function getSeance(int $id): ?Seance public function getSeance(?int $id): ?Seance
{ {
$qb = $this->createQueryBuilder() $qb = $this->createQueryBuilder()
->andWhere('journee.id = :id') ->andWhere('journee.id = :id')
......
...@@ -342,8 +342,8 @@ $canMesSessions = $this->isAllowed(FormateurPrivileges::getResourceId(FormateurP ...@@ -342,8 +342,8 @@ $canMesSessions = $this->isAllowed(FormateurPrivileges::getResourceId(FormateurP
<br/> <br/>
<?php endif; ?> <?php endif; ?>
<?php if ($canEmargement): ?> <?php if ($canEmargement): ?>
<?php /** @see FormationInstanceDocumentController::exportTousEmargementsAction() */ ?> <?php /** @see FormationInstanceDocumentController::genererEmargementAction() */ ?>
<a href="<?php echo $this->url('session/export-tous-emargements', ['session' => $session->getId()], [], true); ?>" <a href="<?php echo $this->url('session/generer-emargement', ['session' => $session->getId()], [], true); ?>"
class="btn btn-primary" target="_blank"> class="btn btn-primary" target="_blank">
<span class="icon icon-pdf"></span> <span class="icon icon-pdf"></span>
Exporter les émargements Exporter les émargements
...@@ -415,8 +415,8 @@ $canMesSessions = $this->isAllowed(FormateurPrivileges::getResourceId(FormateurP ...@@ -415,8 +415,8 @@ $canMesSessions = $this->isAllowed(FormateurPrivileges::getResourceId(FormateurP
</td> </td>
<td> <td>
<?php if ($canEmargement) : ?> <?php if ($canEmargement) : ?>
<?php /** @see FormationInstanceDocumentController::exportEmargementAction() */ ?> <?php /** @see FormationInstanceDocumentController::genererEmargementAction() */ ?>
<a href="<?php echo $this->url('session/export-emargement', ['journee' => $journee->getId()], [], true); ?>" <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"> title="Exporter l'émargement de la séance de formation" target="_blank">
<span class="icon icon-pdf"></span><span class="lettrine">E</span></a> <span class="icon icon-pdf"></span><span class="lettrine">E</span></a>
<?php endif; ?> <?php endif; ?>
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment