<?php
namespace App\Controller;
use App\Entity\Feed;
use App\Repository\AfectadoRepository;
use Doctrine\ORM\EntityManagerInterface;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\Form\Extension\Core\Type\EmailType;
use Symfony\Component\Form\Extension\Core\Type\HiddenType;
use Symfony\Component\Form\Extension\Core\Type\TextareaType;
use Symfony\Component\Form\Extension\Core\Type\TextType;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
use Dompdf\Dompdf;
use Dompdf\Options;
use Imagick;
use ImagickPixel;
class HomeController extends AbstractController
{
/**
* @Route("", name="index")
*/
public function index(Request $request, EntityManagerInterface $em): Response
{
$fb = new Feed();
$form = $this->createCrearForm($fb);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$em->persist($fb);
$em->flush();
$this->addFlash('info', '¡Feed enviado correctamente!');
return $this->render('home/gracias.html.twig', [
'form' => $form->createView(),
]);
}
return $this->render('home/index.html.twig', [
'form' => $form->createView(),
]);
}
/**
* Funcion auxiliar que crea el form para crear una pregunta
*/
private function createCrearForm(Feed $entity)
{
$builder = $this->createFormBuilder($entity);
$builder->setAction($this->generateUrl('index'));
$builder->setMethod('POST');
$builder->add('feedback', TextareaType::class, array('required' => true));
$builder->add('email', EmailType::class, array('required' => true));
$builder->add('nombre', TextType::class, array('required' => true));
$builder->add('_token', HiddenType::class, array('mapped' => false));
return $builder->getForm();
}
/**
* Genera un informe en PDF para un afectado específico.
*
* @param int $id El ID del afectado.
* @param AfectadoRepository $afectadoRepository Repositorio para buscar datos del afectado.
* @param Dompdf $dompdf Servicio Dompdf inyectado por el bundle.
* @return Response
*
* @Route("/{id}/pdf", name="afectado", methods={"GET"})
*/
public function generarInformePdf(int $id, AfectadoRepository $afectadoRepository): Response
{
// 1. Buscar al afectado en la base de datos usando el ID de la URL.
$afectado = $afectadoRepository->find($id);
// 2. Si no se encuentra el afectado, devolver un error 404.
if (!$afectado) {
// Esta es la forma estándar en Symfony de devolver un JSON de error 404
return $this->json(['error' => 'Afectado no encontrado'], Response::HTTP_NOT_FOUND);
}
$svgString = $this->renderView('pdf/cuerpo_heridas.html.twig', [
'afectado' => $afectado,
]);
$imagick = new Imagick();
$imagick->setBackgroundColor(new ImagickPixel('transparent'));
$imagick->readImageBlob($svgString);
$imagick->setImageFormat("png32");
$imagick->resizeImage(300, 250, Imagick::FILTER_LANCZOS, 1);
$imagick->setColorspace(Imagick::COLORSPACE_SRGB);
$pngData = $imagick->getImageBlob();
$bodyMapAsBase64 = 'data:image/png;base64,' . base64_encode($pngData);
$imagick->clear();
$imagick->destroy();
$pdfOptions = new Options();
$pdfOptions->set('defaultFont', 'Arial');
$pdfOptions->isHtml5ParserEnabled(true);
$pdfOptions->set('enable_remote', true);
$pdfOptions->set("isPhpEnabled", true);
$dompdf = new Dompdf($pdfOptions);
// 4. Renderizar la plantilla Twig a una variable HTML.
// Usamos renderView() en lugar de render() porque queremos el HTML como string.
return $html = $this->render('pdf/informe_afectado.html.twig', [
'afectado' => $afectado,
'body_map_image_base64' => $bodyMapAsBase64,
]);
}
}