src/Controller/FacturaController.php line 3451

Open in your IDE?
  1. <?php
  2. namespace App\Controller;
  3. use App\Entity\Banco;
  4. use App\Entity\Comercial;
  5. use App\Entity\Factura;
  6. use App\Entity\FacturaGenerica;
  7. use App\Entity\Tool\Exporter;
  8. use App\Entity\Tool\RedsysAPI;
  9. use App\Entity\Tool\Validador;
  10. use App\Form\ExportarFacturaType;
  11. use App\Form\FacturaGenericaType;
  12. use App\Form\FacturaType;
  13. use App\Form\FiltrarFacturaLightType;
  14. use App\Form\FiltrarFacturaType;
  15. use App\Repository\BancoRepository;
  16. use App\Repository\ContratoRepository;
  17. use App\Repository\FacturaGenericaRepository;
  18. use App\Repository\FacturaRepository;
  19. use DateInterval;
  20. use Doctrine\ORM\EntityManagerInterface;
  21. use Doctrine\ORM\Query\Expr\Math;
  22. use Exception;
  23. use Knp\Bundle\SnappyBundle\Snappy\Response\PdfResponse;
  24. use Knp\Snappy\Pdf;
  25. use Dompdf\Dompdf;
  26. use Monolog\Handler\StreamHandler;
  27. use Monolog\Logger;
  28. use PhpOffice\PhpSpreadsheet\Writer\Xls;
  29. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  30. use Symfony\Component\Filesystem\Filesystem;
  31. use Symfony\Component\HttpFoundation\ResponseHeaderBag;
  32. use Symfony\Component\Mailer\MailerInterface;
  33. use Symfony\Component\Mime\Email;
  34. use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
  35. use Symfony\Component\HttpFoundation\BinaryFileResponse;
  36. use Symfony\Component\HttpFoundation\Request;
  37. use Symfony\Component\HttpFoundation\Response;
  38. use Symfony\Component\Mime\FileinfoMimeTypeGuesser;
  39. use Symfony\Component\Routing\Annotation\Route;
  40. use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
  41. /**
  42.  * @Route("/")
  43.  */
  44. class FacturaController extends AbstractController
  45. {
  46.     /**
  47.      * @Route("/facturas", name="factura_index", methods={"GET"})
  48.      */
  49.     public function indexAjax(): Response
  50.     {
  51.         $this->denyAccessUnlessGranted('ROLE_FACTURACION');
  52.         return $this->render('factura/indexAjax.html.twig', [
  53.             /*'facturas' => array_merge($facturaRepository->findAll(), $facturaGenericaRepository->findAll()),*/
  54.         ]);
  55.     }
  56.     /**
  57.      * @Route("/otros-conceptos", name="facturaGenerica_index", methods={"GET"})
  58.      */
  59.     public function genericaIndexAjax(): Response
  60.     {
  61.         $this->denyAccessUnlessGranted('ROLE_FACTURACION');
  62.         return $this->render('factura/indexAjax.html.twig', [
  63.             /*'facturas' => array_merge($facturaRepository->findAll(), $facturaGenericaRepository->findAll()),*/
  64.         ]);
  65.     }
  66.     /**
  67.      * @Route("/facturas-old", name="factura_old", methods={"GET"})
  68.      */
  69.     public function index(): Response
  70.     {
  71.         $this->denyAccessUnlessGranted('ROLE_FACTURACION');
  72.         return $this->render('factura/indexAjax.html.twig', [
  73.             /*'facturas' => array_merge($facturaRepository->findAll(), $facturaGenericaRepository->findAll()),*/
  74.         ]);
  75.     }
  76.     /**
  77.      * @Route("/filtrar-facturas", name="factura_filtrar", methods={"GET"})
  78.      */
  79.     public function latest(): Response
  80.     {
  81.         $this->denyAccessUnlessGranted('ROLE_FACTURACION');
  82.         $form=$this->createForm(FiltrarFacturaLightType::class);
  83.         return $this->render('factura/indexAjax.html.twig', ['filtrarFacturaForm'=>$form->createView()]);
  84.     }
  85.     /**
  86.      * @Route("/facturas-devueltas", name="factura_devueltas", methods={"GET"})
  87.      */
  88.     public function devueltas(): Response
  89.     {
  90.         $this->denyAccessUnlessGranted('ROLE_FACTURACION');
  91.         return $this->render('factura/indexAjax.html.twig', []);
  92.     }
  93.     /**
  94.      * @Route("/rentabilidad", name="rentabilidad", methods={"POST","GET"})
  95.      */
  96.     public function rentabilidad(FacturaRepository $facturaRepositoryFacturaGenericaRepository $facturaGenericaRepositoryRequest $request): Response
  97.     {
  98.         $this->denyAccessUnlessGranted('ROLE_FACTURACION');
  99.         $form=$this->createForm(FiltrarFacturaType::class);
  100.         $form->handleRequest($request);
  101.         $formSubmitted=false;
  102.         $facturas=[];
  103.         $facturasGenericas=[];
  104.         $facturado=0;
  105.         $coste=0;
  106.         $pagado=0;
  107.         $devuelto=0;
  108.         $pendiente=0;
  109.         $beneficio=0;
  110.         if($form->isSubmitted() && $form->isValid()){
  111.             $formSubmitted=true;
  112.             $fechaEmisionFrom=$form->get('fechaEmisionFrom')->getData();
  113.             $fechaEmisionTo=$form->get('fechaEmisionTo')->getData();
  114.             $fechaLecturaFrom=$form->get('fechaLecturaFrom')->getData();
  115.             $fechaLecturaTo=$form->get('fechaLecturaTo')->getData();
  116.             $fechaCobroFrom=$form->get('fechaCobroFrom')->getData();
  117.             $fechaCobroTo=$form->get('fechaCobroTo')->getData();
  118.             $pagada=$form->get('pagada')->getData();
  119.             $tipo=$form->get('tipo')->getData();
  120.             $estadoCompraFactura=$form->get('estadoCompraFactura')->getData();
  121.             if($tipo=='todas' or $tipo=='suministro'){
  122.                 $facturas=$facturaRepository->findByFilter(
  123.                     $fechaEmisionFrom,
  124.                     $fechaEmisionTo,
  125.                     $fechaLecturaFrom,
  126.                     $fechaLecturaTo,
  127.                     $fechaCobroFrom,
  128.                     $fechaCobroTo,
  129.                     $pagada,
  130.                     $estadoCompraFactura
  131.                 );
  132.                 foreach ($facturas as $factura){
  133.                     $totalCompra=$factura->getTotalCompra();
  134.                     $estdoCompra=$factura->getEstadoCompra();
  135.                     $facturado+=$factura->getTotalFactura();
  136.                     $coste+=$totalCompra;
  137.                     if($estdoCompra !== null){
  138.                         switch($estdoCompra->getNombre()){
  139.                             case 'Pendiente':
  140.                                 $pendiente+=$totalCompra;
  141.                                 break;
  142.                             case 'Devuelta':
  143.                                 $devuelto+=$totalCompra;
  144.                                 break;
  145.                             case 'Pagada':
  146.                                 $pagado+=$totalCompra;
  147.                         }
  148.                     }
  149.                 }
  150.             }
  151.             if ($fechaLecturaFrom==null and $fechaLecturaTo==null and $fechaCobroFrom==null and $fechaCobroTo==null and $estadoCompraFactura==null and ($tipo=='todas' or $tipo=='otros')){
  152.                 $facturasGenericas=$facturaGenericaRepository->findByFilter(
  153.                     $fechaEmisionFrom,
  154.                     $fechaEmisionTo,
  155.                     $pagada
  156.                 );
  157.                 foreach ($facturasGenericas as $factura){
  158.                     $facturado+=$factura->getTotalFactura();
  159.                 }
  160.             }
  161.             $beneficio=$facturado-$coste;
  162.         }
  163.         return $this->render('factura/rentabilidad.html.twig', [
  164.             'filtrarFacturaForm' => $form->createView(),
  165.             'formSubmitted'=>$formSubmitted,
  166.             'facturas' => array_merge($facturas$facturasGenericas),
  167.             'facturado'=>$facturado,
  168.             'coste'=>$coste,
  169.             'pendiente'=>$pendiente,
  170.             'pagado'=>$pagado,
  171.             'devuelto'=>$devuelto,
  172.             'beneficio'=>$beneficio
  173.         ]);
  174.     }
  175.     /*
  176.      * @Route("facturas/new", name="factura_new", methods={"GET","POST"})
  177.     public function new(Request $request): Response
  178.     {
  179.         $factura = new Factura();
  180.         $form = $this->createForm(FacturaType::class, $factura);
  181.         $form->handleRequest($request);
  182.         if ($form->isSubmitted() && $form->isValid()) {
  183.             $entityManager = $this->getDoctrine()->getManager();
  184.             $entityManager->persist($factura);
  185.             $entityManager->flush();
  186.             return $this->redirectToRoute('factura_index');
  187.         }
  188.         return $this->render('factura/new.html.twig', [
  189.             'factura' => $factura,
  190.             'form' => $form->createView(),
  191.         ]);
  192.     }
  193.      */
  194.     /**
  195.      * @Route("/facturas/exportar", name="factura_exportar", methods={"POST","GET"})
  196.      */
  197.     public function export(Request $requestFacturaRepository $facturaRepositoryFacturaGenericaRepository $facturaGenericaRepository): Response
  198.     {
  199.         $this->denyAccessUnlessGranted('ROLE_ADMIN');
  200.         $form $this->createForm(ExportarFacturaType::class);
  201.         $form->handleRequest($request);
  202.         if ($form->isSubmitted() && $form->isValid()) {
  203.             switch ( $form->get('tipoFactura')->getData() ){
  204.                 case 2:
  205.                     $facturas=$facturaRepository->findByExportForm($form);
  206.                     break;
  207.                 case 3:
  208.                     $facturas=$facturaGenericaRepository->findByExportForm($form);
  209.                     break;
  210.                 default:
  211.                     $facturas=array_merge($facturaRepository->findByExportForm($form), $facturaGenericaRepository->findByExportForm($form));
  212.                     break;
  213.             }
  214.             $exporter=new Exporter$facturas );
  215.             $file=$exporter->createFactusolFacturaXls();
  216.             return new BinaryFileResponse($file);
  217.         }else{
  218.             return $this->render('factura/exportar.html.twig', [
  219.                 'form'=>$form->createView(),
  220.             ]);
  221.         }
  222.     }
  223.     /**
  224.      * @Route("factura/{id}", name="factura_show", methods={"GET"})
  225.      */
  226.     public function show(Factura $facturaFacturaRepository $facturaRepositoryBancoRepository $bancoRepositoryEntityManagerInterface $entityManager): Response
  227.     {
  228.         if(
  229.             $factura->getContrato()->getCliente()->getUser()!=$this->getUser() &&
  230.             ($factura->getContrato()->getSeller()??new Comercial())->getUser()!=$this->getUser()
  231.         ){
  232.             $this->denyAccessUnlessGranted('ROLE_FACTURACION');
  233.         }
  234.         setlocale(LC_TIME"spanish");
  235.         $facturas=$facturaRepository->findBy(['contrato'=>$factura->getContrato()], ['fechaLectura'=>'ASC']);
  236.         $tarifa=$factura->getTarifa();
  237.         $entidad=$bancoRepository->findByCuenta($factura->getCcc());
  238.         $consumoAcumulado='0';
  239.         $consumoMedio='0';
  240.         $datosGrafica=[];
  241.         $ultimaFecha='';
  242.         $factura->calcularTotal();
  243.         if($tarifa->getTipoTarifa()=='Electricidad'){
  244.             /*if($tarifa=='2.0A' || $tarifa=='2.1A'){
  245.                 $periodoFacturacion=date_diff($factura->getFechaLecturaAnterior(), $factura->getFechaLectura())->days;
  246.                 $totalPotenciaP1=round($factura->getPotenciaP1()*$factura->getPrecioPotenciaP1()*$periodoFacturacion,2);
  247.                 $totalPotencia=$totalPotenciaP1;
  248.                 $totalEnergiaP1=round($factura->getConsumoP1()*$factura->getPrecioEnergiaP1(),2);
  249.                 $totalEnergia=$totalEnergiaP1;
  250.                 $subtotal=round($totalEnergia+$totalPotencia,2);
  251.                 $importeImpuesto=round($factura->getImpuesto()*$subtotal/100,2);
  252.                 $importeAlquiler=round($periodoFacturacion*$factura->getAlquilerEquipos(),2);
  253.                 $otrosConceptos=0;
  254.                 foreach ($factura->getConceptos() as $concepto){
  255.                     $otrosConceptos+=round($concepto->getImporte(),2);
  256.                 }
  257.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  258.                 $importeIva=round($factura->getIva()*$importeTotal/100,2);
  259.                 $totalFactura=round($importeTotal+$importeIva,2);
  260.                 if( $totalFactura!==$factura->getTotalFactura() ){
  261.                     $factura->setTotalFactura($totalFactura);
  262.                     $this->getDoctrine()->getManager()->flush();
  263.                 }
  264.             }
  265.             elseif($tarifa=='2.0DHA' || $tarifa=='2.1DHA'){
  266.                 $periodoFacturacion=date_diff( $factura->getFechaLecturaAnterior(), $factura->getFechaLectura() )->days;
  267.                 $totalPotenciaP1=round($factura->getPotenciaP1()*$factura->getPrecioPotenciaP1()*$periodoFacturacion,2);
  268.                 $totalPotencia=$totalPotenciaP1;
  269.                 $totalEnergiaP1=round($factura->getConsumoP1()*$factura->getPrecioEnergiaP1(),2);
  270.                 $totalEnergiaP3=round($factura->getConsumoP3()*$factura->getPrecioEnergiaP3(),2);
  271.                 $totalEnergia=$totalEnergiaP1+$totalEnergiaP3;
  272.                 $subtotal=round($totalEnergia+$totalPotencia,2);
  273.                 $importeImpuesto=round($factura->getImpuesto()*$subtotal/100,2);
  274.                 $importeAlquiler=round($periodoFacturacion*$factura->getAlquilerEquipos(),2);
  275.                 $otrosConceptos=0;
  276.                 foreach ($factura->getConceptos() as $concepto){
  277.                     $otrosConceptos+=round($concepto->getImporte(),2);
  278.                 }
  279.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  280.                 $importeIva=round($factura->getIva()*$importeTotal/100,2);
  281.                 $totalFactura=round($importeTotal+$importeIva,2);
  282.                 if( $totalFactura!==$factura->getTotalFactura() ){
  283.                     $factura->setTotalFactura($totalFactura);
  284.                     $this->getDoctrine()->getManager()->flush();
  285.                 }
  286.             }
  287.             elseif($tarifa=='2.0DHS' || $tarifa=='2.1DHS'){
  288.                 $periodoFacturacion=date_diff( $factura->getFechaLecturaAnterior(), $factura->getFechaLectura() )->days;
  289.                 $totalPotenciaP1=round($factura->getPotenciaP1()*$factura->getPrecioPotenciaP1()*$periodoFacturacion,2);
  290.                 $totalPotencia=$totalPotenciaP1;
  291.                 $totalEnergiaP1=round($factura->getConsumoP1()*$factura->getPrecioEnergiaP1(),2);
  292.                 $totalEnergiaP2=round($factura->getConsumoP2()*$factura->getPrecioEnergiaP2(),2);
  293.                 $totalEnergiaP3=round($factura->getConsumoP3()*$factura->getPrecioEnergiaP3(),2);
  294.                 $totalEnergia=$totalEnergiaP1+$totalEnergiaP2+$totalEnergiaP3;
  295.                 $subtotal=round($totalEnergia+$totalPotencia,2);
  296.                 $importeImpuesto=round($factura->getImpuesto()*$subtotal/100,2);
  297.                 $importeAlquiler=round($periodoFacturacion*$factura->getAlquilerEquipos(),2);
  298.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto,2);
  299.                 $importeIva=round($factura->getIva()*$importeTotal/100,2);
  300.                 $totalFactura=round($importeTotal+$importeIva,2);
  301.                 if( $totalFactura!==$factura->getTotalFactura() ){
  302.                     $factura->setTotalFactura($totalFactura);
  303.                     $this->getDoctrine()->getManager()->flush();
  304.                 }
  305.                 //Grafica
  306.                 if($factura===$facturas[0]){
  307.                     $consumoMedio=$factura->getTotalFactura();
  308.                     $datosGrafica[]=[
  309.                         str_replace('.','',strtolower( strftime('%h-%y',$factura->getFechaLectura()->getTimestamp()) )),
  310.                         $factura->getConsumoP1(),
  311.                         $factura->getConsumoP2(),
  312.                         $factura->getConsumoP3()
  313.                     ];
  314.                     $ultimaFecha=$factura->getFechaLectura();
  315.                     $consumoAcumulado=$factura->getConsumo();
  316.                 }
  317.                 else{
  318.                     $indiceFactura=array_search($factura, $facturas);
  319.                     if($indiceFactura<12){
  320.                         for($i=0;$i<=$indiceFactura && $i<12;$i++){
  321.                             $consumoMedio+=$facturas[$i]->getTotalFactura();
  322.                             $consumoAcumulado+=$facturas[$i]->getConsumo();
  323.                             $datosGrafica[]=[
  324.                                 str_replace('.','',strtolower( strftime('%h-%y',$facturas[$i]->getFechaLectura()->getTimestamp()) )),
  325.                                 $facturas[$i]->getConsumoP1(),
  326.                                 $facturas[$i]->getConsumoP2(),
  327.                                 $facturas[$i]->getConsumoP3()
  328.                             ];
  329.                             $ultimaFecha=$facturas[$i]->getFechaLectura();
  330.                         }
  331.                         $consumoMedio=$consumoMedio/($indiceFactura+1);
  332.                     }
  333.                     else{
  334.                         for($i=11;$i>=0;$i--){
  335.                             $n=$indiceFactura-$i;
  336.                             $consumoMedio+=$facturas[$n]->getTotalFactura();
  337.                             $consumoAcumulado+=$facturas[$i]->getConsumo();
  338.                             $datosGrafica[]=[
  339.                                 str_replace('.','',strtolower( strftime('%h-%y',$facturas[$n]->getFechaLectura()->getTimestamp()) )),
  340.                                 $facturas[$n]->getConsumoP1(),
  341.                                 $facturas[$n]->getConsumoP2(),
  342.                                 $facturas[$n]->getConsumoP3()
  343.                             ];
  344.                         }
  345.                         $consumoMedio=$consumoMedio/12;
  346.                         $ultimaFecha=$factura->getFechaLectura();
  347.                     }
  348.                 }
  349.                 while( count($datosGrafica)<12 ){
  350.                     $ultimaFecha = date_add($ultimaFecha, date_interval_create_from_date_string('1 month'));
  351.                     $datosGrafica[]=[
  352.                         str_replace('.','',strtolower( strftime('%h-%y',$ultimaFecha->getTimestamp()) )),
  353.                         0,
  354.                         0,
  355.                         0
  356.                     ];
  357.                 }
  358.                 //Return
  359.                 return $this->render('factura/factura.html.twig', [
  360.                     'factura' => $factura,
  361.                     'vencimientoFactura'=>date_create(),
  362.                     'finContrato'=>$contrato->getFechaFin(),
  363.                     'entidad'=>$entidad,
  364.                     'consumoMedio'=>$consumoMedio,
  365.                     'consumoAcumulado'=>$consumoAcumulado,
  366.                     'periodoFacturacion'=>$periodoFacturacion,
  367.                     'totalPotenciaP1'=>$totalPotenciaP1,
  368.                     'totalPotencia'=>$totalPotencia,
  369.                     'totalEnergiaP1'=>$totalEnergiaP1,
  370.                     'totalEnergiaP3'=>$totalEnergiaP3,
  371.                     'totalEnergia'=>$totalEnergia,
  372.                     'subtotal'=>$subtotal,
  373.                     'importeImpuesto'=>$importeImpuesto,
  374.                     'importeAlquiler'=>$importeAlquiler,
  375.                     'importeTotal'=>$importeTotal,
  376.                     'importeIva'=>$importeIva,
  377.                     'totalFactura'=>$totalFactura,
  378.                     'datosGrafica'=>$datosGrafica
  379.                 ]);
  380.             }
  381.             else*/
  382.             if($tarifa=='3.0A' || $tarifa=='3.1A'){
  383.                 $periodoFacturacion=date_diff$factura->getFechaLecturaAnterior(), $factura->getFechaLectura() )->days;
  384.                 $consumoP1Facturado=$factura->getConsumoP1()+$factura->getConsumoP4();
  385.                 $consumoP2Facturado=$factura->getConsumoP2()+$factura->getConsumoP5();
  386.                 $consumoP3Facturado=$factura->getConsumoP3()+$factura->getConsumoP6();
  387.                 $potenciaP1Facturada=$factura->getPotenciaFacturada('P1');
  388.                 $potenciaP2Facturada=$factura->getPotenciaFacturada('P2');
  389.                 $potenciaP3Facturada=$factura->getPotenciaFacturada('P3');
  390.                 $totalPotenciaP1=round($potenciaP1Facturada*$factura->getPrecioPotenciaP1()*$periodoFacturacion,2);
  391.                 $totalPotenciaP2=round($potenciaP2Facturada*$factura->getPrecioPotenciaP2()*$periodoFacturacion,2);
  392.                 $totalPotenciaP3=round($potenciaP3Facturada*$factura->getPrecioPotenciaP3()*$periodoFacturacion,2);
  393.                 $totalPotencia=$totalPotenciaP1+$totalPotenciaP2+$totalPotenciaP3;
  394.                 $totalEnergiaP1=round($consumoP1Facturado*$factura->getPrecioEnergiaP1(),2);
  395.                 $totalEnergiaP2=round($consumoP2Facturado*$factura->getPrecioEnergiaP2(),2);
  396.                 $totalEnergiaP3=round($consumoP3Facturado*$factura->getPrecioEnergiaP3(),2);
  397.                 $totalEnergia=$totalEnergiaP1+$totalEnergiaP2+$totalEnergiaP3;
  398.                 $reactivaP1=$factura->getReactivaP1()+$factura->getReactivaP4();
  399.                 $reactivaP2=$factura->getReactivaP2()+$factura->getReactivaP5();
  400.                 $excesoReactivaP1=$reactivaP1-0.33*$consumoP1Facturado;
  401.                 $excesoReactivaP2=$reactivaP2-0.33*$consumoP2Facturado;
  402.                 if($excesoReactivaP1<0)
  403.                     $excesoReactivaP1=0;
  404.                 if($excesoReactivaP2<0)
  405.                     $excesoReactivaP2=0;
  406.                 $importeReactivaP1=round($excesoReactivaP1*$factura->getPrecioReactivaP1(),2);
  407.                 $importeReactivaP2=round($excesoReactivaP2*$factura->getPrecioReactivaP2(),2);
  408.                 $totalReactiva=$importeReactivaP1+$importeReactivaP2;
  409.                 $subtotal=round($totalEnergia+$totalPotencia+$totalReactiva,2);
  410.                 $importeImpuesto=round($factura->getImpuesto()*$subtotal/100,2);
  411.                 $importeAlquiler=round($periodoFacturacion*$factura->getAlquilerEquipos(),2);
  412.                 $otrosConceptos=0;
  413.                 foreach ($factura->getConceptos() as $concepto){
  414.                     $otrosConceptos+=round($concepto->getImporte(),2);
  415.                 }
  416.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  417.                 $importeIva=round($factura->getIva()*$importeTotal/100,2);
  418.                 $totalFactura=round($importeTotal+$importeIva,2);
  419.                 if( $totalFactura!==$factura->getTotalFactura() ){
  420.                     $factura->setTotalFactura($totalFactura);
  421.                     $entityManager->flush();
  422.                 }
  423.             }
  424.             else{
  425.                 $periodoFacturacion=date_diff$factura->getFechaLecturaAnterior(), $factura->getFechaLectura() )->days;
  426.                 $consumoP1Facturado=$factura->getConsumoP1();
  427.                 $consumoP2Facturado=$factura->getConsumoP2();
  428.                 $consumoP3Facturado=$factura->getConsumoP3();
  429.                 $consumoP4Facturado=$factura->getConsumoP4();
  430.                 $consumoP5Facturado=$factura->getConsumoP5();
  431.                 $consumoP6Facturado=$factura->getConsumoP6();
  432.                 $potenciaP1Facturada=$factura->getPotenciaFacturada('P1');
  433.                 $potenciaP2Facturada=$factura->getPotenciaFacturada('P2');
  434.                 $potenciaP3Facturada=$factura->getPotenciaFacturada('P3');
  435.                 $potenciaP4Facturada=$factura->getPotenciaFacturada('P4');
  436.                 $potenciaP5Facturada=$factura->getPotenciaFacturada('P5');
  437.                 $potenciaP6Facturada=$factura->getPotenciaFacturada('P6');
  438.                 $totalPotenciaP1=round($potenciaP1Facturada*$factura->getPrecioPotenciaP1()*$periodoFacturacion,2);
  439.                 $totalPotenciaP2=round($potenciaP2Facturada*$factura->getPrecioPotenciaP2()*$periodoFacturacion,2);
  440.                 $totalPotenciaP3=round($potenciaP3Facturada*$factura->getPrecioPotenciaP3()*$periodoFacturacion,2);
  441.                 $totalPotenciaP4=round($potenciaP4Facturada*$factura->getPrecioPotenciaP4()*$periodoFacturacion,2);
  442.                 $totalPotenciaP5=round($potenciaP5Facturada*$factura->getPrecioPotenciaP5()*$periodoFacturacion,2);
  443.                 $totalPotenciaP6=round($potenciaP6Facturada*$factura->getPrecioPotenciaP6()*$periodoFacturacion,2);
  444.                 $totalPotencia=$totalPotenciaP1+$totalPotenciaP2+$totalPotenciaP3+$totalPotenciaP4+$totalPotenciaP5+$totalPotenciaP6;
  445.                 $totalEnergiaP1=round($consumoP1Facturado*$factura->getPrecioEnergiaP1(),2);
  446.                 $totalEnergiaP2=round($consumoP2Facturado*$factura->getPrecioEnergiaP2(),2);
  447.                 $totalEnergiaP3=round($consumoP3Facturado*$factura->getPrecioEnergiaP3(),2);
  448.                 $totalEnergiaP4=round($consumoP4Facturado*$factura->getPrecioEnergiaP4(),2);
  449.                 $totalEnergiaP5=round($consumoP5Facturado*$factura->getPrecioEnergiaP5(),2);
  450.                 $totalEnergiaP6=round($consumoP6Facturado*$factura->getPrecioEnergiaP6(),2);
  451.                 $totalEnergia=$totalEnergiaP1+$totalEnergiaP2+$totalEnergiaP3+$totalEnergiaP4+$totalEnergiaP5+$totalEnergiaP6;
  452.                 $reactivaP1=$factura->getReactivaP1();
  453.                 $reactivaP2=$factura->getReactivaP2();
  454.                 $reactivaP3=$factura->getReactivaP3();
  455.                 $reactivaP4=$factura->getReactivaP4();
  456.                 $reactivaP5=$factura->getReactivaP5();
  457.                 $reactivaP6=$factura->getReactivaP6();
  458.                 if($reactivaP1!=0)
  459.                     $excesoReactivaP1=$reactivaP1-0.33*$factura->getConsumoP1();
  460.                 else
  461.                     $excesoReactivaP1=0;
  462.                 if($reactivaP2!=0)
  463.                     $excesoReactivaP2=$reactivaP2-0.33*$factura->getConsumoP2();
  464.                 else
  465.                     $excesoReactivaP2=0;
  466.                 if($reactivaP3!=0)
  467.                     $excesoReactivaP3=$reactivaP3-0.33*$factura->getConsumoP3();
  468.                 else
  469.                     $excesoReactivaP3=0;
  470.                 if($reactivaP4!=0)
  471.                     $excesoReactivaP4=$reactivaP4-0.33*$factura->getConsumoP4();
  472.                 else
  473.                     $excesoReactivaP4=0;
  474.                 if($reactivaP5!=0)
  475.                     $excesoReactivaP5=$reactivaP5-0.33*$factura->getConsumoP5();
  476.                 else
  477.                     $excesoReactivaP5=0;
  478.                 if($reactivaP6!=0)
  479.                     $excesoReactivaP6=$reactivaP6-0.33*$factura->getConsumoP6();
  480.                 else
  481.                     $excesoReactivaP6=0;
  482.                 if($excesoReactivaP1<0)
  483.                     $excesoReactivaP1=0;
  484.                 if($excesoReactivaP2<0)
  485.                     $excesoReactivaP2=0;
  486.                 if($excesoReactivaP3<0)
  487.                     $excesoReactivaP3=0;
  488.                 if($excesoReactivaP4<0)
  489.                     $excesoReactivaP4=0;
  490.                 if($excesoReactivaP5<0)
  491.                     $excesoReactivaP5=0;
  492.                 if($excesoReactivaP6<0)
  493.                     $excesoReactivaP6=0;
  494.                 $importeReactivaP1=round($excesoReactivaP1*$factura->getPrecioReactivaP1(),2);
  495.                 $importeReactivaP2=round($excesoReactivaP2*$factura->getPrecioReactivaP2(),2);
  496.                 $importeReactivaP3=round($excesoReactivaP3*$factura->getPrecioReactivaP3(),2);
  497.                 $importeReactivaP4=round($excesoReactivaP4*$factura->getPrecioReactivaP4(),2);
  498.                 $importeReactivaP5=round($excesoReactivaP5*$factura->getPrecioReactivaP5(),2);
  499.                 $importeReactivaP6=round($excesoReactivaP6*$factura->getPrecioReactivaP6(),2);
  500.                 $totalReactiva=$importeReactivaP1+$importeReactivaP2+$importeReactivaP3+$importeReactivaP4+$importeReactivaP5+$importeReactivaP6;
  501.                 $subtotal=round($totalEnergia+$totalPotencia+$totalReactiva,2);
  502.                 $importeImpuesto=round($factura->getImpuesto()*$subtotal/100,2);
  503.                 $importeAlquiler=round($periodoFacturacion*$factura->getAlquilerEquipos(),2);
  504.                 $otrosConceptos=0;
  505.                 foreach ($factura->getConceptos() as $concepto){
  506.                     $otrosConceptos+=round($concepto->getImporte(),2);
  507.                 }
  508.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  509.                 $importeIva=round($factura->getIva()*$importeTotal/100,2);
  510.                 $totalFactura=round($importeTotal+$importeIva,2);
  511.                 if( $totalFactura!==$factura->getTotalFactura() ){
  512.                     $factura->setTotalFactura($totalFactura);
  513.                     $entityManager->flush();
  514.                 }
  515.                 //throw $this->createNotFoundException('No se ha encontrado la factura');
  516.             }
  517.             //Grafica
  518.             $indiceFactura=array_search($factura$facturas);
  519.             $arrayP=[false,false,false,false,false,false];
  520.             if($indiceFactura<12){
  521.                 for($i=0;$i<=$indiceFactura && $i<12;$i++){
  522.                     $consumoMedio+=$facturas[$i]->getTotalFactura();
  523.                     $consumoAcumulado+=$facturas[$i]->getConsumo();
  524.                     $ultimaFecha=$facturas[$i]->getFechaLectura();
  525.                     $tarifaI=$facturas[$i]->getTarifa();
  526.                     $arrayPI=[
  527.                         $tarifaI->getEnergiaP1(),
  528.                         $tarifaI->getEnergiaP2(),
  529.                         $tarifaI->getEnergiaP3(),
  530.                         $tarifaI->getEnergiaP4(),
  531.                         $tarifaI->getEnergiaP5(),
  532.                         $tarifaI->getEnergiaP6()
  533.                     ];
  534.                     if(!$arrayP[0])
  535.                         $arrayP[0]=$arrayPI[0];
  536.                     if(!$arrayP[1])
  537.                         $arrayP[1]=$arrayPI[1];
  538.                     if(!$arrayP[2])
  539.                         $arrayP[2]=$arrayPI[2];
  540.                     if(!$arrayP[3])
  541.                         $arrayP[3]=$arrayPI[3];
  542.                     if(!$arrayP[4])
  543.                         $arrayP[4]=$arrayPI[4];
  544.                     if(!$arrayP[5])
  545.                         $arrayP[5]=$arrayPI[5];
  546.                     /*if ( $tarifaI=='2.0A' || $tarifaI=='2.1A' ){
  547.                         $datosGrafica[]=[
  548.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$i]->getFechaLectura()->getTimestamp()) )),
  549.                             $facturas[$i]->getConsumoP1(),
  550.                             0,
  551.                             0
  552.                         ];
  553.                         if ( 1>($numeroP??0) ){
  554.                             $numeroP=1;
  555.                         }
  556.                     }elseif ( $tarifaI=='2.0DHA' || $tarifaI=='2.1DHA' ){
  557.                         $datosGrafica[]=[
  558.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$i]->getFechaLectura()->getTimestamp()) )),
  559.                             $facturas[$i]->getConsumoP1(),
  560.                             0,
  561.                             $facturas[$i]->getConsumoP3()
  562.                         ];
  563.                         if ( 2>($numeroP??0) ){
  564.                             $numeroP=2;
  565.                         }
  566.                     }else*/
  567.                     switch( $tarifaI->getNombre() ){
  568.                         case '3.0A': case '3.1A':
  569.                         $datosGrafica[]=[
  570.                             str_replace('.','',strtolowerstrftime('%h-%y',$facturas[$i]->getFechaLectura()->getTimestamp()) )),
  571.                             $facturas[$i]->getConsumoP1()+$facturas[$i]->getConsumoP4(),
  572.                             $facturas[$i]->getConsumoP2()+$facturas[$i]->getConsumoP5(),
  573.                             $facturas[$i]->getConsumoP3()+$facturas[$i]->getConsumoP6(),
  574.                             0,
  575.                             0,
  576.                             0
  577.                         ];
  578.                         break;
  579.                         default:
  580.                             $datosGrafica[]=[
  581.                                 str_replace('.','',strtolowerstrftime('%h-%y',$facturas[$i]->getFechaLectura()->getTimestamp()) )),
  582.                                 $facturas[$i]->getConsumoP1()??0,
  583.                                 $facturas[$i]->getConsumoP2()??0,
  584.                                 $facturas[$i]->getConsumoP3()??0,
  585.                                 $facturas[$i]->getConsumoP4()??0,
  586.                                 $facturas[$i]->getConsumoP5()??0,
  587.                                 $facturas[$i]->getConsumoP6()??0,
  588.                             ];
  589.                             break;
  590.                     }
  591.                 }
  592.                 $consumoMedio=$consumoMedio/($indiceFactura+1);
  593.                 $numeroP=countarray_filter($arrayP) );
  594.             }
  595.             else{
  596.                 for($i=11;$i>=0;$i--){
  597.                     $n=$indiceFactura-$i;
  598.                     $consumoMedio+=$facturas[$n]->getTotalFactura();
  599.                     $consumoAcumulado+=$facturas[$n]->getConsumo();
  600.                     $tarifaI=$facturas[$n]->getTarifa();
  601.                     $arrayPI=[
  602.                         $tarifaI->getEnergiaP1(),
  603.                         $tarifaI->getEnergiaP2(),
  604.                         $tarifaI->getEnergiaP3(),
  605.                         $tarifaI->getEnergiaP4(),
  606.                         $tarifaI->getEnergiaP5(),
  607.                         $tarifaI->getEnergiaP6()
  608.                     ];
  609.                     if(!$arrayP[0])
  610.                         $arrayP[0]=$arrayPI[0];
  611.                     if(!$arrayP[1])
  612.                         $arrayP[1]=$arrayPI[1];
  613.                     if(!$arrayP[2])
  614.                         $arrayP[2]=$arrayPI[2];
  615.                     if(!$arrayP[3])
  616.                         $arrayP[3]=$arrayPI[3];
  617.                     if(!$arrayP[4])
  618.                         $arrayP[4]=$arrayPI[4];
  619.                     if(!$arrayP[5])
  620.                         $arrayP[5]=$arrayPI[5];
  621.                     /*if ( $tarifaI=='2.0A' || $tarifaI=='2.1A' ){
  622.                         $datosGrafica[]=[
  623.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$n]->getFechaLectura()->getTimestamp()) )),
  624.                             $facturas[$n]->getConsumoP1(),
  625.                             0,
  626.                             0
  627.                         ];
  628.                         if ( 1>($numeroP??0) ){
  629.                             $numeroP=1;
  630.                         }
  631.                     }elseif ( $tarifaI=='2.0DHA' || $tarifaI=='2.1DHA' ){
  632.                         $datosGrafica[]=[
  633.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$n]->getFechaLectura()->getTimestamp()) )),
  634.                             $facturas[$n]->getConsumoP1(),
  635.                             0,
  636.                             $facturas[$n]->getConsumoP3()
  637.                         ];
  638.                         if ( 2>($numeroP??0) ){
  639.                             $numeroP=2;
  640.                         }
  641.                     }elseif( $tarifaI=='3.0A' || $tarifaI=='3.1A' ){
  642.                         $datosGrafica[]=[
  643.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$n]->getFechaLectura()->getTimestamp()) )),
  644.                             $facturas[$n]->getConsumoP1()+$facturas[$n]->getConsumoP4(),
  645.                             $facturas[$n]->getConsumoP2()+$facturas[$n]->getConsumoP5(),
  646.                             $facturas[$n]->getConsumoP3()+$facturas[$n]->getConsumoP6(),
  647.                         ];
  648.                     }*/
  649.                     switch( $tarifaI->getNombre() ){
  650.                         case '3.0A': case '3.1A':
  651.                         $datosGrafica[]=[
  652.                             str_replace('.','',strtolowerstrftime('%h-%y',$facturas[$n]->getFechaLectura()->getTimestamp()) )),
  653.                             $facturas[$n]->getConsumoP1()+$facturas[$n]->getConsumoP4(),
  654.                             $facturas[$n]->getConsumoP2()+$facturas[$n]->getConsumoP5(),
  655.                             $facturas[$n]->getConsumoP3()+$facturas[$n]->getConsumoP6(),
  656.                             0,
  657.                             0,
  658.                             0
  659.                         ];
  660.                         break;
  661.                         default:
  662.                             $datosGrafica[]=[
  663.                                 str_replace('.','',strtolowerstrftime('%h-%y',$facturas[$n]->getFechaLectura()->getTimestamp()) )),
  664.                                 $facturas[$n]->getConsumoP1()??0,
  665.                                 $facturas[$n]->getConsumoP2()??0,
  666.                                 $facturas[$n]->getConsumoP3()??0,
  667.                                 $facturas[$n]->getConsumoP4()??0,
  668.                                 $facturas[$n]->getConsumoP5()??0,
  669.                                 $facturas[$n]->getConsumoP6()??0,
  670.                             ];
  671.                             break;
  672.                     }
  673.                 }
  674.                 $consumoMedio=$consumoMedio/12;
  675.                 $ultimaFecha=$factura->getFechaLectura();
  676.                 $numeroP=countarray_filter($arrayP) );
  677.             }
  678.             $timestamp=date_timestamp_get($ultimaFecha);
  679.             while( count($datosGrafica)<12 ){
  680.                 $ultimaFecha date_add($ultimaFechadate_interval_create_from_date_string('1 month'));
  681.                 $datosGrafica[]=[
  682.                     str_replace('.','',strtolowerstrftime('%h-%y',$ultimaFecha->getTimestamp()) )),
  683.                     0,
  684.                     0,
  685.                     0,
  686.                     0,
  687.                     0,
  688.                     0
  689.                 ];
  690.             }
  691.             $factura->setFechaLectura(date_timestamp_set($ultimaFecha,$timestamp));
  692.             $params=[
  693.                 'factura' => $factura,
  694.                 'entidad'=>$entidad,
  695.                 'consumoMedio'=>$consumoMedio,
  696.                 'consumoAcumulado'=>$consumoAcumulado,
  697.                 'periodoFacturacion'=>$periodoFacturacion,
  698.                 'potenciaP1Facturada'=>$potenciaP1Facturada??null,
  699.                 'potenciaP2Facturada'=>$potenciaP2Facturada??null,
  700.                 'potenciaP3Facturada'=>$potenciaP3Facturada??null,
  701.                 'potenciaP4Facturada'=>$potenciaP4Facturada??null,
  702.                 'potenciaP5Facturada'=>$potenciaP5Facturada??null,
  703.                 'potenciaP6Facturada'=>$potenciaP6Facturada??null,
  704.                 'totalPotenciaP1'=>$totalPotenciaP1,
  705.                 'totalPotenciaP2'=>$totalPotenciaP2??null,
  706.                 'totalPotenciaP3'=>$totalPotenciaP3??null,
  707.                 'totalPotenciaP4'=>$totalPotenciaP4??null,
  708.                 'totalPotenciaP5'=>$totalPotenciaP5??null,
  709.                 'totalPotenciaP6'=>$totalPotenciaP6??null,
  710.                 'totalPotencia'=>$totalPotencia,
  711.                 'totalEnergiaP1'=>$totalEnergiaP1,
  712.                 'totalEnergiaP2'=>$totalEnergiaP2??null,
  713.                 'totalEnergiaP3'=>$totalEnergiaP3??null,
  714.                 'totalEnergiaP4'=>$totalEnergiaP4??null,
  715.                 'totalEnergiaP5'=>$totalEnergiaP5??null,
  716.                 'totalEnergiaP6'=>$totalEnergiaP6??null,
  717.                 'totalEnergia'=>$totalEnergia,
  718.                 'reactivaP1'=>$reactivaP1??null,
  719.                 'reactivaP2'=>$reactivaP2??null,
  720.                 'reactivaP3'=>$reactivaP3??null,
  721.                 'reactivaP4'=>$reactivaP4??null,
  722.                 'reactivaP5'=>$reactivaP5??null,
  723.                 'reactivaP6'=>$reactivaP6??null,
  724.                 'excesoReactivaP1'=>$excesoReactivaP1??null,
  725.                 'excesoReactivaP2'=>$excesoReactivaP2??null,
  726.                 'excesoReactivaP3'=>$excesoReactivaP3??null,
  727.                 'excesoReactivaP4'=>$excesoReactivaP4??null,
  728.                 'excesoReactivaP5'=>$excesoReactivaP5??null,
  729.                 'excesoReactivaP6'=>$excesoReactivaP6??null,
  730.                 'importeReactivaP1'=>$importeReactivaP1??null,
  731.                 'importeReactivaP2'=>$importeReactivaP2??null,
  732.                 'importeReactivaP3'=>$importeReactivaP3??null,
  733.                 'importeReactivaP4'=>$importeReactivaP4??null,
  734.                 'importeReactivaP5'=>$importeReactivaP5??null,
  735.                 'importeReactivaP6'=>$importeReactivaP6??null,
  736.                 'totalReactiva'=>$totalReactiva??null,
  737.                 'subtotal'=>$subtotal,
  738.                 'importeImpuesto'=>$importeImpuesto,
  739.                 'importeAlquiler'=>$importeAlquiler,
  740.                 'otrosConceptos'=>$otrosConceptos??0,
  741.                 'importeTotal'=>$importeTotal,
  742.                 'importeIva'=>$importeIva,
  743.                 'totalFactura'=>$totalFactura,
  744.                 'consumoP1Facturado'=>$consumoP1Facturado??null,
  745.                 'consumoP2Facturado'=>$consumoP2Facturado??null,
  746.                 'consumoP3Facturado'=>$consumoP3Facturado??null,
  747.                 'consumoP4Facturado'=>$consumoP4Facturado??null,
  748.                 'consumoP5Facturado'=>$consumoP5Facturado??null,
  749.                 'consumoP6Facturado'=>$consumoP6Facturado??null,
  750.                 'datosGrafica'=>$datosGrafica,
  751.                 'arrayP'=>$arrayP??[true,false,false,false,false,false],
  752.                 'numeroP'=>$numeroP??1,
  753.             ];
  754.             switch ($_SERVER['APP_ENV']??'finkaluz'){
  755.                 case 'finkaluz':
  756.                     return $this->render('factura/finkaluz.factura.html.twig'$params);
  757.                 case 'emfra':
  758.                     return $this->render('factura/emfra.factura.html.twig'$params);
  759.                 case 'onda':
  760.                     return $this->render('factura/onda.factura.html.twig'$params);
  761.                 case 'digitel':
  762.                     return $this->render('factura/digitel.factura.html.twig'$params);
  763.                 case 'apolo':
  764.                     return $this->render('factura/apolo.factura.html.twig'$params);
  765.                 case 'e3': case 'telkes': case 'paladio': case 'arsen': case 'rburgos':
  766.                     return $this->render('factura/'.$_SERVER['APP_ENV'].'/factura.html.twig'$params);
  767.                 default:
  768.                     return $this->render('factura/factura.html.twig'$params);
  769.             }
  770.         }
  771.         else{
  772.             $periodoFacturacion=date_diff($factura->getFechaLecturaAnterior(), $factura->getFechaLectura())->days;
  773.             $totalPotenciaP1=round($factura->getPrecioPotenciaP1()*$periodoFacturacion,2);
  774.             $totalPotencia=$totalPotenciaP1;
  775.             $totalEnergiaP1=round($factura->getConsumoConvertidoP1()*$factura->getPrecioEnergiaP1(),2);
  776.             $totalEnergia=$totalEnergiaP1;
  777.             $subtotal=round($totalEnergia+$totalPotencia,2);
  778.             $importeImpuesto=round($factura->getImpuesto()*$factura->getConsumoConvertidoP1(),2);
  779.             $importeAlquiler=round($periodoFacturacion*$factura->getAlquilerEquipos(),2);
  780.             $otrosConceptos=0;
  781.             foreach ($factura->getConceptos() as $concepto){
  782.                 $otrosConceptos+=round($concepto->getImporte(),2);
  783.             }
  784.             $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  785.             $importeIva=round($factura->getIva()*$importeTotal/100,2);
  786.             $totalFactura=round($importeTotal+$importeIva,2);
  787.             if( $totalFactura!==$factura->getTotalFactura() ){
  788.                 $factura->setTotalFactura($totalFactura);
  789.                 $entityManager->flush();
  790.             }
  791.             //Grafica
  792.             if($factura === $facturas[0]){
  793.                 $consumoMedio=$factura->getTotalFactura();
  794.                 $datosGrafica[]=[
  795.                     str_replace('.','',strtolowerstrftime('%h-%y',$factura->getFechaLectura()->getTimestamp()) )),
  796.                     $factura->getConsumoConvertidoP1()
  797.                 ];
  798.                 $ultimaFecha=$factura->getFechaLectura();
  799.                 $consumoAcumulado=$factura->getConsumoConvertidoP1();
  800.             }
  801.             else{
  802.                 $indiceFactura=array_search($factura$facturas);
  803.                 if($indiceFactura<12){
  804.                     for($i=0;$i<=$indiceFactura && $i<12;$i++){
  805.                         $consumoMedio+=$facturas[$i]->getTotalFactura();
  806.                         $consumoAcumulado+=$facturas[$i]->getConsumoConvertidoP1();
  807.                         $datosGrafica[]=[
  808.                             str_replace('.','',strtolowerstrftime('%h-%y',$facturas[$i]->getFechaLectura()->getTimestamp()) )),
  809.                             $facturas[$i]->getConsumoConvertidoP1()
  810.                         ];
  811.                         $ultimaFecha=$facturas[$i]->getFechaLectura();
  812.                     }
  813.                     $consumoMedio=$consumoMedio/($indiceFactura+1);
  814.                 }
  815.                 else{
  816.                     for($i=11;$i>=0;$i--){
  817.                         $n=$indiceFactura-$i;
  818.                         $consumoMedio+=$facturas[$n]->getTotalFactura();
  819.                         $consumoAcumulado+=$factura->getConsumoConvertidoP1();
  820.                         $datosGrafica[]=[
  821.                             str_replace('.','',strtolowerstrftime('%h-%y',$facturas[$n]->getFechaLectura()->getTimestamp()) )),
  822.                             $facturas[$n]->getConsumoConvertidoP1()
  823.                         ];
  824.                     }
  825.                     $consumoMedio=$consumoMedio/12;
  826.                     $ultimaFecha=$factura->getFechaLectura();
  827.                 }
  828.             }
  829.             $timestamp=date_timestamp_get($ultimaFecha);
  830.             while( count($datosGrafica)<12 ){
  831.                 $ultimaFecha date_add($ultimaFechadate_interval_create_from_date_string('1 month'));
  832.                 $datosGrafica[]=[
  833.                     str_replace('.','',strtolowerstrftime('%h-%y',$ultimaFecha->getTimestamp()) )),
  834.                     0
  835.                 ];
  836.             }
  837.             $factura->setFechaLectura(date_timestamp_set($ultimaFecha,$timestamp));
  838.             //Return
  839.             $params=[
  840.                 'factura' => $factura,
  841.                 'entidad'=>$entidad,
  842.                 'consumoMedio'=>$consumoMedio,
  843.                 'consumoAcumulado'=>$consumoAcumulado,
  844.                 'periodoFacturacion'=>$periodoFacturacion,
  845.                 'totalPotenciaP1'=>$totalPotenciaP1,
  846.                 'totalPotencia'=>$totalPotencia,
  847.                 'totalEnergiaP1'=>$totalEnergiaP1,
  848.                 'totalEnergia'=>$totalEnergia,
  849.                 'subtotal'=>$subtotal,
  850.                 'importeImpuesto'=>$importeImpuesto,
  851.                 'importeAlquiler'=>$importeAlquiler,
  852.                 'otrosConceptos'=>$otrosConceptos,
  853.                 'importeTotal'=>$importeTotal,
  854.                 'importeIva'=>$importeIva,
  855.                 'totalFactura'=>$totalFactura,
  856.                 'datosGrafica'=>$datosGrafica,
  857.                 'arrayP'=>$arrayP??[true,false,false,false,false,false],
  858.                 'numeroP'=>0,
  859.             ];
  860.             switch ($_SERVER['APP_ENV']??'finkaluz'){
  861.                 case 'digitel':
  862.                     return $this->render('factura/digitel.factura.html.twig'$params);
  863.                 case 'apolo':
  864.                     return $this->render('factura/apolo.factura.html.twig'$params);
  865.                 case 'e3': case 'telkes': case 'paladio': case 'arsen': case 'rburgos':
  866.                     return $this->render('factura/'.$_SERVER['APP_ENV'].'/factura.html.twig'$params);
  867.                 default:
  868.                     return $this->render('factura/factura.html.twig'$params);
  869.             }
  870.         }
  871.     }
  872.     /**
  873.      * @Route("factura/{id}/pdf", name="factura_pdf", methods={"GET", "POST"})
  874.      */
  875.     public function pdf(Factura $facturaPdf $pdfRequest $requestFacturaRepository $facturaRepository,
  876.                         BancoRepository $bancoRepositoryEntityManagerInterface $entityManager): PdfResponse
  877.     {
  878.         if(
  879.             $factura->getContrato()->getCliente()->getUser()!=$this->getUser() &&
  880.             ($factura->getContrato()->getSeller()??new Comercial())->getUser()!=$this->getUser()
  881.         ){
  882.             $this->denyAccessUnlessGranted('ROLE_FACTURACION');
  883.         }
  884.         $urlImagen=$request->request->get("urlImagen");
  885.         $facturas=$facturaRepository->findBy(['contrato'=>$factura->getContrato()], ['fechaLectura'=>'ASC']);
  886.         $tarifa=$factura->getTarifa();
  887.         $entidad=$bancoRepository->findByCuenta($factura->getCcc());
  888.         $consumoAcumulado='0';
  889.         $consumoMedio='0';
  890.         /*if($tarifa->getTipoTarifa()=='Electricidad'){
  891.             if($tarifa=='2.0A' || $tarifa=='2.1A'){
  892.                 $periodoFacturacion=date_diff($factura->getFechaLecturaAnterior(), $factura->getFechaLectura())->days;
  893.                 $totalPotenciaP1=round($factura->getPotenciaP1()*$factura->getPrecioPotenciaP1()*$periodoFacturacion,2);
  894.                 $totalPotencia=$totalPotenciaP1;
  895.                 $totalEnergiaP1=round($factura->getConsumoP1()*$factura->getPrecioEnergiaP1(),2);
  896.                 $totalEnergia=$totalEnergiaP1;
  897.                 $subtotal=round($totalEnergia+$totalPotencia,2);
  898.                 $importeImpuesto=round($factura->getImpuesto()*$subtotal/100,2);
  899.                 $importeAlquiler=round($periodoFacturacion*$factura->getAlquilerEquipos(),2);
  900.                 $otrosConceptos=0;
  901.                 foreach ($factura->getConceptos() as $concepto){
  902.                     $otrosConceptos+=round($concepto->getImporte(),2);
  903.                 }
  904.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  905.                 $importeIva=round($factura->getIva()*$importeTotal/100,2);
  906.                 $totalFactura=round($importeTotal+$importeIva,2);
  907.                 if( $totalFactura!==$factura->getTotalFactura() ){
  908.                     $factura->setTotalFactura($totalFactura);
  909.                     $this->getDoctrine()->getManager()->flush();
  910.                 }
  911.                 //Grafica
  912.                 if($factura === $facturas[0]){
  913.                     $consumoMedio=$factura->getTotalFactura();
  914.                     $consumoAcumulado=$factura->getLecturaEnergiaP1()-$factura->getLecturaAnteriorP1();
  915.                 }
  916.                 else{
  917.                     $indiceFactura=array_search($factura, $facturas);
  918.                     if($indiceFactura<12){
  919.                         for($i=0;$i<=$indiceFactura && $i<12;$i++){
  920.                             $consumoMedio+=$facturas[$i]->getTotalFactura();
  921.                             $consumoAcumulado+=$facturas[$i]->getConsumo();
  922.                         }
  923.                         $consumoMedio=$consumoMedio/($indiceFactura+1);
  924.                     }
  925.                     else{
  926.                         for($i=11;$i>=0;$i--){
  927.                             $n=$indiceFactura-$i;
  928.                             $consumoMedio+=$facturas[$n]->getTotalFactura();
  929.                             $consumoAcumulado+=$factura->getConsumo()[1];
  930.                         }
  931.                         $consumoMedio=$consumoMedio/12;
  932.                     }
  933.                 }
  934.             }
  935.             elseif($tarifa=='2.0DHA' || $tarifa=='2.1DHA'){
  936.                 $periodoFacturacion=date_diff( $factura->getFechaLecturaAnterior(), $factura->getFechaLectura() )->days;
  937.                 $totalPotenciaP1=round($factura->getPotenciaP1()*$factura->getPrecioPotenciaP1()*$periodoFacturacion,2);
  938.                 $totalPotencia=$totalPotenciaP1;
  939.                 $totalEnergiaP1=round($factura->getConsumoP1()*$factura->getPrecioEnergiaP1(),2);
  940.                 $totalEnergiaP3=round($factura->getConsumoP3()*$factura->getPrecioEnergiaP3(),2);
  941.                 $totalEnergia=$totalEnergiaP1+$totalEnergiaP3;
  942.                 $subtotal=round($totalEnergia+$totalPotencia,2);
  943.                 $importeImpuesto=round($factura->getImpuesto()*$subtotal/100,2);
  944.                 $importeAlquiler=round($periodoFacturacion*$factura->getAlquilerEquipos(),2);
  945.                 $otrosConceptos=0;
  946.                 foreach ($factura->getConceptos() as $concepto){
  947.                     $otrosConceptos+=round($concepto->getImporte(),2);
  948.                 }
  949.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  950.                 $importeIva=round($factura->getIva()*$importeTotal/100,2);
  951.                 $totalFactura=round($importeTotal+$importeIva,2);
  952.                 if( $totalFactura!==$factura->getTotalFactura() ){
  953.                     $factura->setTotalFactura($totalFactura);
  954.                     $this->getDoctrine()->getManager()->flush();
  955.                 }
  956.                 //Grafica
  957.                 if($factura===$facturas[0]){
  958.                     $consumoMedio=$factura->getTotalFactura();
  959.                     $consumoAcumulado=$factura->getConsumo();
  960.                 }
  961.                 else{
  962.                     $indiceFactura=array_search($factura, $facturas);
  963.                     if($indiceFactura<12){
  964.                         for($i=0;$i<=$indiceFactura && $i<12;$i++){
  965.                             $consumoMedio+=$facturas[$i]->getTotalFactura();
  966.                             $consumoAcumulado+=$facturas[$i]->getConsumo();
  967.                         }
  968.                         $consumoMedio=$consumoMedio/($indiceFactura+1);
  969.                     }
  970.                     else{
  971.                         for($i=11;$i>=0;$i--){
  972.                             $n=$indiceFactura-$i;
  973.                             $consumoMedio+=$facturas[$n]->getTotalFactura();
  974.                             $consumoAcumulado+=$facturas[$i]->getConsumo();
  975.                         }
  976.                         $consumoMedio=$consumoMedio/12;
  977.                     }
  978.                 }
  979.             }
  980.             elseif($tarifa=='3.0A' || $tarifa=='3.1A'){
  981.                 $periodoFacturacion=date_diff( $factura->getFechaLecturaAnterior(), $factura->getFechaLectura() )->days;
  982.                 $consumoP1Facturado=$factura->getConsumoP1()+$factura->getConsumoP4();
  983.                 $consumoP2Facturado=$factura->getConsumoP2()+$factura->getConsumoP5();
  984.                 $consumoP3Facturado=$factura->getConsumoP3()+$factura->getConsumoP6();
  985.                 $potenciaP1Facturada=$factura->getPotenciaFacturada('P1');
  986.                 $potenciaP2Facturada=$factura->getPotenciaFacturada('P2');
  987.                 $potenciaP3Facturada=$factura->getPotenciaFacturada('P3');
  988.                 $totalPotenciaP1=round($potenciaP1Facturada*$factura->getPrecioPotenciaP1()*$periodoFacturacion,2);
  989.                 $totalPotenciaP2=round($potenciaP2Facturada*$factura->getPrecioPotenciaP2()*$periodoFacturacion,2);
  990.                 $totalPotenciaP3=round($potenciaP3Facturada*$factura->getPrecioPotenciaP3()*$periodoFacturacion,2);
  991.                 $totalPotencia=$totalPotenciaP1+$totalPotenciaP2+$totalPotenciaP3;
  992.                 $totalEnergiaP1=round($consumoP1Facturado*$factura->getPrecioEnergiaP1(),2);
  993.                 $totalEnergiaP2=round($consumoP2Facturado*$factura->getPrecioEnergiaP2(),2);
  994.                 $totalEnergiaP3=round($consumoP3Facturado*$factura->getPrecioEnergiaP3(),2);
  995.                 $totalEnergia=$totalEnergiaP1+$totalEnergiaP2+$totalEnergiaP3;
  996.                 $reactivaP1=$factura->getReactivaP1()+$factura->getReactivaP4();
  997.                 $reactivaP2=$factura->getReactivaP2()+$factura->getReactivaP5();
  998.                 $excesoReactivaP1=$reactivaP1-0.33*$consumoP1Facturado;
  999.                 $excesoReactivaP2=$reactivaP2-0.33*$consumoP2Facturado;
  1000.                 if($excesoReactivaP1<0)
  1001.                     $excesoReactivaP1=0;
  1002.                 if($excesoReactivaP2<0)
  1003.                     $excesoReactivaP2=0;
  1004.                 $importeReactivaP1=round($excesoReactivaP1*$factura->getPrecioReactivaP1(),2);
  1005.                 $importeReactivaP2=round($excesoReactivaP2*$factura->getPrecioReactivaP2(),2);
  1006.                 $totalReactiva=$importeReactivaP1+$importeReactivaP2;
  1007.                 $subtotal=round($totalEnergia+$totalPotencia+$totalReactiva,2);
  1008.                 $importeImpuesto=round($factura->getImpuesto()*$subtotal/100,2);
  1009.                 $importeAlquiler=round($periodoFacturacion*$factura->getAlquilerEquipos(),2);
  1010.                 $otrosConceptos=0;
  1011.                 foreach ($factura->getConceptos() as $concepto){
  1012.                     $otrosConceptos+=round($concepto->getImporte(),2);
  1013.                 }
  1014.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  1015.                 $importeIva=round($factura->getIva()*$importeTotal/100,2);
  1016.                 $totalFactura=round($importeTotal+$importeIva,2);
  1017.                 if( $totalFactura!==$factura->getTotalFactura() ){
  1018.                     $factura->setTotalFactura($totalFactura);
  1019.                     $this->getDoctrine()->getManager()->flush();
  1020.                 }
  1021.                 //Grafica
  1022.                 if($factura===$facturas[0]){
  1023.                     $consumoMedio=$factura->getTotalFactura();
  1024.                     $consumoAcumulado=$factura->getConsumo();
  1025.                 }
  1026.                 else{
  1027.                     $indiceFactura=array_search($factura, $facturas);
  1028.                     if($indiceFactura<12){
  1029.                         for($i=0;$i<=$indiceFactura && $i<12;$i++){
  1030.                             $consumoMedio+=$facturas[$i]->getTotalFactura();
  1031.                             $consumoAcumulado+=$facturas[$i]->getConsumo();
  1032.                         }
  1033.                         $consumoMedio=$consumoMedio/($indiceFactura+1);
  1034.                     }
  1035.                     else{
  1036.                         for($i=11;$i>=0;$i--){
  1037.                             $n=$indiceFactura-$i;
  1038.                             $consumoMedio+=$facturas[$n]->getTotalFactura();
  1039.                         }
  1040.                         $consumoMedio=$consumoMedio/12;
  1041.                         $ultimaFecha=$factura->getFechaLectura();
  1042.                     }
  1043.                 }
  1044.             }
  1045.             else{
  1046.                 throw $this->createNotFoundException('No se ha encontrado la factura');
  1047.             }
  1048.             $html=$this->renderView('factura/factura.pdf.twig', [
  1049.                 'factura' => $factura,
  1050.                 'entidad'=>$entidad,
  1051.                 'consumoMedio'=>$consumoMedio,
  1052.                 'consumoAcumulado'=>$consumoAcumulado,
  1053.                 'periodoFacturacion'=>$periodoFacturacion,
  1054.                 'potenciaP1Facturada'=>$potenciaP1Facturada??null,
  1055.                 'potenciaP2Facturada'=>$potenciaP2Facturada??null,
  1056.                 'potenciaP3Facturada'=>$potenciaP3Facturada??null,
  1057.                 'totalPotenciaP1'=>$totalPotenciaP1,
  1058.                 'totalPotenciaP2'=>$totalPotenciaP2??null,
  1059.                 'totalPotenciaP3'=>$totalPotenciaP3??null,
  1060.                 'totalPotencia'=>$totalPotencia,
  1061.                 'totalEnergiaP1'=>$totalEnergiaP1,
  1062.                 'totalEnergiaP2'=>$totalEnergiaP2??null,
  1063.                 'totalEnergiaP3'=>$totalEnergiaP3??null,
  1064.                 'totalEnergia'=>$totalEnergia,
  1065.                 'reactivaP1'=>$reactivaP1??null,
  1066.                 'reactivaP2'=>$reactivaP2??null,
  1067.                 'excesoReactivaP1'=>$excesoReactivaP1??null,
  1068.                 'excesoReactivaP2'=>$excesoReactivaP2??null,
  1069.                 'importeReactivaP1'=>$importeReactivaP1??null,
  1070.                 'importeReactivaP2'=>$importeReactivaP2??null,
  1071.                 'totalReactiva'=>$totalReactiva??null,
  1072.                 'subtotal'=>$subtotal,
  1073.                 'importeImpuesto'=>$importeImpuesto,
  1074.                 'importeAlquiler'=>$importeAlquiler,
  1075.                 'otrosConceptos'=>$otrosConceptos,
  1076.                 'importeTotal'=>$importeTotal,
  1077.                 'importeIva'=>$importeIva,
  1078.                 'totalFactura'=>$totalFactura,
  1079.                 'consumoP1Facturado'=>$consumoP1Facturado??null,
  1080.                 'consumoP2Facturado'=>$consumoP2Facturado??null,
  1081.                 'consumoP3Facturado'=>$consumoP3Facturado??null,
  1082.                 'urlImagen'=>$urlImagen
  1083.             ]);
  1084.         }*/
  1085.         if($tarifa->getTipoTarifa()=='Electricidad'){
  1086.             if($tarifa=='3.0A' || $tarifa=='3.1A'){
  1087.                 $periodoFacturacion=date_diff$factura->getFechaLecturaAnterior(), $factura->getFechaLectura() )->days;
  1088.                 $consumoP1Facturado=$factura->getConsumoP1()+$factura->getConsumoP4();
  1089.                 $consumoP2Facturado=$factura->getConsumoP2()+$factura->getConsumoP5();
  1090.                 $consumoP3Facturado=$factura->getConsumoP3()+$factura->getConsumoP6();
  1091.                 $potenciaP1Facturada=$factura->getPotenciaFacturada('P1');
  1092.                 $potenciaP2Facturada=$factura->getPotenciaFacturada('P2');
  1093.                 $potenciaP3Facturada=$factura->getPotenciaFacturada('P3');
  1094.                 $totalPotenciaP1=round($potenciaP1Facturada*$factura->getPrecioPotenciaP1()*$periodoFacturacion,2);
  1095.                 $totalPotenciaP2=round($potenciaP2Facturada*$factura->getPrecioPotenciaP2()*$periodoFacturacion,2);
  1096.                 $totalPotenciaP3=round($potenciaP3Facturada*$factura->getPrecioPotenciaP3()*$periodoFacturacion,2);
  1097.                 $totalPotencia=$totalPotenciaP1+$totalPotenciaP2+$totalPotenciaP3;
  1098.                 $totalEnergiaP1=round($consumoP1Facturado*$factura->getPrecioEnergiaP1(),2);
  1099.                 $totalEnergiaP2=round($consumoP2Facturado*$factura->getPrecioEnergiaP2(),2);
  1100.                 $totalEnergiaP3=round($consumoP3Facturado*$factura->getPrecioEnergiaP3(),2);
  1101.                 $totalEnergia=$totalEnergiaP1+$totalEnergiaP2+$totalEnergiaP3;
  1102.                 $reactivaP1=$factura->getReactivaP1()+$factura->getReactivaP4();
  1103.                 $reactivaP2=$factura->getReactivaP2()+$factura->getReactivaP5();
  1104.                 $excesoReactivaP1=$reactivaP1-0.33*$consumoP1Facturado;
  1105.                 $excesoReactivaP2=$reactivaP2-0.33*$consumoP2Facturado;
  1106.                 if($excesoReactivaP1<0)
  1107.                     $excesoReactivaP1=0;
  1108.                 if($excesoReactivaP2<0)
  1109.                     $excesoReactivaP2=0;
  1110.                 $importeReactivaP1=round($excesoReactivaP1*$factura->getPrecioReactivaP1(),2);
  1111.                 $importeReactivaP2=round($excesoReactivaP2*$factura->getPrecioReactivaP2(),2);
  1112.                 $totalReactiva=$importeReactivaP1+$importeReactivaP2;
  1113.                 $subtotal=round($totalEnergia+$totalPotencia+$totalReactiva,2);
  1114.                 $importeImpuesto=round($factura->getImpuesto()*$subtotal/100,2);
  1115.                 $importeAlquiler=round($periodoFacturacion*$factura->getAlquilerEquipos(),2);
  1116.                 $otrosConceptos=0;
  1117.                 foreach ($factura->getConceptos() as $concepto){
  1118.                     $otrosConceptos+=round($concepto->getImporte(),2);
  1119.                 }
  1120.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  1121.                 $importeIva=round($factura->getIva()*$importeTotal/100,2);
  1122.                 $totalFactura=round($importeTotal+$importeIva,2);
  1123.                 if( $totalFactura!==$factura->getTotalFactura() ){
  1124.                     $factura->setTotalFactura($totalFactura);
  1125.                     $entityManager->flush();
  1126.                 }
  1127.             }
  1128.             else{
  1129.                 $periodoFacturacion=date_diff$factura->getFechaLecturaAnterior(), $factura->getFechaLectura() )->days;
  1130.                 $consumoP1Facturado=$factura->getConsumoP1();
  1131.                 $consumoP2Facturado=$factura->getConsumoP2();
  1132.                 $consumoP3Facturado=$factura->getConsumoP3();
  1133.                 $consumoP4Facturado=$factura->getConsumoP4();
  1134.                 $consumoP5Facturado=$factura->getConsumoP5();
  1135.                 $consumoP6Facturado=$factura->getConsumoP6();
  1136.                 $potenciaP1Facturada=$factura->getPotenciaFacturada('P1');
  1137.                 $potenciaP2Facturada=$factura->getPotenciaFacturada('P2');
  1138.                 $potenciaP3Facturada=$factura->getPotenciaFacturada('P3');
  1139.                 $potenciaP4Facturada=$factura->getPotenciaFacturada('P4');
  1140.                 $potenciaP5Facturada=$factura->getPotenciaFacturada('P5');
  1141.                 $potenciaP6Facturada=$factura->getPotenciaFacturada('P6');
  1142.                 $totalPotenciaP1=round($potenciaP1Facturada*$factura->getPrecioPotenciaP1()*$periodoFacturacion,2);
  1143.                 $totalPotenciaP2=round($potenciaP2Facturada*$factura->getPrecioPotenciaP2()*$periodoFacturacion,2);
  1144.                 $totalPotenciaP3=round($potenciaP3Facturada*$factura->getPrecioPotenciaP3()*$periodoFacturacion,2);
  1145.                 $totalPotenciaP4=round($potenciaP4Facturada*$factura->getPrecioPotenciaP4()*$periodoFacturacion,2);
  1146.                 $totalPotenciaP5=round($potenciaP5Facturada*$factura->getPrecioPotenciaP5()*$periodoFacturacion,2);
  1147.                 $totalPotenciaP6=round($potenciaP6Facturada*$factura->getPrecioPotenciaP6()*$periodoFacturacion,2);
  1148.                 $totalPotencia=$totalPotenciaP1+$totalPotenciaP2+$totalPotenciaP3+$totalPotenciaP4+$totalPotenciaP5+$totalPotenciaP6;
  1149.                 $totalEnergiaP1=round($consumoP1Facturado*$factura->getPrecioEnergiaP1(),2);
  1150.                 $totalEnergiaP2=round($consumoP2Facturado*$factura->getPrecioEnergiaP2(),2);
  1151.                 $totalEnergiaP3=round($consumoP3Facturado*$factura->getPrecioEnergiaP3(),2);
  1152.                 $totalEnergiaP4=round($consumoP4Facturado*$factura->getPrecioEnergiaP4(),2);
  1153.                 $totalEnergiaP5=round($consumoP5Facturado*$factura->getPrecioEnergiaP5(),2);
  1154.                 $totalEnergiaP6=round($consumoP6Facturado*$factura->getPrecioEnergiaP6(),2);
  1155.                 $totalEnergia=$totalEnergiaP1+$totalEnergiaP2+$totalEnergiaP3+$totalEnergiaP4+$totalEnergiaP5+$totalEnergiaP6;
  1156.                 $reactivaP1=$factura->getReactivaP1();
  1157.                 $reactivaP2=$factura->getReactivaP2();
  1158.                 $reactivaP3=$factura->getReactivaP3();
  1159.                 $reactivaP4=$factura->getReactivaP4();
  1160.                 $reactivaP5=$factura->getReactivaP5();
  1161.                 $reactivaP6=$factura->getReactivaP6();
  1162.                 if($reactivaP1!=0)
  1163.                     $excesoReactivaP1=$reactivaP1-0.33*$factura->getConsumoP1();
  1164.                 else
  1165.                     $excesoReactivaP1=0;
  1166.                 if($reactivaP2!=0)
  1167.                     $excesoReactivaP2=$reactivaP2-0.33*$factura->getConsumoP2();
  1168.                 else
  1169.                     $excesoReactivaP2=0;
  1170.                 if($reactivaP3!=0)
  1171.                     $excesoReactivaP3=$reactivaP3-0.33*$factura->getConsumoP3();
  1172.                 else
  1173.                     $excesoReactivaP3=0;
  1174.                 if($reactivaP4!=0)
  1175.                     $excesoReactivaP4=$reactivaP4-0.33*$factura->getConsumoP4();
  1176.                 else
  1177.                     $excesoReactivaP4=0;
  1178.                 if($reactivaP5!=0)
  1179.                     $excesoReactivaP5=$reactivaP5-0.33*$factura->getConsumoP5();
  1180.                 else
  1181.                     $excesoReactivaP5=0;
  1182.                 if($reactivaP6!=0)
  1183.                     $excesoReactivaP6=$reactivaP6-0.33*$factura->getConsumoP6();
  1184.                 else
  1185.                     $excesoReactivaP6=0;
  1186.                 if($excesoReactivaP1<0)
  1187.                     $excesoReactivaP1=0;
  1188.                 if($excesoReactivaP2<0)
  1189.                     $excesoReactivaP2=0;
  1190.                 if($excesoReactivaP3<0)
  1191.                     $excesoReactivaP3=0;
  1192.                 if($excesoReactivaP4<0)
  1193.                     $excesoReactivaP4=0;
  1194.                 if($excesoReactivaP5<0)
  1195.                     $excesoReactivaP5=0;
  1196.                 if($excesoReactivaP6<0)
  1197.                     $excesoReactivaP6=0;
  1198.                 $importeReactivaP1=round($excesoReactivaP1*$factura->getPrecioReactivaP1(),2);
  1199.                 $importeReactivaP2=round($excesoReactivaP2*$factura->getPrecioReactivaP2(),2);
  1200.                 $importeReactivaP3=round($excesoReactivaP3*$factura->getPrecioReactivaP3(),2);
  1201.                 $importeReactivaP4=round($excesoReactivaP4*$factura->getPrecioReactivaP4(),2);
  1202.                 $importeReactivaP5=round($excesoReactivaP5*$factura->getPrecioReactivaP5(),2);
  1203.                 $importeReactivaP6=round($excesoReactivaP6*$factura->getPrecioReactivaP6(),2);
  1204.                 $totalReactiva=$importeReactivaP1+$importeReactivaP2+$importeReactivaP3+$importeReactivaP4+$importeReactivaP5+$importeReactivaP6;
  1205.                 $subtotal=round($totalEnergia+$totalPotencia+$totalReactiva,2);
  1206.                 $importeImpuesto=round($factura->getImpuesto()*$subtotal/100,2);
  1207.                 $importeAlquiler=round($periodoFacturacion*$factura->getAlquilerEquipos(),2);
  1208.                 $otrosConceptos=0;
  1209.                 foreach ($factura->getConceptos() as $concepto){
  1210.                     $otrosConceptos+=round($concepto->getImporte(),2);
  1211.                 }
  1212.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  1213.                 $importeIva=round($factura->getIva()*$importeTotal/100,2);
  1214.                 $totalFactura=round($importeTotal+$importeIva,2);
  1215.                 if( $totalFactura!==$factura->getTotalFactura() ){
  1216.                     $factura->setTotalFactura($totalFactura);
  1217.                     $entityManager->flush();
  1218.                 }
  1219.                 //throw $this->createNotFoundException('No se ha encontrado la factura');
  1220.             }
  1221.             //Grafica
  1222.             $indiceFactura=array_search($factura$facturas);
  1223.             $arrayP=[false,false,false,false,false,false];
  1224.             if($indiceFactura<12){
  1225.                 for($i=0;$i<=$indiceFactura && $i<12;$i++){
  1226.                     $consumoMedio+=$facturas[$i]->getTotalFactura();
  1227.                     $consumoAcumulado+=$facturas[$i]->getConsumo();
  1228.                     $tarifaI=$facturas[$i]->getTarifa();
  1229.                     $arrayPI=[
  1230.                         $tarifaI->getEnergiaP1(),
  1231.                         $tarifaI->getEnergiaP2(),
  1232.                         $tarifaI->getEnergiaP3(),
  1233.                         $tarifaI->getEnergiaP4(),
  1234.                         $tarifaI->getEnergiaP5(),
  1235.                         $tarifaI->getEnergiaP6()
  1236.                     ];
  1237.                     if(!$arrayP[0])
  1238.                         $arrayP[0]=$arrayPI[0];
  1239.                     if(!$arrayP[1])
  1240.                         $arrayP[1]=$arrayPI[1];
  1241.                     if(!$arrayP[2])
  1242.                         $arrayP[2]=$arrayPI[2];
  1243.                     if(!$arrayP[3])
  1244.                         $arrayP[3]=$arrayPI[3];
  1245.                     if(!$arrayP[4])
  1246.                         $arrayP[4]=$arrayPI[4];
  1247.                     if(!$arrayP[5])
  1248.                         $arrayP[5]=$arrayPI[5];
  1249.                     /*if ( $tarifaI=='2.0A' || $tarifaI=='2.1A' ){
  1250.                         $datosGrafica[]=[
  1251.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$i]->getFechaLectura()->getTimestamp()) )),
  1252.                             $facturas[$i]->getConsumoP1(),
  1253.                             0,
  1254.                             0
  1255.                         ];
  1256.                         if ( 1>($numeroP??0) ){
  1257.                             $numeroP=1;
  1258.                         }
  1259.                     }elseif ( $tarifaI=='2.0DHA' || $tarifaI=='2.1DHA' ){
  1260.                         $datosGrafica[]=[
  1261.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$i]->getFechaLectura()->getTimestamp()) )),
  1262.                             $facturas[$i]->getConsumoP1(),
  1263.                             0,
  1264.                             $facturas[$i]->getConsumoP3()
  1265.                         ];
  1266.                         if ( 2>($numeroP??0) ){
  1267.                             $numeroP=2;
  1268.                         }
  1269.                     }else*/
  1270.                     switch( $tarifaI->getNombre() ){
  1271.                         case '3.0A': case '3.1A':
  1272.                         $datosGrafica[]=[
  1273.                             str_replace('.','',strtolowerstrftime('%h-%y',$facturas[$i]->getFechaLectura()->getTimestamp()) )),
  1274.                             $facturas[$i]->getConsumoP1()+$facturas[$i]->getConsumoP4(),
  1275.                             $facturas[$i]->getConsumoP2()+$facturas[$i]->getConsumoP5(),
  1276.                             $facturas[$i]->getConsumoP3()+$facturas[$i]->getConsumoP6(),
  1277.                             0,
  1278.                             0,
  1279.                             0
  1280.                         ];
  1281.                         break;
  1282.                         default:
  1283.                             $datosGrafica[]=[
  1284.                                 str_replace('.','',strtolowerstrftime('%h-%y',$facturas[$i]->getFechaLectura()->getTimestamp()) )),
  1285.                                 $facturas[$i]->getConsumoP1()??0,
  1286.                                 $facturas[$i]->getConsumoP2()??0,
  1287.                                 $facturas[$i]->getConsumoP3()??0,
  1288.                                 $facturas[$i]->getConsumoP4()??0,
  1289.                                 $facturas[$i]->getConsumoP5()??0,
  1290.                                 $facturas[$i]->getConsumoP6()??0,
  1291.                             ];
  1292.                             break;
  1293.                     }
  1294.                 }
  1295.                 $consumoMedio=$consumoMedio/($indiceFactura+1);
  1296.                 $numeroP=countarray_filter($arrayP) );
  1297.             }
  1298.             else{
  1299.                 for($i=11;$i>=0;$i--){
  1300.                     $n=$indiceFactura-$i;
  1301.                     $consumoMedio+=$facturas[$n]->getTotalFactura();
  1302.                     $consumoAcumulado+=$facturas[$n]->getConsumo();
  1303.                     $tarifaI=$facturas[$n]->getTarifa();
  1304.                     $arrayPI=[
  1305.                         $tarifaI->getEnergiaP1(),
  1306.                         $tarifaI->getEnergiaP2(),
  1307.                         $tarifaI->getEnergiaP3(),
  1308.                         $tarifaI->getEnergiaP4(),
  1309.                         $tarifaI->getEnergiaP5(),
  1310.                         $tarifaI->getEnergiaP6()
  1311.                     ];
  1312.                     if(!$arrayP[0])
  1313.                         $arrayP[0]=$arrayPI[0];
  1314.                     if(!$arrayP[1])
  1315.                         $arrayP[1]=$arrayPI[1];
  1316.                     if(!$arrayP[2])
  1317.                         $arrayP[2]=$arrayPI[2];
  1318.                     if(!$arrayP[3])
  1319.                         $arrayP[3]=$arrayPI[3];
  1320.                     if(!$arrayP[4])
  1321.                         $arrayP[4]=$arrayPI[4];
  1322.                     if(!$arrayP[5])
  1323.                         $arrayP[5]=$arrayPI[5];
  1324.                     /*if ( $tarifaI=='2.0A' || $tarifaI=='2.1A' ){
  1325.                         $datosGrafica[]=[
  1326.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$n]->getFechaLectura()->getTimestamp()) )),
  1327.                             $facturas[$n]->getConsumoP1(),
  1328.                             0,
  1329.                             0
  1330.                         ];
  1331.                         if ( 1>($numeroP??0) ){
  1332.                             $numeroP=1;
  1333.                         }
  1334.                     }elseif ( $tarifaI=='2.0DHA' || $tarifaI=='2.1DHA' ){
  1335.                         $datosGrafica[]=[
  1336.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$n]->getFechaLectura()->getTimestamp()) )),
  1337.                             $facturas[$n]->getConsumoP1(),
  1338.                             0,
  1339.                             $facturas[$n]->getConsumoP3()
  1340.                         ];
  1341.                         if ( 2>($numeroP??0) ){
  1342.                             $numeroP=2;
  1343.                         }
  1344.                     }elseif( $tarifaI=='3.0A' || $tarifaI=='3.1A' ){
  1345.                         $datosGrafica[]=[
  1346.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$n]->getFechaLectura()->getTimestamp()) )),
  1347.                             $facturas[$n]->getConsumoP1()+$facturas[$n]->getConsumoP4(),
  1348.                             $facturas[$n]->getConsumoP2()+$facturas[$n]->getConsumoP5(),
  1349.                             $facturas[$n]->getConsumoP3()+$facturas[$n]->getConsumoP6(),
  1350.                         ];
  1351.                     }*/
  1352.                 }
  1353.                 $consumoMedio=$consumoMedio/12;;
  1354.                 $numeroP=countarray_filter($arrayP) );
  1355.             }
  1356.             $params=[
  1357.                 'factura' => $factura,
  1358.                 'entidad'=>$entidad,
  1359.                 'consumoMedio'=>$consumoMedio,
  1360.                 'consumoAcumulado'=>$consumoAcumulado,
  1361.                 'periodoFacturacion'=>$periodoFacturacion,
  1362.                 'potenciaP1Facturada'=>$potenciaP1Facturada??null,
  1363.                 'potenciaP2Facturada'=>$potenciaP2Facturada??null,
  1364.                 'potenciaP3Facturada'=>$potenciaP3Facturada??null,
  1365.                 'potenciaP4Facturada'=>$potenciaP4Facturada??null,
  1366.                 'potenciaP5Facturada'=>$potenciaP5Facturada??null,
  1367.                 'potenciaP6Facturada'=>$potenciaP6Facturada??null,
  1368.                 'totalPotenciaP1'=>$totalPotenciaP1,
  1369.                 'totalPotenciaP2'=>$totalPotenciaP2??null,
  1370.                 'totalPotenciaP3'=>$totalPotenciaP3??null,
  1371.                 'totalPotenciaP4'=>$totalPotenciaP4??null,
  1372.                 'totalPotenciaP5'=>$totalPotenciaP5??null,
  1373.                 'totalPotenciaP6'=>$totalPotenciaP6??null,
  1374.                 'totalPotencia'=>$totalPotencia,
  1375.                 'totalEnergiaP1'=>$totalEnergiaP1,
  1376.                 'totalEnergiaP2'=>$totalEnergiaP2??null,
  1377.                 'totalEnergiaP3'=>$totalEnergiaP3??null,
  1378.                 'totalEnergiaP4'=>$totalEnergiaP4??null,
  1379.                 'totalEnergiaP5'=>$totalEnergiaP5??null,
  1380.                 'totalEnergiaP6'=>$totalEnergiaP6??null,
  1381.                 'totalEnergia'=>$totalEnergia,
  1382.                 'reactivaP1'=>$reactivaP1??null,
  1383.                 'reactivaP2'=>$reactivaP2??null,
  1384.                 'reactivaP3'=>$reactivaP3??null,
  1385.                 'reactivaP4'=>$reactivaP4??null,
  1386.                 'reactivaP5'=>$reactivaP5??null,
  1387.                 'reactivaP6'=>$reactivaP6??null,
  1388.                 'excesoReactivaP1'=>$excesoReactivaP1??null,
  1389.                 'excesoReactivaP2'=>$excesoReactivaP2??null,
  1390.                 'excesoReactivaP3'=>$excesoReactivaP3??null,
  1391.                 'excesoReactivaP4'=>$excesoReactivaP4??null,
  1392.                 'excesoReactivaP5'=>$excesoReactivaP5??null,
  1393.                 'excesoReactivaP6'=>$excesoReactivaP6??null,
  1394.                 'importeReactivaP1'=>$importeReactivaP1??null,
  1395.                 'importeReactivaP2'=>$importeReactivaP2??null,
  1396.                 'importeReactivaP3'=>$importeReactivaP3??null,
  1397.                 'importeReactivaP4'=>$importeReactivaP4??null,
  1398.                 'importeReactivaP5'=>$importeReactivaP5??null,
  1399.                 'importeReactivaP6'=>$importeReactivaP6??null,
  1400.                 'totalReactiva'=>$totalReactiva??null,
  1401.                 'subtotal'=>$subtotal,
  1402.                 'importeImpuesto'=>$importeImpuesto,
  1403.                 'importeAlquiler'=>$importeAlquiler,
  1404.                 'otrosConceptos'=>$otrosConceptos??0,
  1405.                 'importeTotal'=>$importeTotal,
  1406.                 'importeIva'=>$importeIva,
  1407.                 'totalFactura'=>$totalFactura,
  1408.                 'consumoP1Facturado'=>$consumoP1Facturado??null,
  1409.                 'consumoP2Facturado'=>$consumoP2Facturado??null,
  1410.                 'consumoP3Facturado'=>$consumoP3Facturado??null,
  1411.                 'consumoP4Facturado'=>$consumoP4Facturado??null,
  1412.                 'consumoP5Facturado'=>$consumoP5Facturado??null,
  1413.                 'consumoP6Facturado'=>$consumoP6Facturado??null,
  1414.                 'arrayP'=>$arrayP??[true,false,false,false,false,false],
  1415.                 'numeroP'=>$numeroP??1,
  1416.                 'urlImagen'=>$urlImagen
  1417.             ];
  1418.             switch ($_SERVER['APP_ENV']??'finkaluz'){
  1419.                 case 'finkaluz':
  1420.                     $html=$this->renderView('factura/finkaluz.factura.pdf.twig'$params);
  1421.                     break;
  1422.                 case 'emfra':
  1423.                     $html=$this->renderView('factura/emfra.factura.pdf.twig'$params);
  1424.                     break;
  1425.                 case 'onda':
  1426.                     $html=$this->renderView('factura/onda.factura.pdf.twig'$params);
  1427.                     break;
  1428.                 case 'digitel':
  1429.                     $html=$this->renderView('factura/digitel.factura.pdf.twig'$params);
  1430.                     break;
  1431.                 case 'apolo':
  1432.                     $html=$this->renderView('factura/apolo.factura.pdf.twig'$params);
  1433.                     break;
  1434.                 case 'e3': case 'telkes': case 'paladio': case 'arsen': case 'rburgos':
  1435.                     $html=$this->renderView('factura/'.$_SERVER['APP_ENV'].'/factura.pdf.twig'$params);
  1436.                     break;
  1437.                 default:
  1438.                     $html=$this->renderView('factura/factura.pdf.twig'$params);
  1439.                     break;
  1440.             }
  1441.             /*$html=$this->renderView('factura/factura.pdf.twig', [
  1442.                 'factura' => $factura,
  1443.                 'entidad'=>$entidad,
  1444.                 'consumoMedio'=>$consumoMedio,
  1445.                 'consumoAcumulado'=>$consumoAcumulado,
  1446.                 'periodoFacturacion'=>$periodoFacturacion,
  1447.                 'potenciaP1Facturada'=>$potenciaP1Facturada??null,
  1448.                 'potenciaP2Facturada'=>$potenciaP2Facturada??null,
  1449.                 'potenciaP3Facturada'=>$potenciaP3Facturada??null,
  1450.                 'potenciaP4Facturada'=>$potenciaP4Facturada??null,
  1451.                 'potenciaP5Facturada'=>$potenciaP5Facturada??null,
  1452.                 'potenciaP6Facturada'=>$potenciaP6Facturada??null,
  1453.                 'totalPotenciaP1'=>$totalPotenciaP1,
  1454.                 'totalPotenciaP2'=>$totalPotenciaP2??null,
  1455.                 'totalPotenciaP3'=>$totalPotenciaP3??null,
  1456.                 'totalPotenciaP4'=>$totalPotenciaP4??null,
  1457.                 'totalPotenciaP5'=>$totalPotenciaP5??null,
  1458.                 'totalPotenciaP6'=>$totalPotenciaP6??null,
  1459.                 'totalPotencia'=>$totalPotencia,
  1460.                 'totalEnergiaP1'=>$totalEnergiaP1,
  1461.                 'totalEnergiaP2'=>$totalEnergiaP2??null,
  1462.                 'totalEnergiaP3'=>$totalEnergiaP3??null,
  1463.                 'totalEnergiaP4'=>$totalEnergiaP4??null,
  1464.                 'totalEnergiaP5'=>$totalEnergiaP5??null,
  1465.                 'totalEnergiaP6'=>$totalEnergiaP6??null,
  1466.                 'totalEnergia'=>$totalEnergia,
  1467.                 'reactivaP1'=>$reactivaP1??null,
  1468.                 'reactivaP2'=>$reactivaP2??null,
  1469.                 'reactivaP3'=>$reactivaP3??null,
  1470.                 'reactivaP4'=>$reactivaP4??null,
  1471.                 'reactivaP5'=>$reactivaP5??null,
  1472.                 'reactivaP6'=>$reactivaP6??null,
  1473.                 'excesoReactivaP1'=>$excesoReactivaP1??null,
  1474.                 'excesoReactivaP2'=>$excesoReactivaP2??null,
  1475.                 'excesoReactivaP3'=>$excesoReactivaP3??null,
  1476.                 'excesoReactivaP4'=>$excesoReactivaP4??null,
  1477.                 'excesoReactivaP5'=>$excesoReactivaP5??null,
  1478.                 'excesoReactivaP6'=>$excesoReactivaP6??null,
  1479.                 'importeReactivaP1'=>$importeReactivaP1??null,
  1480.                 'importeReactivaP2'=>$importeReactivaP2??null,
  1481.                 'importeReactivaP3'=>$importeReactivaP3??null,
  1482.                 'importeReactivaP4'=>$importeReactivaP4??null,
  1483.                 'importeReactivaP5'=>$importeReactivaP5??null,
  1484.                 'importeReactivaP6'=>$importeReactivaP6??null,
  1485.                 'totalReactiva'=>$totalReactiva??null,
  1486.                 'subtotal'=>$subtotal,
  1487.                 'importeImpuesto'=>$importeImpuesto,
  1488.                 'importeAlquiler'=>$importeAlquiler,
  1489.                 'otrosConceptos'=>$otrosConceptos??0,
  1490.                 'importeTotal'=>$importeTotal,
  1491.                 'importeIva'=>$importeIva,
  1492.                 'totalFactura'=>$totalFactura,
  1493.                 'consumoP1Facturado'=>$consumoP1Facturado??null,
  1494.                 'consumoP2Facturado'=>$consumoP2Facturado??null,
  1495.                 'consumoP3Facturado'=>$consumoP3Facturado??null,
  1496.                 'consumoP4Facturado'=>$consumoP4Facturado??null,
  1497.                 'consumoP5Facturado'=>$consumoP5Facturado??null,
  1498.                 'consumoP6Facturado'=>$consumoP6Facturado??null,
  1499.                 'arrayP'=>$arrayP??[true,false,false,false,false,false],
  1500.                 'numeroP'=>$numeroP??1,
  1501.                 'urlImagen'=>$urlImagen
  1502.             ]);*/
  1503.         }
  1504.         else{
  1505.             $periodoFacturacion=date_diff($factura->getFechaLecturaAnterior(), $factura->getFechaLectura())->days;
  1506.             $totalPotenciaP1=round($factura->getPrecioPotenciaP1()*$periodoFacturacion,2);
  1507.             $totalPotencia=$totalPotenciaP1;
  1508.             $totalEnergiaP1=round($factura->getConsumoConvertidoP1()*$factura->getPrecioEnergiaP1(),2);
  1509.             $totalEnergia=$totalEnergiaP1;
  1510.             $subtotal=round($totalEnergia+$totalPotencia,2);
  1511.             $importeImpuesto=round($factura->getImpuesto()*$factura->getConsumoConvertidoP1(),2);
  1512.             $importeAlquiler=round($periodoFacturacion*$factura->getAlquilerEquipos(),2);
  1513.             $otrosConceptos=0;
  1514.             foreach ($factura->getConceptos() as $concepto){
  1515.                 $otrosConceptos+=round($concepto->getImporte(),2);
  1516.             }
  1517.             $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  1518.             $importeIva=round($factura->getIva()*$importeTotal/100,2);
  1519.             $totalFactura=round($importeTotal+$importeIva,2);
  1520.             if( $totalFactura!==$factura->getTotalFactura() ){
  1521.                 $factura->setTotalFactura($totalFactura);
  1522.                 $entityManager->flush();
  1523.             }
  1524.             //Grafica
  1525.             if($factura === $facturas[0]){
  1526.                 $consumoMedio=$factura->getTotalFactura();
  1527.                 $consumoAcumulado=$factura->getConsumoConvertidoP1();
  1528.             }
  1529.             else{
  1530.                 $indiceFactura=array_search($factura$facturas);
  1531.                 if($indiceFactura<12){
  1532.                     for($i=0;$i<=$indiceFactura && $i<12;$i++){
  1533.                         $consumoMedio+=$facturas[$i]->getTotalFactura();
  1534.                         $consumoAcumulado+=$facturas[$i]->getConsumoConvertidoP1();
  1535.                     }
  1536.                     $consumoMedio=$consumoMedio/($indiceFactura+1);
  1537.                 }
  1538.                 else{
  1539.                     for($i=11;$i>=0;$i--){
  1540.                         $n=$indiceFactura-$i;
  1541.                         $consumoMedio+=$facturas[$n]->getTotalFactura();
  1542.                         $consumoAcumulado+=$factura->getConsumoConvertidoP1()[1];
  1543.                     }
  1544.                     $consumoMedio=$consumoMedio/12;
  1545.                 }
  1546.             }
  1547.             $html=$this->renderView('factura/factura.pdf.twig', [
  1548.                 'factura' => $factura,
  1549.                 'entidad'=>$entidad,
  1550.                 'consumoMedio'=>$consumoMedio,
  1551.                 'consumoAcumulado'=>$consumoAcumulado,
  1552.                 'periodoFacturacion'=>$periodoFacturacion,
  1553.                 'totalPotenciaP1'=>$totalPotenciaP1,
  1554.                 'totalPotencia'=>$totalPotencia,
  1555.                 'totalEnergiaP1'=>$totalEnergiaP1,
  1556.                 'totalEnergia'=>$totalEnergia,
  1557.                 'subtotal'=>$subtotal,
  1558.                 'importeImpuesto'=>$importeImpuesto,
  1559.                 'importeAlquiler'=>$importeAlquiler,
  1560.                 'otrosConceptos'=>$otrosConceptos,
  1561.                 'importeTotal'=>$importeTotal,
  1562.                 'importeIva'=>$importeIva,
  1563.                 'totalFactura'=>$totalFactura,
  1564.                 'urlImagen'=>$urlImagen
  1565.             ]);
  1566.         }
  1567.         return new PdfResponse(
  1568.             $pdf->getOutputFromHtml($html),
  1569.             (str_replace('/',"-",$factura->getNumeroFactura())??'factura_sin_numero').'.pdf'
  1570.         );
  1571.     }
  1572.     /**
  1573.      * @Route("factura/{id}/xml", name="factura_xml", methods={"GET", "POST"})
  1574.      */
  1575.     public function xml(Factura $facturaPdf $pdfRequest $requestFacturaRepository $facturaRepository,
  1576.                         BancoRepository $bancoRepositoryFilesystem $filesystemEntityManagerInterface $entityManager): Response
  1577.     {
  1578.         $this->denyAccessUnlessGranted('ROLE_FACTURACION');
  1579.         $logger = new Logger('factura_logger');
  1580.         $logger->pushHandler(new StreamHandler(__DIR__.'/../../logs/email.log'Logger::DEBUG));
  1581.         $urlImagen $request->request->get("urlImagen");
  1582.         $facturas $facturaRepository->findBy(['contrato' => $factura->getContrato()], ['fechaLectura' => 'ASC']);
  1583.         $tarifa $factura->getTarifa();
  1584.         $entidad $bancoRepository->findByCuenta($factura->getCcc());
  1585.         $consumoAcumulado '0';
  1586.         $consumoMedio '0';
  1587.         /*if ($tarifa->getTipoTarifa() == 'Electricidad') {
  1588.             $subject = 'FACTURA ELECTRICIDAD';
  1589.             $tipo='electricidad';
  1590.             if ($tarifa == '2.0A' || $tarifa == '2.1A') {
  1591.                 $periodoFacturacion = date_diff($factura->getFechaLecturaAnterior(), $factura->getFechaLectura())->days;
  1592.                 $totalPotenciaP1 = round($factura->getPotenciaP1() * $factura->getPrecioPotenciaP1() * $periodoFacturacion, 2);
  1593.                 $totalPotencia = $totalPotenciaP1;
  1594.                 $totalEnergiaP1 = round($factura->getConsumoP1() * $factura->getPrecioEnergiaP1(), 2);
  1595.                 $totalEnergia = $totalEnergiaP1;
  1596.                 $subtotal = round($totalEnergia + $totalPotencia, 2);
  1597.                 $importeImpuesto = round($factura->getImpuesto() * $subtotal / 100, 2);
  1598.                 $importeAlquiler = round($periodoFacturacion * $factura->getAlquilerEquipos(), 2);
  1599.                 $otrosConceptos=0;
  1600.                 foreach ($factura->getConceptos() as $concepto){
  1601.                     $otrosConceptos+=round($concepto->getImporte(),2);
  1602.                 }
  1603.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  1604.                 $importeIva = round($factura->getIva() * $importeTotal / 100, 2);
  1605.                 $totalFactura = round($importeTotal + $importeIva, 2);
  1606.                 if ($totalFactura !== $factura->getTotalFactura()) {
  1607.                     $factura->setTotalFactura($totalFactura);
  1608.                     $this->getDoctrine()->getManager()->flush();
  1609.                 }
  1610.                 //Grafica
  1611.                 if ($factura === $facturas[0]) {
  1612.                     $consumoMedio = $factura->getTotalFactura();
  1613.                     $consumoAcumulado = $factura->getLecturaEnergiaP1() - $factura->getLecturaAnteriorP1();
  1614.                 } else {
  1615.                     $indiceFactura = array_search($factura, $facturas);
  1616.                     if ($indiceFactura < 12) {
  1617.                         for ($i = 0; $i <= $indiceFactura && $i < 12; $i++) {
  1618.                             $consumoMedio += $facturas[$i]->getTotalFactura();
  1619.                             $consumoAcumulado += $facturas[$i]->getConsumo();
  1620.                         }
  1621.                         $consumoMedio = $consumoMedio / ($indiceFactura + 1);
  1622.                     } else {
  1623.                         for ($i = 11; $i >= 0; $i--) {
  1624.                             $n = $indiceFactura - $i;
  1625.                             $consumoMedio += $facturas[$n]->getTotalFactura();
  1626.                             $consumoAcumulado += $factura->getConsumo()[1];
  1627.                         }
  1628.                         $consumoMedio = $consumoMedio / 12;
  1629.                     }
  1630.                 }
  1631.             }
  1632.             elseif ($tarifa == '2.0DHA' || $tarifa == '2.1DHA') {
  1633.                 $periodoFacturacion = date_diff($factura->getFechaLecturaAnterior(), $factura->getFechaLectura())->days;
  1634.                 $totalPotenciaP1 = round($factura->getPotenciaP1() * $factura->getPrecioPotenciaP1() * $periodoFacturacion, 2);
  1635.                 $totalPotencia = $totalPotenciaP1;
  1636.                 $totalEnergiaP1 = round($factura->getConsumoP1() * $factura->getPrecioEnergiaP1(), 2);
  1637.                 $totalEnergiaP3 = round($factura->getConsumoP3() * $factura->getPrecioEnergiaP3(), 2);
  1638.                 $totalEnergia = $totalEnergiaP1 + $totalEnergiaP3;
  1639.                 $subtotal = round($totalEnergia + $totalPotencia, 2);
  1640.                 $importeImpuesto = round($factura->getImpuesto() * $subtotal / 100, 2);
  1641.                 $importeAlquiler = round($periodoFacturacion * $factura->getAlquilerEquipos(), 2);
  1642.                 $otrosConceptos=0;
  1643.                 foreach ($factura->getConceptos() as $concepto){
  1644.                     $otrosConceptos+=round($concepto->getImporte(),2);
  1645.                 }
  1646.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  1647.                 $importeIva = round($factura->getIva() * $importeTotal / 100, 2);
  1648.                 $totalFactura = round($importeTotal + $importeIva, 2);
  1649.                 if ($totalFactura !== $factura->getTotalFactura()) {
  1650.                     $factura->setTotalFactura($totalFactura);
  1651.                     $this->getDoctrine()->getManager()->flush();
  1652.                 }
  1653.                 //Grafica
  1654.                 if ($factura === $facturas[0]) {
  1655.                     $consumoMedio = $factura->getTotalFactura();
  1656.                     $consumoAcumulado = $factura->getConsumo();
  1657.                 } else {
  1658.                     $indiceFactura = array_search($factura, $facturas);
  1659.                     if ($indiceFactura < 12) {
  1660.                         for ($i = 0; $i <= $indiceFactura && $i < 12; $i++) {
  1661.                             $consumoMedio += $facturas[$i]->getTotalFactura();
  1662.                             $consumoAcumulado += $facturas[$i]->getConsumo();
  1663.                         }
  1664.                         $consumoMedio = $consumoMedio / ($indiceFactura + 1);
  1665.                     } else {
  1666.                         for ($i = 11; $i >= 0; $i--) {
  1667.                             $n = $indiceFactura - $i;
  1668.                             $consumoMedio += $facturas[$n]->getTotalFactura();
  1669.                             $consumoAcumulado += $facturas[$i]->getConsumo();
  1670.                         }
  1671.                         $consumoMedio = $consumoMedio / 12;
  1672.                     }
  1673.                 }
  1674.             }
  1675.             elseif ($tarifa == '3.0A' || $tarifa == '3.1A') {
  1676.                 $periodoFacturacion = date_diff($factura->getFechaLecturaAnterior(), $factura->getFechaLectura())->days;
  1677.                 $consumoP1Facturado = $factura->getConsumoP1() + $factura->getConsumoP4();
  1678.                 $consumoP2Facturado = $factura->getConsumoP2() + $factura->getConsumoP5();
  1679.                 $consumoP3Facturado = $factura->getConsumoP3() + $factura->getConsumoP6();
  1680.                 $potenciaP1Facturada = $factura->getPotenciaFacturada('P1');
  1681.                 $potenciaP2Facturada = $factura->getPotenciaFacturada('P2');
  1682.                 $potenciaP3Facturada = $factura->getPotenciaFacturada('P3');
  1683.                 $totalPotenciaP1 = round($potenciaP1Facturada * $factura->getPrecioPotenciaP1() * $periodoFacturacion, 2);
  1684.                 $totalPotenciaP2 = round($potenciaP2Facturada * $factura->getPrecioPotenciaP2() * $periodoFacturacion, 2);
  1685.                 $totalPotenciaP3 = round($potenciaP3Facturada * $factura->getPrecioPotenciaP3() * $periodoFacturacion, 2);
  1686.                 $totalPotencia = $totalPotenciaP1 + $totalPotenciaP2 + $totalPotenciaP3;
  1687.                 $totalEnergiaP1 = round($consumoP1Facturado * $factura->getPrecioEnergiaP1(), 2);
  1688.                 $totalEnergiaP2 = round($consumoP2Facturado * $factura->getPrecioEnergiaP2(), 2);
  1689.                 $totalEnergiaP3 = round($consumoP3Facturado * $factura->getPrecioEnergiaP3(), 2);
  1690.                 $totalEnergia = $totalEnergiaP1 + $totalEnergiaP2 + $totalEnergiaP3;
  1691.                 $reactivaP1 = $factura->getReactivaP1() + $factura->getReactivaP4();
  1692.                 $reactivaP2 = $factura->getReactivaP2() + $factura->getReactivaP5();
  1693.                 $excesoReactivaP1 = $reactivaP1 - 0.33 * $consumoP1Facturado;
  1694.                 $excesoReactivaP2 = $reactivaP2 - 0.33 * $consumoP2Facturado;
  1695.                 if($excesoReactivaP1<0)
  1696.                     $excesoReactivaP1=0;
  1697.                 if($excesoReactivaP2<0)
  1698.                     $excesoReactivaP2=0;
  1699.                 $importeReactivaP1 = round($excesoReactivaP1 * $factura->getPrecioReactivaP1(), 2);
  1700.                 $importeReactivaP2 = round($excesoReactivaP2 * $factura->getPrecioReactivaP2(), 2);
  1701.                 $totalReactiva = $importeReactivaP1 + $importeReactivaP2;
  1702.                 $subtotal = round($totalEnergia + $totalPotencia + $totalReactiva, 2);
  1703.                 $importeImpuesto = round($factura->getImpuesto() * $subtotal / 100, 2);
  1704.                 $importeAlquiler = round($periodoFacturacion * $factura->getAlquilerEquipos(), 2);
  1705.                 $otrosConceptos=0;
  1706.                 foreach ($factura->getConceptos() as $concepto){
  1707.                     $otrosConceptos+=round($concepto->getImporte(),2);
  1708.                 }
  1709.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  1710.                 $importeIva = round($factura->getIva() * $importeTotal / 100, 2);
  1711.                 $totalFactura = round($importeTotal + $importeIva, 2);
  1712.                 if ($totalFactura !== $factura->getTotalFactura()) {
  1713.                     $factura->setTotalFactura($totalFactura);
  1714.                     $this->getDoctrine()->getManager()->flush();
  1715.                 }
  1716.                 //Grafica
  1717.                 if ($factura === $facturas[0]) {
  1718.                     $consumoMedio = $factura->getTotalFactura();
  1719.                     $consumoAcumulado = $factura->getConsumo();
  1720.                 } else {
  1721.                     $indiceFactura = array_search($factura, $facturas);
  1722.                     if ($indiceFactura < 12) {
  1723.                         for ($i = 0; $i <= $indiceFactura && $i < 12; $i++) {
  1724.                             $consumoMedio += $facturas[$i]->getTotalFactura();
  1725.                             $consumoAcumulado += $facturas[$i]->getConsumo();
  1726.                         }
  1727.                         $consumoMedio = $consumoMedio / ($indiceFactura + 1);
  1728.                     } else {
  1729.                         for ($i = 11; $i >= 0; $i--) {
  1730.                             $n = $indiceFactura - $i;
  1731.                             $consumoMedio += $facturas[$n]->getTotalFactura();
  1732.                         }
  1733.                         $consumoMedio = $consumoMedio / 12;
  1734.                         $ultimaFecha = $factura->getFechaLectura();
  1735.                     }
  1736.                 }
  1737.             } else {
  1738.                 throw $this->createNotFoundException('No se ha encontrado la factura');
  1739.             }
  1740.             $html = $this->renderView('factura/factura.pdf.twig', [
  1741.                 'factura' => $factura,
  1742.                 'entidad' => $entidad,
  1743.                 'consumoMedio' => $consumoMedio,
  1744.                 'consumoAcumulado' => $consumoAcumulado,
  1745.                 'periodoFacturacion' => $periodoFacturacion,
  1746.                 'potenciaP1Facturada' => $potenciaP1Facturada ?? null,
  1747.                 'potenciaP2Facturada' => $potenciaP2Facturada ?? null,
  1748.                 'potenciaP3Facturada' => $potenciaP3Facturada ?? null,
  1749.                 'totalPotenciaP1' => $totalPotenciaP1,
  1750.                 'totalPotenciaP2' => $totalPotenciaP2 ?? null,
  1751.                 'totalPotenciaP3' => $totalPotenciaP3 ?? null,
  1752.                 'totalPotencia' => $totalPotencia,
  1753.                 'totalEnergiaP1' => $totalEnergiaP1,
  1754.                 'totalEnergiaP2' => $totalEnergiaP2 ?? null,
  1755.                 'totalEnergiaP3' => $totalEnergiaP3 ?? null,
  1756.                 'totalEnergia' => $totalEnergia,
  1757.                 'reactivaP1' => $reactivaP1 ?? null,
  1758.                 'reactivaP2' => $reactivaP2 ?? null,
  1759.                 'excesoReactivaP1' => $excesoReactivaP1 ?? null,
  1760.                 'excesoReactivaP2' => $excesoReactivaP2 ?? null,
  1761.                 'importeReactivaP1' => $importeReactivaP1 ?? null,
  1762.                 'importeReactivaP2' => $importeReactivaP2 ?? null,
  1763.                 'totalReactiva' => $totalReactiva ?? null,
  1764.                 'subtotal' => $subtotal,
  1765.                 'importeImpuesto' => $importeImpuesto,
  1766.                 'importeAlquiler' => $importeAlquiler,
  1767.                 'otrosConceptos'=>$otrosConceptos,
  1768.                 'importeTotal' => $importeTotal,
  1769.                 'importeIva' => $importeIva,
  1770.                 'totalFactura' => $totalFactura,
  1771.                 'consumoP1Facturado' => $consumoP1Facturado ?? null,
  1772.                 'consumoP2Facturado' => $consumoP2Facturado ?? null,
  1773.                 'consumoP3Facturado' => $consumoP3Facturado ?? null,
  1774.                 'urlImagen' => $urlImagen
  1775.             ]);
  1776.         }*/
  1777.         if($tarifa->getTipoTarifa()=='Electricidad'){
  1778.             $subject 'FACTURA ELECTRICIDAD';
  1779.             $tipo='electricidad';
  1780.             if($tarifa=='3.0A' || $tarifa=='3.1A'){
  1781.                 $periodoFacturacion=date_diff$factura->getFechaLecturaAnterior(), $factura->getFechaLectura() )->days;
  1782.                 $consumoP1Facturado=$factura->getConsumoP1()+$factura->getConsumoP4();
  1783.                 $consumoP2Facturado=$factura->getConsumoP2()+$factura->getConsumoP5();
  1784.                 $consumoP3Facturado=$factura->getConsumoP3()+$factura->getConsumoP6();
  1785.                 $potenciaP1Facturada=$factura->getPotenciaFacturada('P1');
  1786.                 $potenciaP2Facturada=$factura->getPotenciaFacturada('P2');
  1787.                 $potenciaP3Facturada=$factura->getPotenciaFacturada('P3');
  1788.                 $totalPotenciaP1=round($potenciaP1Facturada*$factura->getPrecioPotenciaP1()*$periodoFacturacion,2);
  1789.                 $totalPotenciaP2=round($potenciaP2Facturada*$factura->getPrecioPotenciaP2()*$periodoFacturacion,2);
  1790.                 $totalPotenciaP3=round($potenciaP3Facturada*$factura->getPrecioPotenciaP3()*$periodoFacturacion,2);
  1791.                 $totalPotencia=$totalPotenciaP1+$totalPotenciaP2+$totalPotenciaP3;
  1792.                 $totalEnergiaP1=round($consumoP1Facturado*$factura->getPrecioEnergiaP1(),2);
  1793.                 $totalEnergiaP2=round($consumoP2Facturado*$factura->getPrecioEnergiaP2(),2);
  1794.                 $totalEnergiaP3=round($consumoP3Facturado*$factura->getPrecioEnergiaP3(),2);
  1795.                 $totalEnergia=$totalEnergiaP1+$totalEnergiaP2+$totalEnergiaP3;
  1796.                 $reactivaP1=$factura->getReactivaP1()+$factura->getReactivaP4();
  1797.                 $reactivaP2=$factura->getReactivaP2()+$factura->getReactivaP5();
  1798.                 $excesoReactivaP1=$reactivaP1-0.33*$consumoP1Facturado;
  1799.                 $excesoReactivaP2=$reactivaP2-0.33*$consumoP2Facturado;
  1800.                 if($excesoReactivaP1<0)
  1801.                     $excesoReactivaP1=0;
  1802.                 if($excesoReactivaP2<0)
  1803.                     $excesoReactivaP2=0;
  1804.                 $importeReactivaP1=round($excesoReactivaP1*$factura->getPrecioReactivaP1(),2);
  1805.                 $importeReactivaP2=round($excesoReactivaP2*$factura->getPrecioReactivaP2(),2);
  1806.                 $totalReactiva=$importeReactivaP1+$importeReactivaP2;
  1807.                 $subtotal=round($totalEnergia+$totalPotencia+$totalReactiva,2);
  1808.                 $importeImpuesto=round($factura->getImpuesto()*$subtotal/100,2);
  1809.                 $importeAlquiler=round($periodoFacturacion*$factura->getAlquilerEquipos(),2);
  1810.                 $otrosConceptos=0;
  1811.                 foreach ($factura->getConceptos() as $concepto){
  1812.                     $otrosConceptos+=round($concepto->getImporte(),2);
  1813.                 }
  1814.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  1815.                 $importeIva=round($factura->getIva()*$importeTotal/100,2);
  1816.                 $totalFactura=round($importeTotal+$importeIva,2);
  1817.                 if( $totalFactura!==$factura->getTotalFactura() ){
  1818.                     $factura->setTotalFactura($totalFactura);
  1819.                     $entityManager->flush();
  1820.                 }
  1821.             }
  1822.             else{
  1823.                 $periodoFacturacion=date_diff$factura->getFechaLecturaAnterior(), $factura->getFechaLectura() )->days;
  1824.                 $consumoP1Facturado=$factura->getConsumoP1();
  1825.                 $consumoP2Facturado=$factura->getConsumoP2();
  1826.                 $consumoP3Facturado=$factura->getConsumoP3();
  1827.                 $consumoP4Facturado=$factura->getConsumoP4();
  1828.                 $consumoP5Facturado=$factura->getConsumoP5();
  1829.                 $consumoP6Facturado=$factura->getConsumoP6();
  1830.                 $potenciaP1Facturada=$factura->getPotenciaFacturada('P1');
  1831.                 $potenciaP2Facturada=$factura->getPotenciaFacturada('P2');
  1832.                 $potenciaP3Facturada=$factura->getPotenciaFacturada('P3');
  1833.                 $potenciaP4Facturada=$factura->getPotenciaFacturada('P4');
  1834.                 $potenciaP5Facturada=$factura->getPotenciaFacturada('P5');
  1835.                 $potenciaP6Facturada=$factura->getPotenciaFacturada('P6');
  1836.                 $totalPotenciaP1=round($potenciaP1Facturada*$factura->getPrecioPotenciaP1()*$periodoFacturacion,2);
  1837.                 $totalPotenciaP2=round($potenciaP2Facturada*$factura->getPrecioPotenciaP2()*$periodoFacturacion,2);
  1838.                 $totalPotenciaP3=round($potenciaP3Facturada*$factura->getPrecioPotenciaP3()*$periodoFacturacion,2);
  1839.                 $totalPotenciaP4=round($potenciaP4Facturada*$factura->getPrecioPotenciaP4()*$periodoFacturacion,2);
  1840.                 $totalPotenciaP5=round($potenciaP5Facturada*$factura->getPrecioPotenciaP5()*$periodoFacturacion,2);
  1841.                 $totalPotenciaP6=round($potenciaP6Facturada*$factura->getPrecioPotenciaP6()*$periodoFacturacion,2);
  1842.                 $totalPotencia=$totalPotenciaP1+$totalPotenciaP2+$totalPotenciaP3+$totalPotenciaP4+$totalPotenciaP5+$totalPotenciaP6;
  1843.                 $totalEnergiaP1=round($consumoP1Facturado*$factura->getPrecioEnergiaP1(),2);
  1844.                 $totalEnergiaP2=round($consumoP2Facturado*$factura->getPrecioEnergiaP2(),2);
  1845.                 $totalEnergiaP3=round($consumoP3Facturado*$factura->getPrecioEnergiaP3(),2);
  1846.                 $totalEnergiaP4=round($consumoP4Facturado*$factura->getPrecioEnergiaP4(),2);
  1847.                 $totalEnergiaP5=round($consumoP5Facturado*$factura->getPrecioEnergiaP5(),2);
  1848.                 $totalEnergiaP6=round($consumoP6Facturado*$factura->getPrecioEnergiaP6(),2);
  1849.                 $totalEnergia=$totalEnergiaP1+$totalEnergiaP2+$totalEnergiaP3+$totalEnergiaP4+$totalEnergiaP5+$totalEnergiaP6;
  1850.                 $reactivaP1=$factura->getReactivaP1();
  1851.                 $reactivaP2=$factura->getReactivaP2();
  1852.                 $reactivaP3=$factura->getReactivaP3();
  1853.                 $reactivaP4=$factura->getReactivaP4();
  1854.                 $reactivaP5=$factura->getReactivaP5();
  1855.                 $reactivaP6=$factura->getReactivaP6();
  1856.                 if($reactivaP1!=0)
  1857.                     $excesoReactivaP1=$reactivaP1-0.33*$factura->getConsumoP1();
  1858.                 else
  1859.                     $excesoReactivaP1=0;
  1860.                 if($reactivaP2!=0)
  1861.                     $excesoReactivaP2=$reactivaP2-0.33*$factura->getConsumoP2();
  1862.                 else
  1863.                     $excesoReactivaP2=0;
  1864.                 if($reactivaP3!=0)
  1865.                     $excesoReactivaP3=$reactivaP3-0.33*$factura->getConsumoP3();
  1866.                 else
  1867.                     $excesoReactivaP3=0;
  1868.                 if($reactivaP4!=0)
  1869.                     $excesoReactivaP4=$reactivaP4-0.33*$factura->getConsumoP4();
  1870.                 else
  1871.                     $excesoReactivaP4=0;
  1872.                 if($reactivaP5!=0)
  1873.                     $excesoReactivaP5=$reactivaP5-0.33*$factura->getConsumoP5();
  1874.                 else
  1875.                     $excesoReactivaP5=0;
  1876.                 if($reactivaP6!=0)
  1877.                     $excesoReactivaP6=$reactivaP6-0.33*$factura->getConsumoP6();
  1878.                 else
  1879.                     $excesoReactivaP6=0;
  1880.                 if($excesoReactivaP1<0)
  1881.                     $excesoReactivaP1=0;
  1882.                 if($excesoReactivaP2<0)
  1883.                     $excesoReactivaP2=0;
  1884.                 if($excesoReactivaP3<0)
  1885.                     $excesoReactivaP3=0;
  1886.                 if($excesoReactivaP4<0)
  1887.                     $excesoReactivaP4=0;
  1888.                 if($excesoReactivaP5<0)
  1889.                     $excesoReactivaP5=0;
  1890.                 if($excesoReactivaP6<0)
  1891.                     $excesoReactivaP6=0;
  1892.                 $importeReactivaP1=round($excesoReactivaP1*$factura->getPrecioReactivaP1(),2);
  1893.                 $importeReactivaP2=round($excesoReactivaP2*$factura->getPrecioReactivaP2(),2);
  1894.                 $importeReactivaP3=round($excesoReactivaP3*$factura->getPrecioReactivaP3(),2);
  1895.                 $importeReactivaP4=round($excesoReactivaP4*$factura->getPrecioReactivaP4(),2);
  1896.                 $importeReactivaP5=round($excesoReactivaP5*$factura->getPrecioReactivaP5(),2);
  1897.                 $importeReactivaP6=round($excesoReactivaP6*$factura->getPrecioReactivaP6(),2);
  1898.                 $totalReactiva=$importeReactivaP1+$importeReactivaP2+$importeReactivaP3+$importeReactivaP4+$importeReactivaP5+$importeReactivaP6;
  1899.                 $subtotal=round($totalEnergia+$totalPotencia+$totalReactiva,2);
  1900.                 $importeImpuesto=round($factura->getImpuesto()*$subtotal/100,2);
  1901.                 $importeAlquiler=round($periodoFacturacion*$factura->getAlquilerEquipos(),2);
  1902.                 $otrosConceptos=0;
  1903.                 foreach ($factura->getConceptos() as $concepto){
  1904.                     $otrosConceptos+=round($concepto->getImporte(),2);
  1905.                 }
  1906.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  1907.                 $importeIva=round($factura->getIva()*$importeTotal/100,2);
  1908.                 $totalFactura=round($importeTotal+$importeIva,2);
  1909.                 if( $totalFactura!==$factura->getTotalFactura() ){
  1910.                     $factura->setTotalFactura($totalFactura);
  1911.                     $entityManager->flush();
  1912.                 }
  1913.                 //throw $this->createNotFoundException('No se ha encontrado la factura');
  1914.             }
  1915.             //Grafica
  1916.             $indiceFactura=array_search($factura$facturas);
  1917.             $arrayP=[false,false,false,false,false,false];
  1918.             if($indiceFactura<12){
  1919.                 for($i=0;$i<=$indiceFactura && $i<12;$i++){
  1920.                     $consumoMedio+=$facturas[$i]->getTotalFactura();
  1921.                     $consumoAcumulado+=$facturas[$i]->getConsumo();
  1922.                     $tarifaI=$facturas[$i]->getTarifa();
  1923.                     $arrayPI=[
  1924.                         $tarifaI->getEnergiaP1(),
  1925.                         $tarifaI->getEnergiaP2(),
  1926.                         $tarifaI->getEnergiaP3(),
  1927.                         $tarifaI->getEnergiaP4(),
  1928.                         $tarifaI->getEnergiaP5(),
  1929.                         $tarifaI->getEnergiaP6()
  1930.                     ];
  1931.                     if(!$arrayP[0])
  1932.                         $arrayP[0]=$arrayPI[0];
  1933.                     if(!$arrayP[1])
  1934.                         $arrayP[1]=$arrayPI[1];
  1935.                     if(!$arrayP[2])
  1936.                         $arrayP[2]=$arrayPI[2];
  1937.                     if(!$arrayP[3])
  1938.                         $arrayP[3]=$arrayPI[3];
  1939.                     if(!$arrayP[4])
  1940.                         $arrayP[4]=$arrayPI[4];
  1941.                     if(!$arrayP[5])
  1942.                         $arrayP[5]=$arrayPI[5];
  1943.                     /*if ( $tarifaI=='2.0A' || $tarifaI=='2.1A' ){
  1944.                         $datosGrafica[]=[
  1945.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$i]->getFechaLectura()->getTimestamp()) )),
  1946.                             $facturas[$i]->getConsumoP1(),
  1947.                             0,
  1948.                             0
  1949.                         ];
  1950.                         if ( 1>($numeroP??0) ){
  1951.                             $numeroP=1;
  1952.                         }
  1953.                     }elseif ( $tarifaI=='2.0DHA' || $tarifaI=='2.1DHA' ){
  1954.                         $datosGrafica[]=[
  1955.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$i]->getFechaLectura()->getTimestamp()) )),
  1956.                             $facturas[$i]->getConsumoP1(),
  1957.                             0,
  1958.                             $facturas[$i]->getConsumoP3()
  1959.                         ];
  1960.                         if ( 2>($numeroP??0) ){
  1961.                             $numeroP=2;
  1962.                         }
  1963.                     }else*/
  1964.                     switch( $tarifaI->getNombre() ){
  1965.                         case '3.0A': case '3.1A':
  1966.                         $datosGrafica[]=[
  1967.                             str_replace('.','',strtolowerstrftime('%h-%y',$facturas[$i]->getFechaLectura()->getTimestamp()) )),
  1968.                             $facturas[$i]->getConsumoP1()+$facturas[$i]->getConsumoP4(),
  1969.                             $facturas[$i]->getConsumoP2()+$facturas[$i]->getConsumoP5(),
  1970.                             $facturas[$i]->getConsumoP3()+$facturas[$i]->getConsumoP6(),
  1971.                             0,
  1972.                             0,
  1973.                             0
  1974.                         ];
  1975.                         break;
  1976.                         default:
  1977.                             $datosGrafica[]=[
  1978.                                 str_replace('.','',strtolowerstrftime('%h-%y',$facturas[$i]->getFechaLectura()->getTimestamp()) )),
  1979.                                 $facturas[$i]->getConsumoP1()??0,
  1980.                                 $facturas[$i]->getConsumoP2()??0,
  1981.                                 $facturas[$i]->getConsumoP3()??0,
  1982.                                 $facturas[$i]->getConsumoP4()??0,
  1983.                                 $facturas[$i]->getConsumoP5()??0,
  1984.                                 $facturas[$i]->getConsumoP6()??0,
  1985.                             ];
  1986.                             break;
  1987.                     }
  1988.                 }
  1989.                 $consumoMedio=$consumoMedio/($indiceFactura+1);
  1990.                 $numeroP=countarray_filter($arrayP) );
  1991.             }
  1992.             else{
  1993.                 for($i=11;$i>=0;$i--){
  1994.                     $n=$indiceFactura-$i;
  1995.                     $consumoMedio+=$facturas[$n]->getTotalFactura();
  1996.                     $consumoAcumulado+=$facturas[$n]->getConsumo();
  1997.                     $tarifaI=$facturas[$n]->getTarifa();
  1998.                     $arrayPI=[
  1999.                         $tarifaI->getEnergiaP1(),
  2000.                         $tarifaI->getEnergiaP2(),
  2001.                         $tarifaI->getEnergiaP3(),
  2002.                         $tarifaI->getEnergiaP4(),
  2003.                         $tarifaI->getEnergiaP5(),
  2004.                         $tarifaI->getEnergiaP6()
  2005.                     ];
  2006.                     if(!$arrayP[0])
  2007.                         $arrayP[0]=$arrayPI[0];
  2008.                     if(!$arrayP[1])
  2009.                         $arrayP[1]=$arrayPI[1];
  2010.                     if(!$arrayP[2])
  2011.                         $arrayP[2]=$arrayPI[2];
  2012.                     if(!$arrayP[3])
  2013.                         $arrayP[3]=$arrayPI[3];
  2014.                     if(!$arrayP[4])
  2015.                         $arrayP[4]=$arrayPI[4];
  2016.                     if(!$arrayP[5])
  2017.                         $arrayP[5]=$arrayPI[5];
  2018.                     /*if ( $tarifaI=='2.0A' || $tarifaI=='2.1A' ){
  2019.                         $datosGrafica[]=[
  2020.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$n]->getFechaLectura()->getTimestamp()) )),
  2021.                             $facturas[$n]->getConsumoP1(),
  2022.                             0,
  2023.                             0
  2024.                         ];
  2025.                         if ( 1>($numeroP??0) ){
  2026.                             $numeroP=1;
  2027.                         }
  2028.                     }elseif ( $tarifaI=='2.0DHA' || $tarifaI=='2.1DHA' ){
  2029.                         $datosGrafica[]=[
  2030.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$n]->getFechaLectura()->getTimestamp()) )),
  2031.                             $facturas[$n]->getConsumoP1(),
  2032.                             0,
  2033.                             $facturas[$n]->getConsumoP3()
  2034.                         ];
  2035.                         if ( 2>($numeroP??0) ){
  2036.                             $numeroP=2;
  2037.                         }
  2038.                     }elseif( $tarifaI=='3.0A' || $tarifaI=='3.1A' ){
  2039.                         $datosGrafica[]=[
  2040.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$n]->getFechaLectura()->getTimestamp()) )),
  2041.                             $facturas[$n]->getConsumoP1()+$facturas[$n]->getConsumoP4(),
  2042.                             $facturas[$n]->getConsumoP2()+$facturas[$n]->getConsumoP5(),
  2043.                             $facturas[$n]->getConsumoP3()+$facturas[$n]->getConsumoP6(),
  2044.                         ];
  2045.                     }*/
  2046.                 }
  2047.                 $consumoMedio=$consumoMedio/12;;
  2048.                 $numeroP=countarray_filter($arrayP) );
  2049.             }
  2050.             $params=[
  2051.                 'factura' => $factura,
  2052.                 'entidad'=>$entidad,
  2053.                 'consumoMedio'=>$consumoMedio,
  2054.                 'consumoAcumulado'=>$consumoAcumulado,
  2055.                 'periodoFacturacion'=>$periodoFacturacion,
  2056.                 'potenciaP1Facturada'=>$potenciaP1Facturada??null,
  2057.                 'potenciaP2Facturada'=>$potenciaP2Facturada??null,
  2058.                 'potenciaP3Facturada'=>$potenciaP3Facturada??null,
  2059.                 'potenciaP4Facturada'=>$potenciaP4Facturada??null,
  2060.                 'potenciaP5Facturada'=>$potenciaP5Facturada??null,
  2061.                 'potenciaP6Facturada'=>$potenciaP6Facturada??null,
  2062.                 'totalPotenciaP1'=>$totalPotenciaP1,
  2063.                 'totalPotenciaP2'=>$totalPotenciaP2??null,
  2064.                 'totalPotenciaP3'=>$totalPotenciaP3??null,
  2065.                 'totalPotenciaP4'=>$totalPotenciaP4??null,
  2066.                 'totalPotenciaP5'=>$totalPotenciaP5??null,
  2067.                 'totalPotenciaP6'=>$totalPotenciaP6??null,
  2068.                 'totalPotencia'=>$totalPotencia,
  2069.                 'totalEnergiaP1'=>$totalEnergiaP1,
  2070.                 'totalEnergiaP2'=>$totalEnergiaP2??null,
  2071.                 'totalEnergiaP3'=>$totalEnergiaP3??null,
  2072.                 'totalEnergiaP4'=>$totalEnergiaP4??null,
  2073.                 'totalEnergiaP5'=>$totalEnergiaP5??null,
  2074.                 'totalEnergiaP6'=>$totalEnergiaP6??null,
  2075.                 'totalEnergia'=>$totalEnergia,
  2076.                 'reactivaP1'=>$reactivaP1??null,
  2077.                 'reactivaP2'=>$reactivaP2??null,
  2078.                 'reactivaP3'=>$reactivaP3??null,
  2079.                 'reactivaP4'=>$reactivaP4??null,
  2080.                 'reactivaP5'=>$reactivaP5??null,
  2081.                 'reactivaP6'=>$reactivaP6??null,
  2082.                 'excesoReactivaP1'=>$excesoReactivaP1??null,
  2083.                 'excesoReactivaP2'=>$excesoReactivaP2??null,
  2084.                 'excesoReactivaP3'=>$excesoReactivaP3??null,
  2085.                 'excesoReactivaP4'=>$excesoReactivaP4??null,
  2086.                 'excesoReactivaP5'=>$excesoReactivaP5??null,
  2087.                 'excesoReactivaP6'=>$excesoReactivaP6??null,
  2088.                 'importeReactivaP1'=>$importeReactivaP1??null,
  2089.                 'importeReactivaP2'=>$importeReactivaP2??null,
  2090.                 'importeReactivaP3'=>$importeReactivaP3??null,
  2091.                 'importeReactivaP4'=>$importeReactivaP4??null,
  2092.                 'importeReactivaP5'=>$importeReactivaP5??null,
  2093.                 'importeReactivaP6'=>$importeReactivaP6??null,
  2094.                 'totalReactiva'=>$totalReactiva??null,
  2095.                 'subtotal'=>$subtotal,
  2096.                 'importeImpuesto'=>$importeImpuesto,
  2097.                 'importeAlquiler'=>$importeAlquiler,
  2098.                 'otrosConceptos'=>$otrosConceptos??0,
  2099.                 'importeTotal'=>$importeTotal,
  2100.                 'importeIva'=>$importeIva,
  2101.                 'totalFactura'=>$totalFactura,
  2102.                 'consumoP1Facturado'=>$consumoP1Facturado??null,
  2103.                 'consumoP2Facturado'=>$consumoP2Facturado??null,
  2104.                 'consumoP3Facturado'=>$consumoP3Facturado??null,
  2105.                 'consumoP4Facturado'=>$consumoP4Facturado??null,
  2106.                 'consumoP5Facturado'=>$consumoP5Facturado??null,
  2107.                 'consumoP6Facturado'=>$consumoP6Facturado??null,
  2108.                 'arrayP'=>$arrayP??[true,false,false,false,false,false],
  2109.                 'numeroP'=>$numeroP??1,
  2110.                 'urlImagen'=>$urlImagen
  2111.             ];
  2112.             switch ($_SERVER['APP_ENV']??'finkaluz'){
  2113.                 case 'finkaluz':
  2114.                     $html=$this->renderView('factura/finkaluz.factura.pdf.twig'$params);
  2115.                     break;
  2116.                 case 'emfra':
  2117.                     $html=$this->renderView('factura/emfra.factura.pdf.twig'$params);
  2118.                     break;
  2119.                 case 'onda':
  2120.                     $html=$this->renderView('factura/onda.factura.pdf.twig'$params);
  2121.                     break;
  2122.                 case 'digitel':
  2123.                     $html=$this->renderView('factura/digitel.factura.pdf.twig'$params);
  2124.                     break;
  2125.                 case 'apolo':
  2126.                     $html=$this->renderView('factura/apolo.factura.pdf.twig'$params);
  2127.                     break;
  2128.                 case 'e3': case 'telkes': case 'paladio': case 'arsen': case 'rburgos':
  2129.                     $html=$this->renderView('factura/'.$_SERVER['APP_ENV'].'/factura.pdf.twig'$params);
  2130.                     break;
  2131.                 default:
  2132.                     $html=$this->renderView('factura/factura.pdf.twig'$params);
  2133.                     break;
  2134.             }
  2135.         }
  2136.         else {
  2137.             $subject 'FACTURA GAS';
  2138.             $tipo='gas';
  2139.             $periodoFacturacion date_diff($factura->getFechaLecturaAnterior(), $factura->getFechaLectura())->days;
  2140.             $totalPotenciaP1 round($factura->getPrecioPotenciaP1() * $periodoFacturacion2);
  2141.             $totalPotencia $totalPotenciaP1;
  2142.             $totalEnergiaP1 round($factura->getConsumoConvertidoP1() * $factura->getPrecioEnergiaP1(), 2);
  2143.             $totalEnergia $totalEnergiaP1;
  2144.             $subtotal round($totalEnergia $totalPotencia2);
  2145.             $importeImpuesto round($factura->getImpuesto() * $factura->getConsumoConvertidoP1(), 2);
  2146.             $importeAlquiler round($periodoFacturacion $factura->getAlquilerEquipos(), 2);
  2147.             $otrosConceptos=0;
  2148.             foreach ($factura->getConceptos() as $concepto){
  2149.                 $otrosConceptos+=round($concepto->getImporte(),2);
  2150.             }
  2151.             $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  2152.             $importeIva round($factura->getIva() * $importeTotal 1002);
  2153.             $totalFactura round($importeTotal $importeIva2);
  2154.             if ($totalFactura !== $factura->getTotalFactura()) {
  2155.                 $factura->setTotalFactura($totalFactura);
  2156.                 $entityManager->flush();
  2157.             }
  2158.             //Grafica
  2159.             if ($factura === $facturas[0]) {
  2160.                 $consumoMedio $factura->getTotalFactura();
  2161.                 $consumoAcumulado $factura->getConsumoConvertidoP1();
  2162.             } else {
  2163.                 $indiceFactura array_search($factura$facturas);
  2164.                 if ($indiceFactura 12) {
  2165.                     for ($i 0$i <= $indiceFactura && $i 12$i++) {
  2166.                         $consumoMedio += $facturas[$i]->getTotalFactura();
  2167.                         $consumoAcumulado += $facturas[$i]->getConsumoConvertidoP1();
  2168.                     }
  2169.                     $consumoMedio $consumoMedio / ($indiceFactura 1);
  2170.                 } else {
  2171.                     for ($i 11$i >= 0$i--) {
  2172.                         $n $indiceFactura $i;
  2173.                         $consumoMedio += $facturas[$n]->getTotalFactura();
  2174.                         $consumoAcumulado += $facturas[$n]->getConsumoConvertidoP1();
  2175.                     }
  2176.                     $consumoMedio $consumoMedio 12;
  2177.                 }
  2178.             }
  2179.             $params=[
  2180.                 'factura' => $factura,
  2181.                 'entidad' => $entidad,
  2182.                 'consumoMedio' => $consumoMedio,
  2183.                 'consumoAcumulado' => $consumoAcumulado,
  2184.                 'periodoFacturacion' => $periodoFacturacion,
  2185.                 'totalPotenciaP1' => $totalPotenciaP1,
  2186.                 'totalPotencia' => $totalPotencia,
  2187.                 'totalEnergiaP1' => $totalEnergiaP1,
  2188.                 'totalEnergia' => $totalEnergia,
  2189.                 'subtotal' => $subtotal,
  2190.                 'importeImpuesto' => $importeImpuesto,
  2191.                 'importeAlquiler' => $importeAlquiler,
  2192.                 'otrosConceptos'=>$otrosConceptos,
  2193.                 'importeTotal' => $importeTotal,
  2194.                 'importeIva' => $importeIva,
  2195.                 'totalFactura' => $totalFactura,
  2196.                 'urlImagen' => $urlImagen
  2197.             ];
  2198.             switch ($_SERVER['APP_ENV']??'finkaluz'){
  2199.                 case 'finkaluz':
  2200.                     $html=$this->renderView('factura/finkaluz.factura.pdf.twig'$params);
  2201.                     break;
  2202.                 case 'emfra':
  2203.                     $html=$this->renderView('factura/emfra.factura.pdf.twig'$params);
  2204.                     break;
  2205.                 case 'onda':
  2206.                     $html=$this->renderView('factura/onda.factura.pdf.twig'$params);
  2207.                     break;
  2208.                 case 'digitel':
  2209.                     $html=$this->renderView('factura/digitel.factura.pdf.twig'$params);
  2210.                     break;
  2211.                 case 'apolo':
  2212.                     $html=$this->renderView('factura/apolo.factura.pdf.twig'$params);
  2213.                     break;
  2214.                 case 'e3': case 'telkes': case 'paladio':  case 'arsen': case 'rburgos':
  2215.                     $html=$this->renderView('factura/'.$_SERVER['APP_ENV'].'/factura.pdf.twig'$params);
  2216.                     break;
  2217.                 default:
  2218.                     $html=$this->renderView('factura/factura.pdf.twig'$params);
  2219.                     break;
  2220.             }
  2221.         }
  2222.         //Attach PDF
  2223.         try {
  2224.             unlink(__DIR__ '/../../temp/' . (str_replace('/',"-",$factura->getNumeroFactura()) ?? 'factura_sin_número') . '.pdf');
  2225.         } catch (\Exception $exception) {
  2226.         }
  2227.         $pdfPath=__DIR__ '/../../temp/' . (str_replace('/',"-",$factura->getNumeroFactura()) ?? 'factura_sin_número') . '.pdf';
  2228.         $pdf->generateFromHtml(
  2229.             $html,
  2230.             $pdfPath
  2231.         );
  2232.         $params['pdf']=base64_encode(file_get_contents($pdfPath));
  2233.         //Detect NIF type
  2234.         $nif=$factura->getNifCliente();
  2235.         $first=ctype_alphasubstr($nif,0,1) );
  2236.         $last=ctype_alphasubstr($nif,strlen($nif)-1,1) );
  2237.         $validador= new Validador();
  2238.         if( $validador->validateCif($nif) ){
  2239.             $params['tipoDocumento']='CIF';
  2240.         }
  2241.         elseif($first && $last)
  2242.             $params['tipoDocumento']='NIE';
  2243.         elseif ($first)
  2244.             $params['tipoDocumento']='CIF';
  2245.         else
  2246.             $params['tipoDocumento']='DNI';
  2247.         switch ($params['tipoDocumento']){
  2248.             case 'NIE':case 'DNI':
  2249.             $cliente=$factura->getContrato()->getCliente();
  2250.             if ( $factura->getNombreCliente()==$cliente->__toString() ){
  2251.                 $params['nombre']['nombre']=$cliente->getNombre();
  2252.                 $params['nombre']['apellido1']=$cliente->getApellido();
  2253.                 $params['nombre']['apellido2']=$cliente->getApellido2();
  2254.             }
  2255.             else{
  2256.                 $nombreArray=explode' '$factura->getNombreCliente() );
  2257.                 $arrayCount=count($nombreArray);
  2258.                 $params['nombre']['nombre']=$nombreArray[0];
  2259.                 if($arrayCount==2){
  2260.                     $params['nombre']['apellido1']=$nombreArray[1];
  2261.                 }elseif ($arrayCount==3){
  2262.                     $params['nombre']['apellido1']=$nombreArray[1];
  2263.                     $params['nombre']['apellido2']=$nombreArray[2];
  2264.                 }elseif ($arrayCount==4){
  2265.                     $params['nombre']['nombre'].=' '.$nombreArray[1];
  2266.                     $params['nombre']['apellido1']=$nombreArray[2];
  2267.                     $params['nombre']['apellido2']=$nombreArray[3];
  2268.                 }else {
  2269.                     $nombreArray explode(' '$factura->getNombreCliente());
  2270.                     $arrayCount count($nombreArray);
  2271.                     if ($arrayCount 1) {
  2272.                         $params['nombre']['apellido1'] = '';
  2273.                         $params['nombre']['apellido2'] = '';
  2274.                         $i=1;
  2275.                         for (; $i $arrayCount$i++) {
  2276.                             $concatenatedString $params['nombre']['apellido1'] . $nombreArray[$i] . ' ';
  2277.                             if (strlen($concatenatedString) <= 40) {
  2278.                                 $params['nombre']['apellido1'] = $concatenatedString;
  2279.                             } else {
  2280.                                 break;
  2281.                             }
  2282.                         }
  2283.                         for (; $i $arrayCount$i++) {
  2284.                             $concatenatedString $params['nombre']['apellido2'] . $nombreArray[$i] . ' ';
  2285.                             if (strlen($concatenatedString) <= 40) {
  2286.                                 $params['nombre']['apellido2'] = $concatenatedString;
  2287.                             } else {
  2288.                                 break;
  2289.                             }
  2290.                         }
  2291.                     }
  2292.                     $params['nombre']['apellido1'] = trim($params['nombre']['apellido1']);
  2293.                     $params['nombre']['apellido2'] = trim($params['nombre']['apellido2']);
  2294.                 }
  2295.             }
  2296.         }
  2297.         switch ($_SERVER['APP_ENV']??'finkaluz'){
  2298.             case 'finkaluz':
  2299.                 $xml=$this->renderView('factura/finkaluz.factura.xml.twig'$params);
  2300.                 break;
  2301.             case 'emfra':
  2302.                 $xml=$this->renderView('factura/emfra.factura.xml.twig'$params);
  2303.                 break;
  2304.             case 'onda':
  2305.                 $xml=$this->renderView('factura/onda.factura.xml.twig'$params);
  2306.                 break;
  2307.             case 'digitel':
  2308.                 $xml=$this->renderView('factura/digitel.factura.xml.twig'$params);
  2309.                 break;
  2310.             case 'apolo':
  2311.                 $xml=$this->renderView('factura/apolo.factura.xml.twig'$params);
  2312.                 break;
  2313.             case 'e3': case 'telkes': case 'paladio': case 'arsen': case 'rburgos':
  2314.                 $xml=$this->renderView('factura/'.$_SERVER['APP_ENV'].'/factura.xml.twig'$params);
  2315.                 break;
  2316.             default:
  2317.                 $xml=$this->renderView('factura/factura.xml.twig'$params);
  2318.                 break;
  2319.         }
  2320.         $path=__DIR__ '/../../temp/';
  2321.         $filename=(str_replace('/',"-",$factura->getNumeroFactura()) ?? 'factura_sin_número') . '.xml';
  2322.         $filesystem->dumpFile($path.$filename$xml);
  2323.         $response= new BinaryFileResponse($path.$filename);
  2324.         // Create the disposition of the file
  2325.         $disposition $response->headers->makeDisposition(
  2326.             ResponseHeaderBag::DISPOSITION_ATTACHMENT,
  2327.             $filename
  2328.         );
  2329.         // Set the content disposition
  2330.         $response->headers->set('Content-Disposition'$disposition);
  2331.         // Dispatch request
  2332.         return $response;
  2333.     }
  2334.     /**
  2335.      * @Route("factura/{id}/enviar", name="factura_enviar", methods={"GET", "POST"})
  2336.      */
  2337.     public function enviar(Factura $facturaPdf $pdfRequest $requestFacturaRepository $facturaRepository,
  2338.                            BancoRepository $bancoRepositoryMailerInterface $mailerEntityManagerInterface $entityManager): Response
  2339.     {
  2340.         $this->denyAccessUnlessGranted('ROLE_FACTURACION');
  2341.         $logger = new Logger('factura_logger');
  2342.         $logger->pushHandler(new StreamHandler(__DIR__.'/../../logs/email.log'Logger::DEBUG));
  2343.         $urlImagen $request->request->get("urlImagen");
  2344.         $facturas $facturaRepository->findBy(['contrato' => $factura->getContrato()], ['fechaLectura' => 'ASC']);
  2345.         $tarifa $factura->getTarifa();
  2346.         $entidad $bancoRepository->findByCuenta($factura->getCcc());
  2347.         $consumoAcumulado '0';
  2348.         $consumoMedio '0';
  2349.         /*if ($tarifa->getTipoTarifa() == 'Electricidad') {
  2350.             $subject = 'FACTURA ELECTRICIDAD';
  2351.             $tipo='electricidad';
  2352.             if ($tarifa == '2.0A' || $tarifa == '2.1A') {
  2353.                 $periodoFacturacion = date_diff($factura->getFechaLecturaAnterior(), $factura->getFechaLectura())->days;
  2354.                 $totalPotenciaP1 = round($factura->getPotenciaP1() * $factura->getPrecioPotenciaP1() * $periodoFacturacion, 2);
  2355.                 $totalPotencia = $totalPotenciaP1;
  2356.                 $totalEnergiaP1 = round($factura->getConsumoP1() * $factura->getPrecioEnergiaP1(), 2);
  2357.                 $totalEnergia = $totalEnergiaP1;
  2358.                 $subtotal = round($totalEnergia + $totalPotencia, 2);
  2359.                 $importeImpuesto = round($factura->getImpuesto() * $subtotal / 100, 2);
  2360.                 $importeAlquiler = round($periodoFacturacion * $factura->getAlquilerEquipos(), 2);
  2361.                 $otrosConceptos=0;
  2362.                 foreach ($factura->getConceptos() as $concepto){
  2363.                     $otrosConceptos+=round($concepto->getImporte(),2);
  2364.                 }
  2365.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  2366.                 $importeIva = round($factura->getIva() * $importeTotal / 100, 2);
  2367.                 $totalFactura = round($importeTotal + $importeIva, 2);
  2368.                 if ($totalFactura !== $factura->getTotalFactura()) {
  2369.                     $factura->setTotalFactura($totalFactura);
  2370.                     $this->getDoctrine()->getManager()->flush();
  2371.                 }
  2372.                 //Grafica
  2373.                 if ($factura === $facturas[0]) {
  2374.                     $consumoMedio = $factura->getTotalFactura();
  2375.                     $consumoAcumulado = $factura->getLecturaEnergiaP1() - $factura->getLecturaAnteriorP1();
  2376.                 } else {
  2377.                     $indiceFactura = array_search($factura, $facturas);
  2378.                     if ($indiceFactura < 12) {
  2379.                         for ($i = 0; $i <= $indiceFactura && $i < 12; $i++) {
  2380.                             $consumoMedio += $facturas[$i]->getTotalFactura();
  2381.                             $consumoAcumulado += $facturas[$i]->getConsumo();
  2382.                         }
  2383.                         $consumoMedio = $consumoMedio / ($indiceFactura + 1);
  2384.                     } else {
  2385.                         for ($i = 11; $i >= 0; $i--) {
  2386.                             $n = $indiceFactura - $i;
  2387.                             $consumoMedio += $facturas[$n]->getTotalFactura();
  2388.                             $consumoAcumulado += $factura->getConsumo()[1];
  2389.                         }
  2390.                         $consumoMedio = $consumoMedio / 12;
  2391.                     }
  2392.                 }
  2393.             }
  2394.             elseif ($tarifa == '2.0DHA' || $tarifa == '2.1DHA') {
  2395.                 $periodoFacturacion = date_diff($factura->getFechaLecturaAnterior(), $factura->getFechaLectura())->days;
  2396.                 $totalPotenciaP1 = round($factura->getPotenciaP1() * $factura->getPrecioPotenciaP1() * $periodoFacturacion, 2);
  2397.                 $totalPotencia = $totalPotenciaP1;
  2398.                 $totalEnergiaP1 = round($factura->getConsumoP1() * $factura->getPrecioEnergiaP1(), 2);
  2399.                 $totalEnergiaP3 = round($factura->getConsumoP3() * $factura->getPrecioEnergiaP3(), 2);
  2400.                 $totalEnergia = $totalEnergiaP1 + $totalEnergiaP3;
  2401.                 $subtotal = round($totalEnergia + $totalPotencia, 2);
  2402.                 $importeImpuesto = round($factura->getImpuesto() * $subtotal / 100, 2);
  2403.                 $importeAlquiler = round($periodoFacturacion * $factura->getAlquilerEquipos(), 2);
  2404.                 $otrosConceptos=0;
  2405.                 foreach ($factura->getConceptos() as $concepto){
  2406.                     $otrosConceptos+=round($concepto->getImporte(),2);
  2407.                 }
  2408.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  2409.                 $importeIva = round($factura->getIva() * $importeTotal / 100, 2);
  2410.                 $totalFactura = round($importeTotal + $importeIva, 2);
  2411.                 if ($totalFactura !== $factura->getTotalFactura()) {
  2412.                     $factura->setTotalFactura($totalFactura);
  2413.                     $this->getDoctrine()->getManager()->flush();
  2414.                 }
  2415.                 //Grafica
  2416.                 if ($factura === $facturas[0]) {
  2417.                     $consumoMedio = $factura->getTotalFactura();
  2418.                     $consumoAcumulado = $factura->getConsumo();
  2419.                 } else {
  2420.                     $indiceFactura = array_search($factura, $facturas);
  2421.                     if ($indiceFactura < 12) {
  2422.                         for ($i = 0; $i <= $indiceFactura && $i < 12; $i++) {
  2423.                             $consumoMedio += $facturas[$i]->getTotalFactura();
  2424.                             $consumoAcumulado += $facturas[$i]->getConsumo();
  2425.                         }
  2426.                         $consumoMedio = $consumoMedio / ($indiceFactura + 1);
  2427.                     } else {
  2428.                         for ($i = 11; $i >= 0; $i--) {
  2429.                             $n = $indiceFactura - $i;
  2430.                             $consumoMedio += $facturas[$n]->getTotalFactura();
  2431.                             $consumoAcumulado += $facturas[$i]->getConsumo();
  2432.                         }
  2433.                         $consumoMedio = $consumoMedio / 12;
  2434.                     }
  2435.                 }
  2436.             }
  2437.             elseif ($tarifa == '3.0A' || $tarifa == '3.1A') {
  2438.                 $periodoFacturacion = date_diff($factura->getFechaLecturaAnterior(), $factura->getFechaLectura())->days;
  2439.                 $consumoP1Facturado = $factura->getConsumoP1() + $factura->getConsumoP4();
  2440.                 $consumoP2Facturado = $factura->getConsumoP2() + $factura->getConsumoP5();
  2441.                 $consumoP3Facturado = $factura->getConsumoP3() + $factura->getConsumoP6();
  2442.                 $potenciaP1Facturada = $factura->getPotenciaFacturada('P1');
  2443.                 $potenciaP2Facturada = $factura->getPotenciaFacturada('P2');
  2444.                 $potenciaP3Facturada = $factura->getPotenciaFacturada('P3');
  2445.                 $totalPotenciaP1 = round($potenciaP1Facturada * $factura->getPrecioPotenciaP1() * $periodoFacturacion, 2);
  2446.                 $totalPotenciaP2 = round($potenciaP2Facturada * $factura->getPrecioPotenciaP2() * $periodoFacturacion, 2);
  2447.                 $totalPotenciaP3 = round($potenciaP3Facturada * $factura->getPrecioPotenciaP3() * $periodoFacturacion, 2);
  2448.                 $totalPotencia = $totalPotenciaP1 + $totalPotenciaP2 + $totalPotenciaP3;
  2449.                 $totalEnergiaP1 = round($consumoP1Facturado * $factura->getPrecioEnergiaP1(), 2);
  2450.                 $totalEnergiaP2 = round($consumoP2Facturado * $factura->getPrecioEnergiaP2(), 2);
  2451.                 $totalEnergiaP3 = round($consumoP3Facturado * $factura->getPrecioEnergiaP3(), 2);
  2452.                 $totalEnergia = $totalEnergiaP1 + $totalEnergiaP2 + $totalEnergiaP3;
  2453.                 $reactivaP1 = $factura->getReactivaP1() + $factura->getReactivaP4();
  2454.                 $reactivaP2 = $factura->getReactivaP2() + $factura->getReactivaP5();
  2455.                 $excesoReactivaP1 = $reactivaP1 - 0.33 * $consumoP1Facturado;
  2456.                 $excesoReactivaP2 = $reactivaP2 - 0.33 * $consumoP2Facturado;
  2457.                 if($excesoReactivaP1<0)
  2458.                     $excesoReactivaP1=0;
  2459.                 if($excesoReactivaP2<0)
  2460.                     $excesoReactivaP2=0;
  2461.                 $importeReactivaP1 = round($excesoReactivaP1 * $factura->getPrecioReactivaP1(), 2);
  2462.                 $importeReactivaP2 = round($excesoReactivaP2 * $factura->getPrecioReactivaP2(), 2);
  2463.                 $totalReactiva = $importeReactivaP1 + $importeReactivaP2;
  2464.                 $subtotal = round($totalEnergia + $totalPotencia + $totalReactiva, 2);
  2465.                 $importeImpuesto = round($factura->getImpuesto() * $subtotal / 100, 2);
  2466.                 $importeAlquiler = round($periodoFacturacion * $factura->getAlquilerEquipos(), 2);
  2467.                 $otrosConceptos=0;
  2468.                 foreach ($factura->getConceptos() as $concepto){
  2469.                     $otrosConceptos+=round($concepto->getImporte(),2);
  2470.                 }
  2471.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  2472.                 $importeIva = round($factura->getIva() * $importeTotal / 100, 2);
  2473.                 $totalFactura = round($importeTotal + $importeIva, 2);
  2474.                 if ($totalFactura !== $factura->getTotalFactura()) {
  2475.                     $factura->setTotalFactura($totalFactura);
  2476.                     $this->getDoctrine()->getManager()->flush();
  2477.                 }
  2478.                 //Grafica
  2479.                 if ($factura === $facturas[0]) {
  2480.                     $consumoMedio = $factura->getTotalFactura();
  2481.                     $consumoAcumulado = $factura->getConsumo();
  2482.                 } else {
  2483.                     $indiceFactura = array_search($factura, $facturas);
  2484.                     if ($indiceFactura < 12) {
  2485.                         for ($i = 0; $i <= $indiceFactura && $i < 12; $i++) {
  2486.                             $consumoMedio += $facturas[$i]->getTotalFactura();
  2487.                             $consumoAcumulado += $facturas[$i]->getConsumo();
  2488.                         }
  2489.                         $consumoMedio = $consumoMedio / ($indiceFactura + 1);
  2490.                     } else {
  2491.                         for ($i = 11; $i >= 0; $i--) {
  2492.                             $n = $indiceFactura - $i;
  2493.                             $consumoMedio += $facturas[$n]->getTotalFactura();
  2494.                         }
  2495.                         $consumoMedio = $consumoMedio / 12;
  2496.                         $ultimaFecha = $factura->getFechaLectura();
  2497.                     }
  2498.                 }
  2499.             } else {
  2500.                 throw $this->createNotFoundException('No se ha encontrado la factura');
  2501.             }
  2502.             $html = $this->renderView('factura/factura.pdf.twig', [
  2503.                 'factura' => $factura,
  2504.                 'entidad' => $entidad,
  2505.                 'consumoMedio' => $consumoMedio,
  2506.                 'consumoAcumulado' => $consumoAcumulado,
  2507.                 'periodoFacturacion' => $periodoFacturacion,
  2508.                 'potenciaP1Facturada' => $potenciaP1Facturada ?? null,
  2509.                 'potenciaP2Facturada' => $potenciaP2Facturada ?? null,
  2510.                 'potenciaP3Facturada' => $potenciaP3Facturada ?? null,
  2511.                 'totalPotenciaP1' => $totalPotenciaP1,
  2512.                 'totalPotenciaP2' => $totalPotenciaP2 ?? null,
  2513.                 'totalPotenciaP3' => $totalPotenciaP3 ?? null,
  2514.                 'totalPotencia' => $totalPotencia,
  2515.                 'totalEnergiaP1' => $totalEnergiaP1,
  2516.                 'totalEnergiaP2' => $totalEnergiaP2 ?? null,
  2517.                 'totalEnergiaP3' => $totalEnergiaP3 ?? null,
  2518.                 'totalEnergia' => $totalEnergia,
  2519.                 'reactivaP1' => $reactivaP1 ?? null,
  2520.                 'reactivaP2' => $reactivaP2 ?? null,
  2521.                 'excesoReactivaP1' => $excesoReactivaP1 ?? null,
  2522.                 'excesoReactivaP2' => $excesoReactivaP2 ?? null,
  2523.                 'importeReactivaP1' => $importeReactivaP1 ?? null,
  2524.                 'importeReactivaP2' => $importeReactivaP2 ?? null,
  2525.                 'totalReactiva' => $totalReactiva ?? null,
  2526.                 'subtotal' => $subtotal,
  2527.                 'importeImpuesto' => $importeImpuesto,
  2528.                 'importeAlquiler' => $importeAlquiler,
  2529.                 'otrosConceptos'=>$otrosConceptos,
  2530.                 'importeTotal' => $importeTotal,
  2531.                 'importeIva' => $importeIva,
  2532.                 'totalFactura' => $totalFactura,
  2533.                 'consumoP1Facturado' => $consumoP1Facturado ?? null,
  2534.                 'consumoP2Facturado' => $consumoP2Facturado ?? null,
  2535.                 'consumoP3Facturado' => $consumoP3Facturado ?? null,
  2536.                 'urlImagen' => $urlImagen
  2537.             ]);
  2538.         }*/
  2539.         if($tarifa->getTipoTarifa()=='Electricidad'){
  2540.             $subject 'FACTURA ELECTRICIDAD';
  2541.             $tipo='electricidad';
  2542.             if($tarifa=='3.0A' || $tarifa=='3.1A'){
  2543.                 $periodoFacturacion=date_diff$factura->getFechaLecturaAnterior(), $factura->getFechaLectura() )->days;
  2544.                 $consumoP1Facturado=$factura->getConsumoP1()+$factura->getConsumoP4();
  2545.                 $consumoP2Facturado=$factura->getConsumoP2()+$factura->getConsumoP5();
  2546.                 $consumoP3Facturado=$factura->getConsumoP3()+$factura->getConsumoP6();
  2547.                 $potenciaP1Facturada=$factura->getPotenciaFacturada('P1');
  2548.                 $potenciaP2Facturada=$factura->getPotenciaFacturada('P2');
  2549.                 $potenciaP3Facturada=$factura->getPotenciaFacturada('P3');
  2550.                 $totalPotenciaP1=round($potenciaP1Facturada*$factura->getPrecioPotenciaP1()*$periodoFacturacion,2);
  2551.                 $totalPotenciaP2=round($potenciaP2Facturada*$factura->getPrecioPotenciaP2()*$periodoFacturacion,2);
  2552.                 $totalPotenciaP3=round($potenciaP3Facturada*$factura->getPrecioPotenciaP3()*$periodoFacturacion,2);
  2553.                 $totalPotencia=$totalPotenciaP1+$totalPotenciaP2+$totalPotenciaP3;
  2554.                 $totalEnergiaP1=round($consumoP1Facturado*$factura->getPrecioEnergiaP1(),2);
  2555.                 $totalEnergiaP2=round($consumoP2Facturado*$factura->getPrecioEnergiaP2(),2);
  2556.                 $totalEnergiaP3=round($consumoP3Facturado*$factura->getPrecioEnergiaP3(),2);
  2557.                 $totalEnergia=$totalEnergiaP1+$totalEnergiaP2+$totalEnergiaP3;
  2558.                 $reactivaP1=$factura->getReactivaP1()+$factura->getReactivaP4();
  2559.                 $reactivaP2=$factura->getReactivaP2()+$factura->getReactivaP5();
  2560.                 $excesoReactivaP1=$reactivaP1-0.33*$consumoP1Facturado;
  2561.                 $excesoReactivaP2=$reactivaP2-0.33*$consumoP2Facturado;
  2562.                 if($excesoReactivaP1<0)
  2563.                     $excesoReactivaP1=0;
  2564.                 if($excesoReactivaP2<0)
  2565.                     $excesoReactivaP2=0;
  2566.                 $importeReactivaP1=round($excesoReactivaP1*$factura->getPrecioReactivaP1(),2);
  2567.                 $importeReactivaP2=round($excesoReactivaP2*$factura->getPrecioReactivaP2(),2);
  2568.                 $totalReactiva=$importeReactivaP1+$importeReactivaP2;
  2569.                 $subtotal=round($totalEnergia+$totalPotencia+$totalReactiva,2);
  2570.                 $importeImpuesto=round($factura->getImpuesto()*$subtotal/100,2);
  2571.                 $importeAlquiler=round($periodoFacturacion*$factura->getAlquilerEquipos(),2);
  2572.                 $otrosConceptos=0;
  2573.                 foreach ($factura->getConceptos() as $concepto){
  2574.                     $otrosConceptos+=round($concepto->getImporte(),2);
  2575.                 }
  2576.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  2577.                 $importeIva=round($factura->getIva()*$importeTotal/100,2);
  2578.                 $totalFactura=round($importeTotal+$importeIva,2);
  2579.                 if( $totalFactura!==$factura->getTotalFactura() ){
  2580.                     $factura->setTotalFactura($totalFactura);
  2581.                     $entityManager->flush();
  2582.                 }
  2583.             }
  2584.             else{
  2585.                 $periodoFacturacion=date_diff$factura->getFechaLecturaAnterior(), $factura->getFechaLectura() )->days;
  2586.                 $consumoP1Facturado=$factura->getConsumoP1();
  2587.                 $consumoP2Facturado=$factura->getConsumoP2();
  2588.                 $consumoP3Facturado=$factura->getConsumoP3();
  2589.                 $consumoP4Facturado=$factura->getConsumoP4();
  2590.                 $consumoP5Facturado=$factura->getConsumoP5();
  2591.                 $consumoP6Facturado=$factura->getConsumoP6();
  2592.                 $potenciaP1Facturada=$factura->getPotenciaFacturada('P1');
  2593.                 $potenciaP2Facturada=$factura->getPotenciaFacturada('P2');
  2594.                 $potenciaP3Facturada=$factura->getPotenciaFacturada('P3');
  2595.                 $potenciaP4Facturada=$factura->getPotenciaFacturada('P4');
  2596.                 $potenciaP5Facturada=$factura->getPotenciaFacturada('P5');
  2597.                 $potenciaP6Facturada=$factura->getPotenciaFacturada('P6');
  2598.                 $totalPotenciaP1=round($potenciaP1Facturada*$factura->getPrecioPotenciaP1()*$periodoFacturacion,2);
  2599.                 $totalPotenciaP2=round($potenciaP2Facturada*$factura->getPrecioPotenciaP2()*$periodoFacturacion,2);
  2600.                 $totalPotenciaP3=round($potenciaP3Facturada*$factura->getPrecioPotenciaP3()*$periodoFacturacion,2);
  2601.                 $totalPotenciaP4=round($potenciaP4Facturada*$factura->getPrecioPotenciaP4()*$periodoFacturacion,2);
  2602.                 $totalPotenciaP5=round($potenciaP5Facturada*$factura->getPrecioPotenciaP5()*$periodoFacturacion,2);
  2603.                 $totalPotenciaP6=round($potenciaP6Facturada*$factura->getPrecioPotenciaP6()*$periodoFacturacion,2);
  2604.                 $totalPotencia=$totalPotenciaP1+$totalPotenciaP2+$totalPotenciaP3+$totalPotenciaP4+$totalPotenciaP5+$totalPotenciaP6;
  2605.                 $totalEnergiaP1=round($consumoP1Facturado*$factura->getPrecioEnergiaP1(),2);
  2606.                 $totalEnergiaP2=round($consumoP2Facturado*$factura->getPrecioEnergiaP2(),2);
  2607.                 $totalEnergiaP3=round($consumoP3Facturado*$factura->getPrecioEnergiaP3(),2);
  2608.                 $totalEnergiaP4=round($consumoP4Facturado*$factura->getPrecioEnergiaP4(),2);
  2609.                 $totalEnergiaP5=round($consumoP5Facturado*$factura->getPrecioEnergiaP5(),2);
  2610.                 $totalEnergiaP6=round($consumoP6Facturado*$factura->getPrecioEnergiaP6(),2);
  2611.                 $totalEnergia=$totalEnergiaP1+$totalEnergiaP2+$totalEnergiaP3+$totalEnergiaP4+$totalEnergiaP5+$totalEnergiaP6;
  2612.                 $reactivaP1=$factura->getReactivaP1();
  2613.                 $reactivaP2=$factura->getReactivaP2();
  2614.                 $reactivaP3=$factura->getReactivaP3();
  2615.                 $reactivaP4=$factura->getReactivaP4();
  2616.                 $reactivaP5=$factura->getReactivaP5();
  2617.                 $reactivaP6=$factura->getReactivaP6();
  2618.                 if($reactivaP1!=0)
  2619.                     $excesoReactivaP1=$reactivaP1-0.33*$factura->getConsumoP1();
  2620.                 else
  2621.                     $excesoReactivaP1=0;
  2622.                 if($reactivaP2!=0)
  2623.                     $excesoReactivaP2=$reactivaP2-0.33*$factura->getConsumoP2();
  2624.                 else
  2625.                     $excesoReactivaP2=0;
  2626.                 if($reactivaP3!=0)
  2627.                     $excesoReactivaP3=$reactivaP3-0.33*$factura->getConsumoP3();
  2628.                 else
  2629.                     $excesoReactivaP3=0;
  2630.                 if($reactivaP4!=0)
  2631.                     $excesoReactivaP4=$reactivaP4-0.33*$factura->getConsumoP4();
  2632.                 else
  2633.                     $excesoReactivaP4=0;
  2634.                 if($reactivaP5!=0)
  2635.                     $excesoReactivaP5=$reactivaP5-0.33*$factura->getConsumoP5();
  2636.                 else
  2637.                     $excesoReactivaP5=0;
  2638.                 if($reactivaP6!=0)
  2639.                     $excesoReactivaP6=$reactivaP6-0.33*$factura->getConsumoP6();
  2640.                 else
  2641.                     $excesoReactivaP6=0;
  2642.                 if($excesoReactivaP1<0)
  2643.                     $excesoReactivaP1=0;
  2644.                 if($excesoReactivaP2<0)
  2645.                     $excesoReactivaP2=0;
  2646.                 if($excesoReactivaP3<0)
  2647.                     $excesoReactivaP3=0;
  2648.                 if($excesoReactivaP4<0)
  2649.                     $excesoReactivaP4=0;
  2650.                 if($excesoReactivaP5<0)
  2651.                     $excesoReactivaP5=0;
  2652.                 if($excesoReactivaP6<0)
  2653.                     $excesoReactivaP6=0;
  2654.                 $importeReactivaP1=round($excesoReactivaP1*$factura->getPrecioReactivaP1(),2);
  2655.                 $importeReactivaP2=round($excesoReactivaP2*$factura->getPrecioReactivaP2(),2);
  2656.                 $importeReactivaP3=round($excesoReactivaP3*$factura->getPrecioReactivaP3(),2);
  2657.                 $importeReactivaP4=round($excesoReactivaP4*$factura->getPrecioReactivaP4(),2);
  2658.                 $importeReactivaP5=round($excesoReactivaP5*$factura->getPrecioReactivaP5(),2);
  2659.                 $importeReactivaP6=round($excesoReactivaP6*$factura->getPrecioReactivaP6(),2);
  2660.                 $totalReactiva=$importeReactivaP1+$importeReactivaP2+$importeReactivaP3+$importeReactivaP4+$importeReactivaP5+$importeReactivaP6;
  2661.                 $subtotal=round($totalEnergia+$totalPotencia+$totalReactiva,2);
  2662.                 $importeImpuesto=round($factura->getImpuesto()*$subtotal/100,2);
  2663.                 $importeAlquiler=round($periodoFacturacion*$factura->getAlquilerEquipos(),2);
  2664.                 $otrosConceptos=0;
  2665.                 foreach ($factura->getConceptos() as $concepto){
  2666.                     $otrosConceptos+=round($concepto->getImporte(),2);
  2667.                 }
  2668.                 $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  2669.                 $importeIva=round($factura->getIva()*$importeTotal/100,2);
  2670.                 $totalFactura=round($importeTotal+$importeIva,2);
  2671.                 if( $totalFactura!==$factura->getTotalFactura() ){
  2672.                     $factura->setTotalFactura($totalFactura);
  2673.                     $entityManager->flush();
  2674.                 }
  2675.                 //throw $this->createNotFoundException('No se ha encontrado la factura');
  2676.             }
  2677.             //Grafica
  2678.             $indiceFactura=array_search($factura$facturas);
  2679.             $arrayP=[false,false,false,false,false,false];
  2680.             if($indiceFactura<12){
  2681.                 for($i=0;$i<=$indiceFactura && $i<12;$i++){
  2682.                     $consumoMedio+=$facturas[$i]->getTotalFactura();
  2683.                     $consumoAcumulado+=$facturas[$i]->getConsumo();
  2684.                     $tarifaI=$facturas[$i]->getTarifa();
  2685.                     $arrayPI=[
  2686.                         $tarifaI->getEnergiaP1(),
  2687.                         $tarifaI->getEnergiaP2(),
  2688.                         $tarifaI->getEnergiaP3(),
  2689.                         $tarifaI->getEnergiaP4(),
  2690.                         $tarifaI->getEnergiaP5(),
  2691.                         $tarifaI->getEnergiaP6()
  2692.                     ];
  2693.                     if(!$arrayP[0])
  2694.                         $arrayP[0]=$arrayPI[0];
  2695.                     if(!$arrayP[1])
  2696.                         $arrayP[1]=$arrayPI[1];
  2697.                     if(!$arrayP[2])
  2698.                         $arrayP[2]=$arrayPI[2];
  2699.                     if(!$arrayP[3])
  2700.                         $arrayP[3]=$arrayPI[3];
  2701.                     if(!$arrayP[4])
  2702.                         $arrayP[4]=$arrayPI[4];
  2703.                     if(!$arrayP[5])
  2704.                         $arrayP[5]=$arrayPI[5];
  2705.                     /*if ( $tarifaI=='2.0A' || $tarifaI=='2.1A' ){
  2706.                         $datosGrafica[]=[
  2707.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$i]->getFechaLectura()->getTimestamp()) )),
  2708.                             $facturas[$i]->getConsumoP1(),
  2709.                             0,
  2710.                             0
  2711.                         ];
  2712.                         if ( 1>($numeroP??0) ){
  2713.                             $numeroP=1;
  2714.                         }
  2715.                     }elseif ( $tarifaI=='2.0DHA' || $tarifaI=='2.1DHA' ){
  2716.                         $datosGrafica[]=[
  2717.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$i]->getFechaLectura()->getTimestamp()) )),
  2718.                             $facturas[$i]->getConsumoP1(),
  2719.                             0,
  2720.                             $facturas[$i]->getConsumoP3()
  2721.                         ];
  2722.                         if ( 2>($numeroP??0) ){
  2723.                             $numeroP=2;
  2724.                         }
  2725.                     }else*/
  2726.                     switch( $tarifaI->getNombre() ){
  2727.                         case '3.0A': case '3.1A':
  2728.                         $datosGrafica[]=[
  2729.                             str_replace('.','',strtolowerstrftime('%h-%y',$facturas[$i]->getFechaLectura()->getTimestamp()) )),
  2730.                             $facturas[$i]->getConsumoP1()+$facturas[$i]->getConsumoP4(),
  2731.                             $facturas[$i]->getConsumoP2()+$facturas[$i]->getConsumoP5(),
  2732.                             $facturas[$i]->getConsumoP3()+$facturas[$i]->getConsumoP6(),
  2733.                             0,
  2734.                             0,
  2735.                             0
  2736.                         ];
  2737.                         break;
  2738.                         default:
  2739.                             $datosGrafica[]=[
  2740.                                 str_replace('.','',strtolowerstrftime('%h-%y',$facturas[$i]->getFechaLectura()->getTimestamp()) )),
  2741.                                 $facturas[$i]->getConsumoP1()??0,
  2742.                                 $facturas[$i]->getConsumoP2()??0,
  2743.                                 $facturas[$i]->getConsumoP3()??0,
  2744.                                 $facturas[$i]->getConsumoP4()??0,
  2745.                                 $facturas[$i]->getConsumoP5()??0,
  2746.                                 $facturas[$i]->getConsumoP6()??0,
  2747.                             ];
  2748.                             break;
  2749.                     }
  2750.                 }
  2751.                 $consumoMedio=$consumoMedio/($indiceFactura+1);
  2752.                 $numeroP=countarray_filter($arrayP) );
  2753.             }
  2754.             else{
  2755.                 for($i=11;$i>=0;$i--){
  2756.                     $n=$indiceFactura-$i;
  2757.                     $consumoMedio+=$facturas[$n]->getTotalFactura();
  2758.                     $consumoAcumulado+=$facturas[$n]->getConsumo();
  2759.                     $tarifaI=$facturas[$n]->getTarifa();
  2760.                     $arrayPI=[
  2761.                         $tarifaI->getEnergiaP1(),
  2762.                         $tarifaI->getEnergiaP2(),
  2763.                         $tarifaI->getEnergiaP3(),
  2764.                         $tarifaI->getEnergiaP4(),
  2765.                         $tarifaI->getEnergiaP5(),
  2766.                         $tarifaI->getEnergiaP6()
  2767.                     ];
  2768.                     if(!$arrayP[0])
  2769.                         $arrayP[0]=$arrayPI[0];
  2770.                     if(!$arrayP[1])
  2771.                         $arrayP[1]=$arrayPI[1];
  2772.                     if(!$arrayP[2])
  2773.                         $arrayP[2]=$arrayPI[2];
  2774.                     if(!$arrayP[3])
  2775.                         $arrayP[3]=$arrayPI[3];
  2776.                     if(!$arrayP[4])
  2777.                         $arrayP[4]=$arrayPI[4];
  2778.                     if(!$arrayP[5])
  2779.                         $arrayP[5]=$arrayPI[5];
  2780.                     /*if ( $tarifaI=='2.0A' || $tarifaI=='2.1A' ){
  2781.                         $datosGrafica[]=[
  2782.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$n]->getFechaLectura()->getTimestamp()) )),
  2783.                             $facturas[$n]->getConsumoP1(),
  2784.                             0,
  2785.                             0
  2786.                         ];
  2787.                         if ( 1>($numeroP??0) ){
  2788.                             $numeroP=1;
  2789.                         }
  2790.                     }elseif ( $tarifaI=='2.0DHA' || $tarifaI=='2.1DHA' ){
  2791.                         $datosGrafica[]=[
  2792.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$n]->getFechaLectura()->getTimestamp()) )),
  2793.                             $facturas[$n]->getConsumoP1(),
  2794.                             0,
  2795.                             $facturas[$n]->getConsumoP3()
  2796.                         ];
  2797.                         if ( 2>($numeroP??0) ){
  2798.                             $numeroP=2;
  2799.                         }
  2800.                     }elseif( $tarifaI=='3.0A' || $tarifaI=='3.1A' ){
  2801.                         $datosGrafica[]=[
  2802.                             str_replace('.','',strtolower( strftime('%h-%y',$facturas[$n]->getFechaLectura()->getTimestamp()) )),
  2803.                             $facturas[$n]->getConsumoP1()+$facturas[$n]->getConsumoP4(),
  2804.                             $facturas[$n]->getConsumoP2()+$facturas[$n]->getConsumoP5(),
  2805.                             $facturas[$n]->getConsumoP3()+$facturas[$n]->getConsumoP6(),
  2806.                         ];
  2807.                     }*/
  2808.                 }
  2809.                 $consumoMedio=$consumoMedio/12;;
  2810.                 $numeroP=countarray_filter($arrayP) );
  2811.             }
  2812.             $params=[
  2813.                 'factura' => $factura,
  2814.                 'entidad'=>$entidad,
  2815.                 'consumoMedio'=>$consumoMedio,
  2816.                 'consumoAcumulado'=>$consumoAcumulado,
  2817.                 'periodoFacturacion'=>$periodoFacturacion,
  2818.                 'potenciaP1Facturada'=>$potenciaP1Facturada??null,
  2819.                 'potenciaP2Facturada'=>$potenciaP2Facturada??null,
  2820.                 'potenciaP3Facturada'=>$potenciaP3Facturada??null,
  2821.                 'potenciaP4Facturada'=>$potenciaP4Facturada??null,
  2822.                 'potenciaP5Facturada'=>$potenciaP5Facturada??null,
  2823.                 'potenciaP6Facturada'=>$potenciaP6Facturada??null,
  2824.                 'totalPotenciaP1'=>$totalPotenciaP1,
  2825.                 'totalPotenciaP2'=>$totalPotenciaP2??null,
  2826.                 'totalPotenciaP3'=>$totalPotenciaP3??null,
  2827.                 'totalPotenciaP4'=>$totalPotenciaP4??null,
  2828.                 'totalPotenciaP5'=>$totalPotenciaP5??null,
  2829.                 'totalPotenciaP6'=>$totalPotenciaP6??null,
  2830.                 'totalPotencia'=>$totalPotencia,
  2831.                 'totalEnergiaP1'=>$totalEnergiaP1,
  2832.                 'totalEnergiaP2'=>$totalEnergiaP2??null,
  2833.                 'totalEnergiaP3'=>$totalEnergiaP3??null,
  2834.                 'totalEnergiaP4'=>$totalEnergiaP4??null,
  2835.                 'totalEnergiaP5'=>$totalEnergiaP5??null,
  2836.                 'totalEnergiaP6'=>$totalEnergiaP6??null,
  2837.                 'totalEnergia'=>$totalEnergia,
  2838.                 'reactivaP1'=>$reactivaP1??null,
  2839.                 'reactivaP2'=>$reactivaP2??null,
  2840.                 'reactivaP3'=>$reactivaP3??null,
  2841.                 'reactivaP4'=>$reactivaP4??null,
  2842.                 'reactivaP5'=>$reactivaP5??null,
  2843.                 'reactivaP6'=>$reactivaP6??null,
  2844.                 'excesoReactivaP1'=>$excesoReactivaP1??null,
  2845.                 'excesoReactivaP2'=>$excesoReactivaP2??null,
  2846.                 'excesoReactivaP3'=>$excesoReactivaP3??null,
  2847.                 'excesoReactivaP4'=>$excesoReactivaP4??null,
  2848.                 'excesoReactivaP5'=>$excesoReactivaP5??null,
  2849.                 'excesoReactivaP6'=>$excesoReactivaP6??null,
  2850.                 'importeReactivaP1'=>$importeReactivaP1??null,
  2851.                 'importeReactivaP2'=>$importeReactivaP2??null,
  2852.                 'importeReactivaP3'=>$importeReactivaP3??null,
  2853.                 'importeReactivaP4'=>$importeReactivaP4??null,
  2854.                 'importeReactivaP5'=>$importeReactivaP5??null,
  2855.                 'importeReactivaP6'=>$importeReactivaP6??null,
  2856.                 'totalReactiva'=>$totalReactiva??null,
  2857.                 'subtotal'=>$subtotal,
  2858.                 'importeImpuesto'=>$importeImpuesto,
  2859.                 'importeAlquiler'=>$importeAlquiler,
  2860.                 'otrosConceptos'=>$otrosConceptos??0,
  2861.                 'importeTotal'=>$importeTotal,
  2862.                 'importeIva'=>$importeIva,
  2863.                 'totalFactura'=>$totalFactura,
  2864.                 'consumoP1Facturado'=>$consumoP1Facturado??null,
  2865.                 'consumoP2Facturado'=>$consumoP2Facturado??null,
  2866.                 'consumoP3Facturado'=>$consumoP3Facturado??null,
  2867.                 'consumoP4Facturado'=>$consumoP4Facturado??null,
  2868.                 'consumoP5Facturado'=>$consumoP5Facturado??null,
  2869.                 'consumoP6Facturado'=>$consumoP6Facturado??null,
  2870.                 'arrayP'=>$arrayP??[true,false,false,false,false,false],
  2871.                 'numeroP'=>$numeroP??1,
  2872.                 'urlImagen'=>$urlImagen
  2873.             ];
  2874.             switch ($_SERVER['APP_ENV']??'finkaluz'){
  2875.                 case 'finkaluz':
  2876.                     $html=$this->renderView('factura/finkaluz.factura.pdf.twig'$params);
  2877.                     break;
  2878.                 case 'emfra':
  2879.                     $html=$this->renderView('factura/emfra.factura.pdf.twig'$params);
  2880.                     break;
  2881.                 case 'onda':
  2882.                     $html=$this->renderView('factura/onda.factura.pdf.twig'$params);
  2883.                     break;
  2884.                 case 'digitel':
  2885.                     $html=$this->renderView('factura/digitel.factura.pdf.twig'$params);
  2886.                     break;
  2887.                 case 'apolo':
  2888.                     $html=$this->renderView('factura/apolo.factura.pdf.twig'$params);
  2889.                     break;
  2890.                 case 'e3': case 'telkes': case 'paladio': case 'arsen': case 'rburgos':
  2891.                     $html=$this->renderView('factura/'.$_SERVER['APP_ENV'].'/factura.pdf.twig'$params);
  2892.                     break;
  2893.                 default:
  2894.                     $html=$this->renderView('factura/factura.pdf.twig'$params);
  2895.                     break;
  2896.             }
  2897.         }
  2898.         else {
  2899.             $subject 'FACTURA GAS';
  2900.             $tipo='gas';
  2901.             $periodoFacturacion date_diff($factura->getFechaLecturaAnterior(), $factura->getFechaLectura())->days;
  2902.             $totalPotenciaP1 round($factura->getPrecioPotenciaP1() * $periodoFacturacion2);
  2903.             $totalPotencia $totalPotenciaP1;
  2904.             $totalEnergiaP1 round($factura->getConsumoConvertidoP1() * $factura->getPrecioEnergiaP1(), 2);
  2905.             $totalEnergia $totalEnergiaP1;
  2906.             $subtotal round($totalEnergia $totalPotencia2);
  2907.             $importeImpuesto round($factura->getImpuesto() * $factura->getConsumoConvertidoP1(), 2);
  2908.             $importeAlquiler round($periodoFacturacion $factura->getAlquilerEquipos(), 2);
  2909.             $otrosConceptos=0;
  2910.             foreach ($factura->getConceptos() as $concepto){
  2911.                 $otrosConceptos+=round($concepto->getImporte(),2);
  2912.             }
  2913.             $importeTotal=round($subtotal+$importeAlquiler+$importeImpuesto+$otrosConceptos,2);
  2914.             $importeIva round($factura->getIva() * $importeTotal 1002);
  2915.             $totalFactura round($importeTotal $importeIva2);
  2916.             if ($totalFactura !== $factura->getTotalFactura()) {
  2917.                 $factura->setTotalFactura($totalFactura);
  2918.                 $entityManager->flush();
  2919.             }
  2920.             //Grafica
  2921.             if ($factura === $facturas[0]) {
  2922.                 $consumoMedio $factura->getTotalFactura();
  2923.                 $consumoAcumulado $factura->getConsumoConvertidoP1();
  2924.             } else {
  2925.                 $indiceFactura array_search($factura$facturas);
  2926.                 if ($indiceFactura 12) {
  2927.                     for ($i 0$i <= $indiceFactura && $i 12$i++) {
  2928.                         $consumoMedio += $facturas[$i]->getTotalFactura();
  2929.                         $consumoAcumulado += $facturas[$i]->getConsumoConvertidoP1();
  2930.                     }
  2931.                     $consumoMedio $consumoMedio / ($indiceFactura 1);
  2932.                 } else {
  2933.                     for ($i 11$i >= 0$i--) {
  2934.                         $n $indiceFactura $i;
  2935.                         $consumoMedio += $facturas[$n]->getTotalFactura();
  2936.                         $consumoAcumulado += $facturas[$n]->getConsumoConvertidoP1();
  2937.                     }
  2938.                     $consumoMedio $consumoMedio 12;
  2939.                 }
  2940.             }
  2941.             $params=[
  2942.                 'factura' => $factura,
  2943.                 'entidad' => $entidad,
  2944.                 'consumoMedio' => $consumoMedio,
  2945.                 'consumoAcumulado' => $consumoAcumulado,
  2946.                 'periodoFacturacion' => $periodoFacturacion,
  2947.                 'totalPotenciaP1' => $totalPotenciaP1,
  2948.                 'totalPotencia' => $totalPotencia,
  2949.                 'totalEnergiaP1' => $totalEnergiaP1,
  2950.                 'totalEnergia' => $totalEnergia,
  2951.                 'subtotal' => $subtotal,
  2952.                 'importeImpuesto' => $importeImpuesto,
  2953.                 'importeAlquiler' => $importeAlquiler,
  2954.                 'otrosConceptos'=>$otrosConceptos,
  2955.                 'importeTotal' => $importeTotal,
  2956.                 'importeIva' => $importeIva,
  2957.                 'totalFactura' => $totalFactura,
  2958.                 'urlImagen' => $urlImagen
  2959.             ];
  2960.             switch ($_SERVER['APP_ENV']??'finkaluz'){
  2961.                 case 'finkaluz':
  2962.                     $html=$this->renderView('factura/finkaluz.factura.pdf.twig'$params);
  2963.                     break;
  2964.                 case 'emfra':
  2965.                     $html=$this->renderView('factura/emfra.factura.pdf.twig'$params);
  2966.                     break;
  2967.                 case 'onda':
  2968.                     $html=$this->renderView('factura/onda.factura.pdf.twig'$params);
  2969.                     break;
  2970.                 case 'digitel':
  2971.                     $html=$this->renderView('factura/digitel.factura.pdf.twig'$params);
  2972.                     break;
  2973.                 case 'apolo':
  2974.                     $html=$this->renderView('factura/apolo.factura.pdf.twig'$params);
  2975.                     break;
  2976.                 case 'e3': case 'telkes': case 'paladio': case 'arsen': case 'rburgos':
  2977.                     $html=$this->renderView('factura/'.$_SERVER['APP_ENV'].'/factura.pdf.twig'$params);
  2978.                     break;
  2979.                 default:
  2980.                     $html=$this->renderView('factura/factura.pdf.twig'$params);
  2981.                     break;
  2982.             }
  2983.         }
  2984.         try {
  2985.             unlink(__DIR__ '/../../temp/' . (str_replace('/',"-",$factura->getNumeroFactura()) ?? 'factura_sin_número') . '.pdf');
  2986.         } catch (\Exception $exception) {
  2987.         }
  2988.         $pdf->generateFromHtml(
  2989.             $html,
  2990.             __DIR__ '/../../temp/' . (str_replace('/',"-",$factura->getNumeroFactura()) ?? 'factura_sin_número') . '.pdf'
  2991.         );
  2992.         try {
  2993.             switch ($_SERVER['APP_ENV']??'finkaluz'){
  2994.                 case 'finkaluz':
  2995.                     $body=$this->renderView('email/finkaluz.factura.html.twig',['tipo'=>$tipo]);
  2996.                     $from='finkaluz@finkaluz.com';
  2997.                     break;
  2998.                 case 'emfra':
  2999.                     $body=$this->renderView('email/emfra.factura.html.twig',['tipo'=>$tipo]);
  3000.                     $from='finkaluz@finkaluz.com';
  3001.                     break;
  3002.                 case 'onda':
  3003.                     $body=$this->renderView('email/onda.factura.html.twig',['tipo'=>$tipo]);
  3004.                     $from='facturacion@ondaenergia.es';
  3005.                     break;
  3006.                 case 'digitel':
  3007.                     $body=$this->renderView('email/digitel.factura.html.twig',['tipo'=>$tipo'email'=>$factura->getContrato()->getCliente()->getEmail()]);
  3008.                     $from='facturacionluz@itdigitel.es';
  3009.                     break;
  3010.                 case 'apolo':
  3011.                     $body=$this->renderView('email/apolo.factura.html.twig',['tipo'=>$tipo,'factura'=>$factura]);
  3012.                     $from='clientes@vibraenergies.es';
  3013.                     break;
  3014.                 case 'e3':
  3015.                     $body=$this->renderView('email/e3/factura.html.twig',['tipo'=>$tipo,'cliente'=>$factura->getContrato()->getCliente()]);
  3016.                     $from='e3powerenergy@e3powerenergy.com';
  3017.                     break;
  3018.                 case 'telkes':
  3019.                     $body=$this->renderView('email/telkes/factura.html.twig',['tipo'=>$tipo,'cliente'=>$factura->getContrato()->getCliente()]);
  3020.                     $from='info@telkesenergia.es';
  3021.                     break;
  3022.                 case 'paladio':
  3023.                     $body=$this->renderView('email/paladio/factura.html.twig',['tipo'=>$tipo,'cliente'=>$factura->getContrato()->getCliente()]);
  3024.                     $from='clientes@paladiopartners.es';
  3025.                     break;
  3026.                 case 'arsen':
  3027.                     $body=$this->renderView('email/arsen/factura.html.twig',['tipo'=>$tipo,'cliente'=>$factura->getContrato()->getCliente()]);
  3028.                     $from='arsenenergia@arsenenergia.com';
  3029.                     break;
  3030.                 case 'rburgos':
  3031.                     $body=$this->renderView('email/rburgos/factura.html.twig',['tipo'=>$tipo,'cliente'=>$factura->getContrato()->getCliente()]);
  3032.                     $from='facturacion@rburgos.es';
  3033.                     break;
  3034.                 default:
  3035.                     $body=$this->renderView('email/factura.html.twig',['tipo'=>$tipo]);
  3036.                     $from='no-reply@energaze.com';
  3037.                     break;
  3038.             }
  3039.             $message = (new Email())
  3040.                 ->subject($subject)
  3041.                 ->from($from)
  3042.                 ->to($factura->getContrato()->getCliente()->getEmail())
  3043.                 ->html($body)
  3044.                 ->attachFromPath(__DIR__ '/../../temp/' . (str_replace('/',"-",$factura->getNumeroFactura()) ?? 'factura_sin_número') . '.pdf');
  3045.             /*try{
  3046.                 unlink(__DIR__.'/../../temp/'.(str_replace('/',"-",$factura->getNumeroFactura())??'factura_sin_número').'.pdf');
  3047.             }catch (\Exception $exception){}*/
  3048.             $mailer->send($message);
  3049.             $status='success';
  3050.         }catch (\Exception $exception){
  3051.             $status='error';
  3052.             $logger->info($exception->getMessage());
  3053.         }
  3054.         return $this->redirectToRoute('factura_show',['id'=>$factura->getId(), 'status'=>$status]);
  3055.     }
  3056.     /**
  3057.      * @Route("factura/{id}/pagar", name="factura_pagar", methods={"GET","POST"})
  3058.      */
  3059.     public function pagar(Factura $facturaMailerInterface $mailerEntityManagerInterface $entityManager): Response
  3060.     {
  3061.         if( $factura->getContrato()->getCliente()->getUser()!=$this->getUser() ){
  3062.             $this->denyAccessUnlessGranted('ROLE_FACTURACION');
  3063.         }
  3064.         $env=$_SERVER['APP_ENV']??'finkaluz';
  3065.         $error=false;
  3066.         $version="";
  3067.         $params="";
  3068.         $signature="";
  3069.         $logger = new Logger('my_logger');
  3070.         $logger->pushHandler(new StreamHandler(__DIR__.'/../../logs/pruebaRedsys.log'Logger::DEBUG));
  3071.         if($factura->getDevuelta()) {
  3072.             //$logger->info('Detectado !pagado. Inicia comprobación.');
  3073.             $api = new RedsysAPI;
  3074.             if (!empty($_POST)) {
  3075.                 //URL DE RESP. ONLINE
  3076.                 //$logger->info('Detectado POST. Inicia comprobación.');
  3077.                 $version $_POST["Ds_SignatureVersion"];
  3078.                 $datos $_POST["Ds_MerchantParameters"];
  3079.                 $signatureRecibida $_POST["Ds_Signature"];
  3080.                 $decodec $api->decodeMerchantParameters($datos);
  3081.                 switch ($env){
  3082.                     case 'finkaluz':case 'emfra':
  3083.                     $kc 'Kh6cHWPsap169mNSJCUNi2vpxT1DnnAd';
  3084.                     break;
  3085.                     default:
  3086.                         $kc 'f534PExNDgl6MWbwG8BglFJTFeFzr9Dq';
  3087.                         break;
  3088.                 }
  3089.                 $firma $api->createMerchantSignatureNotif($kc$datos);
  3090.                 $logger->info(gettype($decodec));
  3091.                 $logger->info($decodec["Ds_Response"]);
  3092.                 $decodec2=json_decode($decodectrue);
  3093.                 $logger->info(gettype($decodec2));
  3094.                 $logger->info($decodec2["Ds_Response"]);
  3095.                 if ($firma === $signatureRecibida) {
  3096.                     if (intval($decodec['Ds_Response'])<100){
  3097.                         $pagado true;
  3098.                         $logger->info('Marcando $pagado=true');
  3099.                     }else{
  3100.                         $error=true;
  3101.                     }
  3102.                     echo'FIRMA OK';
  3103.                 } else {
  3104.                     $pagado false;
  3105.                     //$logger->info('Firma POST denegada.');
  3106.                     echo'FIRMA KO';
  3107.                 }
  3108.             }
  3109.             elseif (!empty($_GET)) {//URL DE RESP. ONLINE
  3110.                 //$logger->info('Detectado GET. Inicia comprobación.');
  3111.                 $version $_GET["Ds_SignatureVersion"];
  3112.                 $datos $_GET["Ds_MerchantParameters"];
  3113.                 $signatureRecibida $_GET["Ds_Signature"];
  3114.                 $decodec json_decode($api->decodeMerchantParameters($datos), true);
  3115.                 switch ($env){
  3116.                     case 'finkaluz':case 'emfra':
  3117.                     $kc 'Kh6cHWPsap169mNSJCUNi2vpxT1DnnAd';
  3118.                     break;
  3119.                     default:
  3120.                         $kc 'f534PExNDgl6MWbwG8BglFJTFeFzr9Dq';
  3121.                         break;
  3122.                 }
  3123.                 $firma $api->createMerchantSignatureNotif($kc$datos);
  3124.                 $logger->info(gettype($decodec));
  3125.                 $logger->info($decodec["Ds_Response"]);
  3126.                 $decodec2=json_decode($decodectrue);
  3127.                 $logger->info(gettype($decodec2));
  3128.                 $logger->info($decodec2["Ds_Response"]);
  3129.                 if ($firma === $signatureRecibida) {
  3130.                     if (intval($decodec['Ds_Response'])<100){
  3131.                         $pagado true;
  3132.                         $logger->info('Marcando $pagado=true');
  3133.                     }else{
  3134.                         $error=true;
  3135.                     }
  3136.                     echo'FIRMA OK';
  3137.                 } else {
  3138.                     $pagado false;
  3139.                     //$logger->info('Firma GET denegada.');
  3140.                     echo'FIRMA KO';
  3141.                 }
  3142.             }
  3143.             else{
  3144.                 $api=new RedsysAPI();
  3145.                 $logger = new Logger('my_logger');
  3146.                 $logger->pushHandler(new StreamHandler(__DIR__.'/../../logs/pruebaRedsys.log'Logger::DEBUG));
  3147.                 switch ($env){
  3148.                     case 'finkaluz':case 'emfra':
  3149.                     $fuc="355719071";
  3150.                     break;
  3151.                     default:
  3152.                         $fuc="351398243";
  3153.                         break;
  3154.                 }
  3155.                 $terminal="1";
  3156.                 $moneda="978";
  3157.                 $trans="0";
  3158.                 $url=$this->generateUrl('factura_pagar',['id' => $factura->getId()], UrlGeneratorInterface::ABSOLUTE_URL);
  3159.                 $urlOKKO=$this->generateUrl('factura_pagar',['id' => $factura->getId()], UrlGeneratorInterface::ABSOLUTE_URL);
  3160.                 $id=time();
  3161.                 $amount=str_replace('.','',$factura->getTotalFactura());;
  3162.                 // Se Rellenan los campos
  3163.                 $api->setParameter("DS_MERCHANT_AMOUNT",$amount);
  3164.                 $api->setParameter("DS_MERCHANT_ORDER",$id);
  3165.                 $api->setParameter("DS_MERCHANT_MERCHANTCODE",$fuc);
  3166.                 $api->setParameter("DS_MERCHANT_CURRENCY",$moneda);
  3167.                 $api->setParameter("DS_MERCHANT_TRANSACTIONTYPE",$trans);
  3168.                 $api->setParameter("DS_MERCHANT_TERMINAL",$terminal);
  3169.                 $api->setParameter("DS_MERCHANT_MERCHANTURL",$url);
  3170.                 $api->setParameter("DS_MERCHANT_URLOK",$urlOKKO);
  3171.                 $api->setParameter("DS_MERCHANT_URLKO",$urlOKKO);
  3172.                 //Datos de configuración
  3173.                 $version="HMAC_SHA256_V1";
  3174.                 switch ($env){
  3175.                     case 'finkaluz':case 'emfra':
  3176.                     $kc 'Kh6cHWPsap169mNSJCUNi2vpxT1DnnAd';
  3177.                     break;
  3178.                     default:
  3179.                         $kc 'f534PExNDgl6MWbwG8BglFJTFeFzr9Dq';
  3180.                         break;
  3181.                 }
  3182.                 // Se generan los parámetros de la petición
  3183.                 $request "";
  3184.                 $params $api->createMerchantParameters();
  3185.                 $signature $api->createMerchantSignature($kc);
  3186.             }
  3187.             if ($pagado??null === true) {
  3188.                 $logger->info('Marcando como pagado.');
  3189.                 $factura->setDevuelta(false);
  3190.                 $entityManager->persist($factura);
  3191.                 $entityManager->flush();
  3192.                 //Notificación email
  3193.                 try {
  3194.                     switch ($env){
  3195.                         case 'finkaluz':
  3196.                             $body=$this->renderView('email/finkaluz.facturaPagada.html.twig',['factura'=>$factura]);
  3197.                             $from='finkaluz@finkaluz.com';
  3198.                             break;
  3199.                         case 'emfra':
  3200.                             $body=$this->renderView('email/emfra.facturaPagada.html.twig',['factura'=>$factura]);
  3201.                             $from='finkaluz@finkaluz.com';
  3202.                             break;
  3203.                         case 'apolo':
  3204.                             $body=$this->renderView('email/apolo.facturaPagada.html.twig',['factura'=>$factura]);
  3205.                             $from='clientes@vibraenergies.es';
  3206.                             break;
  3207.                         default:
  3208.                             $body=$this->renderView('email/facturaPagada.html.twig',['factura'=>$factura]);
  3209.                             $from='no-reply@energaze.com';
  3210.                             break;
  3211.                     }
  3212.                     $message = (new Email())
  3213.                         ->subject('FACTURA PAGADA')
  3214.                         ->from($from)
  3215.                         ->to($factura->getContrato()->getCliente()->getEmail())
  3216.                         ->html($body);
  3217.                     $mailer->send($message);
  3218.                 }catch (\Exception $exception){
  3219.                     $logger->info($exception->getMessage());
  3220.                 }
  3221.             }elseif ($pagado??null === false){
  3222.                 $error=true;
  3223.             }
  3224.         }
  3225.         switch ($env){
  3226.             case 'finkaluz':
  3227.                 $template='factura/finkaluz.pagar.html.twig';
  3228.                 break;
  3229.             case 'emfra':
  3230.                 $template='factura/emfra.pagar.html.twig';
  3231.                 break;
  3232.             case 'apolo':
  3233.                 $template='factura/apolo.pagar.html.twig';
  3234.                 break;
  3235.             default:
  3236.                 $template='factura/pagar.html.twig';
  3237.                 break;
  3238.         }
  3239.         return $this->render($template, [
  3240.             'factura' => $factura,
  3241.             'error' => $error,
  3242.             'version' => $version,
  3243.             'params' => $params,
  3244.             'signature' => $signature,
  3245.         ]);
  3246.     }
  3247.     /**
  3248.      * @Route("factura/{id}/edit", name="factura_edit", methods={"GET","POST"})
  3249.      */
  3250.     public function edit(Request $requestFactura $facturaEntityManagerInterface $entityManager): Response
  3251.     {
  3252.         $this->denyAccessUnlessGranted('ROLE_FACTURACION');
  3253.         $form $this->createForm(FacturaType::class, $factura);
  3254.         $form->handleRequest($request);
  3255.         if ($form->isSubmitted() && $form->isValid()) {
  3256.             $factura->calcularTotal();
  3257.             $entityManager->flush();
  3258.             return $this->redirectToRoute('factura_show', ['id'=>$factura->getId()]);
  3259.         }
  3260.         return $this->render('factura/edit.html.twig', [
  3261.             'factura' => $factura,
  3262.             'form' => $form->createView(),
  3263.         ]);
  3264.     }
  3265.     /*    /**
  3266.          * @Route("factura/{id}", name="factura_delete", methods={"DELETE"})
  3267.          *
  3268.         public function delete(Request $request, Factura $factura): Response
  3269.         {
  3270.             $this->denyAccessUnlessGranted('ROLE_FACTURACION');
  3271.             if ($this->isCsrfTokenValid('delete'.$factura->getId(), $request->request->get('_token'))) {
  3272.                 $contrato=$factura->getContrato();
  3273.                 $entityManager = $this->getDoctrine()->getManager();
  3274.                 $entityManager->remove($factura);
  3275.                 $entityManager->flush();
  3276.             }
  3277.             return $this->redirectToRoute('contrato_show',['id'=>$contrato->getId()]);
  3278.         }*/
  3279.     /**
  3280.      * @Route("factura/{id}", name="factura_delete", methods={"POST"})
  3281.      */
  3282.     public function delete(Request $requestFactura $facturaFacturaRepository $facturaRepository): Response
  3283.     {
  3284.         if ($this->isCsrfTokenValid('delete'.$factura->getId(), $request->request->get('_token'))) {
  3285.             $contrato=$factura->getContrato();
  3286.             $facturaRepository->remove($facturatrue);
  3287.         }
  3288.         return $this->redirectToRoute('contrato_show',['id'=>$contrato->getId()], Response::HTTP_SEE_OTHER);
  3289.     }
  3290.     /**
  3291.      * @Route("factura/otros/{id}", name="facturaGenerica_show", methods={"GET"})
  3292.      */
  3293.     public function showGenerica(FacturaGenerica $facturaBancoRepository $bancoRepositoryEntityManagerInterface $entityManager): Response
  3294.     {
  3295.         if(
  3296.             $factura->getContrato()->getCliente()->getUser()!=$this->getUser() &&
  3297.             ($factura->getContrato()->getSeller()??new Comercial())->getUser()!=$this->getUser()
  3298.         ){
  3299.             $this->denyAccessUnlessGranted('ROLE_FACTURACION');
  3300.         }
  3301.         $entidad=$bancoRepository->findByCuenta($factura->getCcc());
  3302.         $importeTotal=0;
  3303.         foreach ($factura->getConceptos() as $concepto){
  3304.             $importeTotal+=$concepto->getImporte();
  3305.         }
  3306.         $importeIva=round($factura->getIva()*$importeTotal/100,2);
  3307.         $totalFactura=round($importeTotal+$importeIva,2);
  3308.         if( $totalFactura!==$factura->getTotalFactura() ){
  3309.             $factura->setTotalFactura($totalFactura);
  3310.             $entityManager->flush();
  3311.         }
  3312.         $params=[
  3313.             'factura' => $factura,
  3314.             'entidad'=>$entidad,
  3315.             'importeTotal'=>$importeTotal,
  3316.             'importeIva'=>$importeIva,
  3317.             'totalFactura'=>$totalFactura,
  3318.         ];
  3319.         switch ($_SERVER['APP_ENV']??'finkaluz'){
  3320.             case 'finkaluz':
  3321.                 return $this->render('factura_generica/finkaluz.factura.html.twig'$params);
  3322.             case 'emfra':
  3323.                 return $this->render('factura_generica/emfra.factura.html.twig'$params);
  3324.             case 'onda':
  3325.                 return $this->render('factura_generica/onda.factura.html.twig'$params);
  3326.             case 'digitel':
  3327.                 return $this->render('factura_generica/digitel.factura.html.twig'$params);
  3328.             case 'apolo':
  3329.                 return $this->render('factura_generica/apolo.factura.html.twig'$params);
  3330.             case 'e3': case 'telkes': case 'paladio': case 'arsen': case 'rburgos':
  3331.                 return $this->render('factura_generica/'.$_SERVER['APP_ENV'].'/factura.html.twig'$params);
  3332.             default:
  3333.                 return $this->render('factura_generica/factura.html.twig'$params);
  3334.         }
  3335.     }
  3336.     /**
  3337.      * @Route("factura/otros/{id}/pdf", name="facturaGenerica_pdf", methods={"GET", "POST"})
  3338.      */
  3339.     public function pdfGenerica(FacturaGenerica $facturaPdf $pdfBancoRepository $bancoRepositoryEntityManagerInterface $entityManager): Response
  3340.     {
  3341.         if(
  3342.             $factura->getContrato()->getCliente()->getUser()!=$this->getUser() &&
  3343.             ($factura->getContrato()->getSeller()??new Comercial())->getUser()!=$this->getUser()
  3344.         ){
  3345.             $this->denyAccessUnlessGranted('ROLE_FACTURACION');
  3346.         }
  3347.         $entidad=$bancoRepository->findByCuenta($factura->getCcc());
  3348.         $importeTotal=0;
  3349.         foreach ($factura->getConceptos() as $concepto){
  3350.             $importeTotal+=$concepto->getImporte();
  3351.         }
  3352.         $importeIva=round($factura->getIva()*$importeTotal/100,2);
  3353.         $totalFactura=round($importeTotal+$importeIva,2);
  3354.         if( $totalFactura!==$factura->getTotalFactura() ){
  3355.             $factura->setTotalFactura($totalFactura);
  3356.             $entityManager->flush();
  3357.         }
  3358.         $params=[
  3359.             'factura' => $factura,
  3360.             'entidad'=>$entidad,
  3361.             'importeTotal'=>$importeTotal,
  3362.             'importeIva'=>$importeIva,
  3363.             'totalFactura'=>$totalFactura,
  3364.         ];
  3365.         switch ($_SERVER['APP_ENV']??'finkaluz'){
  3366.             case 'finkaluz':
  3367.                 $html=$this->renderView('factura_generica/finkaluz.factura.pdf.twig'$params);
  3368.                 break;
  3369.             case 'emfra':
  3370.                 $html=$this->renderView('factura_generica/emfra.factura.pdf.twig'$params);
  3371.                 break;
  3372.             case 'onda':
  3373.                 $html=$this->renderView('factura_generica/onda.factura.pdf.twig'$params);
  3374.                 break;
  3375.             case 'digitel':
  3376.                 $html=$this->renderView('factura_generica/digitel.factura.pdf.twig'$params);
  3377.                 break;
  3378.             case 'apolo':
  3379.                 $html=$this->renderView('factura_generica/apolo.factura.pdf.twig'$params);
  3380.                 break;
  3381.             case 'e3': case 'telkes': case 'paladio': case 'arsen': case 'rburgos':
  3382.                 $html=$this->renderView('factura_generica/'.$_SERVER['APP_ENV'].'/factura.pdf.twig'$params);
  3383.                 break;
  3384.             default:
  3385.                 $html=$this->renderView('factura_generica/factura.pdf.twig'$params);
  3386.                 break;
  3387.         }
  3388.         return new PdfResponse(
  3389.             $pdf->getOutputFromHtml($html),
  3390.             (str_replace('/',"-",$factura->getNumeroFactura())??'factura_sin_numero').'.pdf'
  3391.         );
  3392.     }
  3393.     /**
  3394.      * @Route("factura/otros/{id}/xml", name="facturaGenerica_xml", methods={"GET", "POST"})
  3395.      */
  3396.     public function xmlGenerica(FacturaGenerica $facturaPdf $pdfBancoRepository $bancoRepository,
  3397.                                 Filesystem $filesystemEntityManagerInterface $entityManager): Response
  3398.     {
  3399.         if(
  3400.             $factura->getContrato()->getCliente()->getUser()!=$this->getUser() &&
  3401.             ($factura->getContrato()->getSeller()??new Comercial())->getUser()!=$this->getUser()
  3402.         ){
  3403.             $this->denyAccessUnlessGranted('ROLE_FACTURACION');
  3404.         }
  3405.         $entidad=$bancoRepository->findByCuenta($factura->getCcc());
  3406.         $importeTotal=0;
  3407.         foreach ($factura->getConceptos() as $concepto){
  3408.             $importeTotal+=$concepto->getImporte();
  3409.         }
  3410.         $importeIva=round($factura->getIva()*$importeTotal/100,2);
  3411.         $totalFactura=round($importeTotal+$importeIva,2);
  3412.         if( $totalFactura!==$factura->getTotalFactura() ){
  3413.             $factura->setTotalFactura($totalFactura);
  3414.             $entityManager->flush();
  3415.         }
  3416.         $params=[
  3417.             'factura' => $factura,
  3418.             'entidad'=>$entidad,
  3419.             'importeTotal'=>$importeTotal,
  3420.             'importeIva'=>$importeIva,
  3421.             'totalFactura'=>$totalFactura,
  3422.         ];
  3423.         switch ($_SERVER['APP_ENV']??'finkaluz'){
  3424.             case 'finkaluz':
  3425.                 $html=$this->renderView('factura_generica/finkaluz.factura.pdf.twig'$params);
  3426.                 break;
  3427.             case 'emfra':
  3428.                 $html=$this->renderView('factura_generica/emfra.factura.pdf.twig'$params);
  3429.                 break;
  3430.             case 'onda':
  3431.                 $html=$this->renderView('factura_generica/onda.factura.pdf.twig'$params);
  3432.                 break;
  3433.             case 'digitel':
  3434.                 $html=$this->renderView('factura_generica/digitel.factura.pdf.twig'$params);
  3435.                 break;
  3436.             case 'apolo':
  3437.                 $html=$this->renderView('factura_generica/apolo.factura.pdf.twig'$params);
  3438.                 break;
  3439.             case 'e3': case 'telkes': case 'paladio': case 'arsen': case 'rburgos':
  3440.                 $html=$this->renderView('factura_generica/'.$_SERVER['APP_ENV'].'/factura.pdf.twig'$params);
  3441.                 break;
  3442.             default:
  3443.                 $html=$this->renderView('factura_generica/factura.pdf.twig'$params);
  3444.                 break;
  3445.         }
  3446.         //Attach PDF
  3447.         try {
  3448.             unlink(__DIR__ '/../../temp/' . (str_replace('/',"-",$factura->getNumeroFactura()) ?? 'factura_sin_número') . '.pdf');
  3449.         } catch (\Exception $exception) {
  3450.         }
  3451.         $pdfPath=__DIR__ '/../../temp/' . (str_replace('/',"-",$factura->getNumeroFactura()) ?? 'factura_sin_número') . '.pdf';
  3452.         $pdf->generateFromHtml(
  3453.             $html,
  3454.             $pdfPath
  3455.         );
  3456.         $params['pdf']=base64_encode(file_get_contents($pdfPath));
  3457.         //Detect NIF type
  3458.         $nif=$factura->getNifCliente();
  3459.         $first=ctype_alphasubstr($nif,0,1) );
  3460.         $last=ctype_alphasubstr($nif,strlen($nif)-1,1) );
  3461.         $validador= new Validador();
  3462.         if( $validador->validateCif($nif) ){
  3463.             $params['tipoDocumento']='CIF';
  3464.         }
  3465.         elseif($first && $last)
  3466.             $params['tipoDocumento']='NIE';
  3467.         elseif ($first)
  3468.             $params['tipoDocumento']='CIF';
  3469.         else
  3470.             $params['tipoDocumento']='DNI';
  3471.         switch ($params['tipoDocumento']){
  3472.             case 'NIE':case 'DNI':
  3473.             $cliente=$factura->getContrato()->getCliente();
  3474.             if ( $factura->getNombreCliente()==$cliente->__toString() ){
  3475.                 $params['nombre']['nombre']=$cliente->getNombre();
  3476.                 $params['nombre']['apellido1']=$cliente->getApellido();
  3477.                 $params['nombre']['apellido2']=$cliente->getApellido2();
  3478.             }
  3479.             else{
  3480.                 $nombreArray=explode' '$factura->getNombreCliente() );
  3481.                 $arrayCount=count($nombreArray);
  3482.                 $params['nombre']['nombre']=$nombreArray[0];
  3483.                 if($arrayCount==2){
  3484.                     $params['nombre']['apellido1']=$nombreArray[1];
  3485.                 }elseif ($arrayCount==3){
  3486.                     $params['nombre']['apellido1']=$nombreArray[1];
  3487.                     $params['nombre']['apellido2']=$nombreArray[2];
  3488.                 }elseif ($arrayCount==4){
  3489.                     $params['nombre']['nombre'].=' '.$nombreArray[1];
  3490.                     $params['nombre']['apellido1']=$nombreArray[2];
  3491.                     $params['nombre']['apellido2']=$nombreArray[3];
  3492.                 }else {
  3493.                     $nombreArray explode(' '$factura->getNombreCliente());
  3494.                     $arrayCount count($nombreArray);
  3495.                     if ($arrayCount 1) {
  3496.                         $params['nombre']['apellido1'] = '';
  3497.                         $params['nombre']['apellido2'] = '';
  3498.                         $i=1;
  3499.                         for (; $i $arrayCount$i++) {
  3500.                             $concatenatedString $params['nombre']['apellido1'] . $nombreArray[$i] . ' ';
  3501.                             if (strlen($concatenatedString) <= 40) {
  3502.                                 $params['nombre']['apellido1'] = $concatenatedString;
  3503.                             } else {
  3504.                                 break;
  3505.                             }
  3506.                         }
  3507.                         for (; $i $arrayCount$i++) {
  3508.                             $concatenatedString $params['nombre']['apellido2'] . $nombreArray[$i] . ' ';
  3509.                             if (strlen($concatenatedString) <= 40) {
  3510.                                 $params['nombre']['apellido2'] = $concatenatedString;
  3511.                             } else {
  3512.                                 break;
  3513.                             }
  3514.                         }
  3515.                     }
  3516.                     $params['nombre']['apellido1'] = trim($params['nombre']['apellido1']);
  3517.                     $params['nombre']['apellido2'] = trim($params['nombre']['apellido2']);
  3518.                 }
  3519.             }
  3520.         }
  3521.         switch ($_SERVER['APP_ENV']??'finkaluz'){
  3522.             case 'finkaluz':
  3523.                 $xml=$this->renderView('factura_generica/finkaluz.factura.xml.twig'$params);
  3524.                 break;
  3525.             case 'emfra':
  3526.                 $xml=$this->renderView('factura_generica/emfra.factura.xml.twig'$params);
  3527.                 break;
  3528.             case 'onda':
  3529.                 $xml=$this->renderView('factura_generica/onda.factura.xml.twig'$params);
  3530.                 break;
  3531.             case 'digitel':
  3532.                 $xml=$this->renderView('factura_generica/digitel.factura.xml.twig'$params);
  3533.                 break;
  3534.             case 'apolo':
  3535.                 $xml=$this->renderView('factura_generica/apolo.factura.xml.twig'$params);
  3536.                 break;
  3537.             case 'e3': case 'telkes': case 'paladio': case 'arsen': case 'rburgos':
  3538.                 $xml=$this->renderView('factura_generica/'.$_SERVER['APP_ENV'].'/factura.xml.twig'$params);
  3539.                 break;
  3540.             default:
  3541.                 $xml=$this->renderView('factura_generica/factura.xml.twig'$params);
  3542.                 break;
  3543.         }
  3544.         $path=__DIR__ '/../../temp/';
  3545.         $filename=(str_replace('/',"-",$factura->getNumeroFactura()) ?? 'factura_sin_número') . '.xml';
  3546.         $filesystem->dumpFile($path.$filename$xml);
  3547.         $response= new BinaryFileResponse($path.$filename);
  3548.         // Create the disposition of the file
  3549.         $disposition $response->headers->makeDisposition(
  3550.             ResponseHeaderBag::DISPOSITION_ATTACHMENT,
  3551.             $filename
  3552.         );
  3553.         // Set the content disposition
  3554.         $response->headers->set('Content-Disposition'$disposition);
  3555.         // Dispatch request
  3556.         return $response;
  3557.     }
  3558.     /**
  3559.      * @Route("factura/otros/{id}/enviar", name="facturaGenerica_enviar", methods={"GET", "POST"})
  3560.      */
  3561.     public function enviarGenerica(FacturaGenerica $facturaPdf $pdfBancoRepository $bancoRepository,
  3562.                                    MailerInterface $mailerEntityManagerInterface $entityManager): Response
  3563.     {
  3564.         $this->denyAccessUnlessGranted('ROLE_FACTURACION');
  3565.         $logger = new Logger('factura_logger');
  3566.         $logger->pushHandler(new StreamHandler(__DIR__.'/../../logs/email.log'Logger::DEBUG));
  3567.         $entidad $bancoRepository->findByCuenta($factura->getCcc());
  3568.         $tarifa $factura->getTarifa();
  3569.         if ($tarifa->getTipoTarifa() == 'Electricidad') {
  3570.             $subject 'FACTURA ELECTRICIDAD';
  3571.             $tipo='electricidad';
  3572.         }
  3573.         else {
  3574.             $subject 'FACTURA GAS';
  3575.             $tipo='gas';
  3576.         }
  3577.         $importeTotal=0;
  3578.         foreach ($factura->getConceptos() as $concepto){
  3579.             $importeTotal+=$concepto->getImporte();
  3580.         }
  3581.         $importeIva=round($factura->getIva()*$importeTotal/100,2);
  3582.         $totalFactura=round($importeTotal+$importeIva,2);
  3583.         if( $totalFactura!==$factura->getTotalFactura() ) {
  3584.             $factura->setTotalFactura($totalFactura);
  3585.             $entityManager->flush();
  3586.         }
  3587.         $params=[
  3588.             'factura' => $factura,
  3589.             'entidad'=>$entidad,
  3590.             'importeTotal'=>$importeTotal,
  3591.             'importeIva'=>$importeIva,
  3592.             'totalFactura'=>$totalFactura,
  3593.         ];
  3594.         switch ($_SERVER['APP_ENV']??'finkaluz'){
  3595.             case 'finkaluz':
  3596.                 $html=$this->renderView('factura_generica/finkaluz.factura.pdf.twig'$params);
  3597.                 break;
  3598.             case 'emfra':
  3599.                 $html=$this->renderView('factura_generica/emfra.factura.pdf.twig'$params);
  3600.                 break;
  3601.             case 'onda':
  3602.                 $html=$this->renderView('factura_generica/onda.factura.pdf.twig'$params);
  3603.                 break;
  3604.             case 'digitel':
  3605.                 $html=$this->renderView('factura_generica/digitel.factura.pdf.twig'$params);
  3606.                 break;
  3607.             case 'apolo':
  3608.                 $html=$this->renderView('factura_generica/apolo.factura.pdf.twig'$params);
  3609.                 break;
  3610.             case 'e3': case 'telkes': case 'paladio': case 'arsen': case 'rburgos':
  3611.                 $html=$this->renderView('factura_generica/'.$_SERVER['APP_ENV'].'/factura.pdf.twig'$params);
  3612.                 break;
  3613.             default:
  3614.                 $html=$this->renderView('factura_generica/factura.pdf.twig'$params);
  3615.                 break;
  3616.         }
  3617.         try {
  3618.             unlink(__DIR__ '/../../temp/' . (str_replace('/',"-",$factura->getNumeroFactura()) ?? 'factura_sin_número') . '.pdf');
  3619.         } catch (\Exception $exception) {
  3620.         }
  3621.         $pdf->generateFromHtml(
  3622.             $html,
  3623.             __DIR__ '/../../temp/' . (str_replace('/',"-",$factura->getNumeroFactura()) ?? 'factura_sin_número') . '.pdf'
  3624.         );
  3625.         try {
  3626.             switch ($_SERVER['APP_ENV']??'finkaluz'){
  3627.                 case 'finkaluz':
  3628.                     $body=$this->renderView('email/finkaluz.factura.html.twig',['tipo'=>$tipo]);
  3629.                     $from='finkaluz@finkaluz.com';
  3630.                     break;
  3631.                 case 'emfra':
  3632.                     $body=$this->renderView('email/emfra.factura.html.twig',['tipo'=>$tipo]);
  3633.                     $from='finkaluz@finkaluz.com';
  3634.                     break;
  3635.                 case 'onda':
  3636.                     $body=$this->renderView('email/onda.factura.html.twig',['tipo'=>$tipo]);
  3637.                     $from='facturacion@ondaenergia.es';
  3638.                     break;
  3639.                 case 'digitel':
  3640.                     $body=$this->renderView('email/digitel.factura.html.twig',['tipo'=>$tipo'email'=>$factura->getContrato()->getCliente()->getEmail()]);
  3641.                     $from='energy@itdigitel.es';
  3642.                     break;
  3643.                 case 'apolo':
  3644.                     $body=$this->renderView('email/apolo.factura.html.twig',['tipo'=>$tipo'factura'=>$factura]);
  3645.                     $from='clientes@vibraenergies.es';
  3646.                     break;
  3647.                 case 'e3':
  3648.                     $body=$this->renderView('email/e3/factura.html.twig',['tipo'=>$tipo]);
  3649.                     $from='e3powerenergy@e3powerenergy.com';
  3650.                     break;
  3651.                 case 'telkes':
  3652.                     $body=$this->renderView('email/telkes/factura.html.twig',['tipo'=>$tipo]);
  3653.                     $from='info@telkesenergia.com';
  3654.                     break;
  3655.                 case 'paladio':
  3656.                     $body=$this->renderView('email/paladio/factura.html.twig',['tipo'=>$tipo]);
  3657.                     $from='clientes@paladiopartners.com';
  3658.                     break;
  3659.                 case 'arsen':
  3660.                     $body=$this->renderView('email/arsen/factura.html.twig',['tipo'=>$tipo]);
  3661.                     $from='arsenenergia@arsenenergia.com';
  3662.                     break;
  3663.                 case 'rburgos':
  3664.                     $body=$this->renderView('email/rburgos/factura.html.twig',['tipo'=>$tipo]);
  3665.                     $from='facturacion@rburgos.es';
  3666.                     break;
  3667.                 default:
  3668.                     $body=$this->renderView('email/factura.html.twig',['tipo'=>$tipo]);
  3669.                     $from='no-reply@energaze.com';
  3670.                     break;
  3671.             }
  3672.             $message = (new Email())
  3673.                 ->subject($subject)
  3674.                 ->from($from)
  3675.                 ->to($factura->getContrato()->getCliente()->getEmail())
  3676.                 ->html($body)
  3677.                 ->attachFromPath(__DIR__ '/../../temp/' . (str_replace('/',"-",$factura->getNumeroFactura()) ?? 'factura_sin_número') . '.pdf');
  3678.             /*try{
  3679.                 unlink(__DIR__.'/../../temp/'.(str_replace('/',"-",$factura->getNumeroFactura())??'factura_sin_número').'.pdf');
  3680.             }catch (\Exception $exception){}*/
  3681.             $mailer->send($message);
  3682.             $status='success';
  3683.         }catch (\Exception $exception){
  3684.             $status='error';
  3685.             $logger->info($exception->getMessage());
  3686.         }
  3687.         return $this->redirectToRoute('facturaGenerica_show',['id'=>$factura->getId(), 'status'=>$status]);
  3688.     }
  3689.     /**
  3690.      * @Route("factura/otros/{id}/pagar", name="facturaGenerica_pagar", methods={"GET","POST"})
  3691.      */
  3692.     public function pagarGenerica(FacturaGenerica $facturaMailerInterface $mailerEntityManagerInterface $entityManager): Response
  3693.     {
  3694.         if( $factura->getContrato()->getCliente()->getUser()!=$this->getUser() ){
  3695.             $this->denyAccessUnlessGranted('ROLE_FACTURACION');
  3696.         }
  3697.         $error=false;
  3698.         $version="";
  3699.         $params="";
  3700.         $signature="";
  3701.         $logger = new Logger('my_logger');
  3702.         $logger->pushHandler(new StreamHandler(__DIR__.'/../../logs/pruebaRedsys.log'Logger::DEBUG));
  3703.         if($factura->getDevuelta()) {
  3704.             //$logger->info('Detectado !pagado. Inicia comprobación.');
  3705.             $api = new RedsysAPI;
  3706.             if (!empty($_POST)) {//URL DE RESP. ONLINE
  3707.                 //$logger->info('Detectado POST. Inicia comprobación.');
  3708.                 $version $_POST["Ds_SignatureVersion"];
  3709.                 $datos $_POST["Ds_MerchantParameters"];
  3710.                 $signatureRecibida $_POST["Ds_Signature"];
  3711.                 $decodec $api->decodeMerchantParameters($datos);
  3712.                 $kc 'f534PExNDgl6MWbwG8BglFJTFeFzr9Dq'//Clave recuperada de CANALES
  3713.                 $firma $api->createMerchantSignatureNotif($kc$datos);
  3714.                 $logger->info(gettype($decodec));
  3715.                 $logger->info($decodec["Ds_Response"]);
  3716.                 $decodec2=json_decode($decodectrue);
  3717.                 $logger->info(gettype($decodec2));
  3718.                 $logger->info($decodec2["Ds_Response"]);
  3719.                 if ($firma === $signatureRecibida) {
  3720.                     if (intval($decodec['Ds_Response'])<100){
  3721.                         $pagado true;
  3722.                         $logger->info('Marcando $pagado=true');
  3723.                     }else{
  3724.                         $error=true;
  3725.                     }
  3726.                     echo'FIRMA OK';
  3727.                 } else {
  3728.                     $pagado false;
  3729.                     //$logger->info('Firma POST denegada.');
  3730.                     echo'FIRMA KO';
  3731.                 }
  3732.             }
  3733.             elseif (!empty($_GET)) {//URL DE RESP. ONLINE
  3734.                 //$logger->info('Detectado GET. Inicia comprobación.');
  3735.                 $version $_GET["Ds_SignatureVersion"];
  3736.                 $datos $_GET["Ds_MerchantParameters"];
  3737.                 $signatureRecibida $_GET["Ds_Signature"];
  3738.                 $decodec json_decode($api->decodeMerchantParameters($datos), true);
  3739.                 $kc 'f534PExNDgl6MWbwG8BglFJTFeFzr9Dq'//Clave recuperada de CANALES
  3740.                 $firma $api->createMerchantSignatureNotif($kc$datos);
  3741.                 $logger->info(gettype($decodec));
  3742.                 $logger->info($decodec["Ds_Response"]);
  3743.                 $decodec2=json_decode($decodectrue);
  3744.                 $logger->info(gettype($decodec2));
  3745.                 $logger->info($decodec2["Ds_Response"]);
  3746.                 if ($firma === $signatureRecibida) {
  3747.                     if (intval($decodec['Ds_Response'])<100){
  3748.                         $pagado true;
  3749.                         $logger->info('Marcando $pagado=true');
  3750.                     }else{
  3751.                         $error=true;
  3752.                     }
  3753.                     echo'FIRMA OK';
  3754.                 } else {
  3755.                     $pagado false;
  3756.                     //$logger->info('Firma GET denegada.');
  3757.                     echo'FIRMA KO';
  3758.                 }
  3759.             }
  3760.             else{
  3761.                 $api=new RedsysAPI();
  3762.                 $logger = new Logger('my_logger');
  3763.                 $logger->pushHandler(new StreamHandler(__DIR__.'/../../logs/pruebaRedsys.log'Logger::DEBUG));
  3764.                 $fuc="351398243";
  3765.                 $terminal="1";
  3766.                 $moneda="978";
  3767.                 $trans="0";
  3768.                 $url=$this->generateUrl('facturaGenerica_pagar',['id' => $factura->getId()], UrlGeneratorInterface::ABSOLUTE_URL);
  3769.                 $urlOKKO=$this->generateUrl('facturaGenerica_pagar',['id' => $factura->getId()], UrlGeneratorInterface::ABSOLUTE_URL);
  3770.                 $id=time();
  3771.                 $amount=str_replace('.','',$factura->getTotalFactura());;
  3772.                 // Se Rellenan los campos
  3773.                 $api->setParameter("DS_MERCHANT_AMOUNT",$amount);
  3774.                 $api->setParameter("DS_MERCHANT_ORDER",$id);
  3775.                 $api->setParameter("DS_MERCHANT_MERCHANTCODE",$fuc);
  3776.                 $api->setParameter("DS_MERCHANT_CURRENCY",$moneda);
  3777.                 $api->setParameter("DS_MERCHANT_TRANSACTIONTYPE",$trans);
  3778.                 $api->setParameter("DS_MERCHANT_TERMINAL",$terminal);
  3779.                 $api->setParameter("DS_MERCHANT_MERCHANTURL",$url);
  3780.                 $api->setParameter("DS_MERCHANT_URLOK",$urlOKKO);
  3781.                 $api->setParameter("DS_MERCHANT_URLKO",$urlOKKO);
  3782.                 //Datos de configuración
  3783.                 $version="HMAC_SHA256_V1";
  3784.                 $kc 'f534PExNDgl6MWbwG8BglFJTFeFzr9Dq';//Clave recuperada de CANALES
  3785.                 // Se generan los parámetros de la petición
  3786.                 $request "";
  3787.                 $params $api->createMerchantParameters();
  3788.                 $signature $api->createMerchantSignature($kc);
  3789.             }
  3790.             if ($pagado??null === true) {
  3791.                 $logger->info('Marcando como pagado.');
  3792.                 $factura->setDevuelta(false);
  3793.                 $entityManager->persist($factura);
  3794.                 $entityManager->flush();
  3795.                 //Notificación email
  3796.                 try {
  3797.                     $message = (new Email())
  3798.                         ->subject('FACTURA PAGADA')
  3799.                         ->from('no-reply@energaze.com')
  3800.                         ->to($factura->getContrato()->getCliente()->getEmail())
  3801.                         ->html($this->renderView('email/facturaPagada.html.twig',['factura'=>$factura]));
  3802.                     $mailer->send($message);
  3803.                 }catch (\Exception $exception){
  3804.                     $logger->info($exception->getMessage());
  3805.                 }
  3806.             }elseif ($pagado??null === false){
  3807.                 $error=true;
  3808.             }
  3809.         }
  3810.         return $this->render('factura/pagar.html.twig', [
  3811.             'factura' => $factura,
  3812.             'error' => $error,
  3813.             'version' => $version,
  3814.             'params' => $params,
  3815.             'signature' => $signature,
  3816.         ]);
  3817.     }
  3818.     /**
  3819.      * @Route("factura/otros/{id}/edit", name="facturaGenerica_edit", methods={"GET","POST"})
  3820.      */
  3821.     public function editGenerica(Request $requestFacturaGenerica $facturaEntityManagerInterface $entityManager): Response
  3822.     {
  3823.         $this->denyAccessUnlessGranted('ROLE_FACTURACION');;
  3824.         $logger = new Logger('my_logger');
  3825.         $logger->pushHandler(new StreamHandler(__DIR__.'/../../logs/pruebaApi.log'Logger::DEBUG));
  3826.         $form $this->createForm(FacturaGenericaType::class, $factura);
  3827.         $form->handleRequest($request);
  3828.         if ($form->isSubmitted() && $form->isValid()) {
  3829.             $factura->calcularTotal();
  3830.             $entityManager->flush();
  3831.             $logger->info('Factura '.$factura->getId().' editada por usuario '.$this->getUser()->getUsername());
  3832.             return $this->redirectToRoute('facturaGenerica_show', ['id'=>$factura->getId()]);
  3833.         }
  3834.         return $this->render('factura_generica/edit.html.twig', [
  3835.             'contrato'=>$factura->getContrato(),
  3836.             'factura' => $factura,
  3837.             'form' => $form->createView(),
  3838.         ]);
  3839.     }
  3840.     /**
  3841.      * @Route("factura/otros/{id}", name="facturaGenerica_delete", methods={"POST"})
  3842.      */
  3843.     public function deleteGenerica(Request $requestFacturaGenerica $facturaFacturaGenericaRepository $facturaRepository): Response
  3844.     {
  3845.         if ($this->isCsrfTokenValid('delete'.$factura->getId(), $request->request->get('_token'))) {
  3846.             $contrato=$factura->getContrato();
  3847.             $facturaRepository->remove($facturatrue);
  3848.         }
  3849.         return $this->redirectToRoute('contrato_show',['id'=>$contrato->getId()], Response::HTTP_SEE_OTHER);
  3850.     }
  3851. }