src/Controller/ContaBancariaMovimentacaoController.php line 48
<?php
namespace App\Controller;
use App\Entity\ContaBancariaMovimentacao;
use App\Entity\ContaBancaria;
use App\Form\ContaBancariaMovimentacaoType;
use App\Repository\ContaBancariaMovimentacaoRepository;
use App\Repository\ContaBancariaRepository;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\IsGranted;
use Dompdf\Dompdf;
#[Route('/conta_movimentacao')]
class ContaBancariaMovimentacaoController extends AbstractController
{
/**
* @IsGranted("ROLE_ADMIN")
*/
#[Route('/', name: 'app_conta_bancaria_movimentacao_index', methods: ['GET'])]
public function index(ContaBancariaMovimentacaoRepository $contaBancariaMovimentacaoRepository,Request $request): Response{
$filter['tipo'] = $request->get('tipo') ?: '';
$filter['descricao'] = $request->get('descricao') ?: '';
$filter['pagina'] = $request->get('pagina') ?: 1;
$filter['anterior'] = $this->verifica('anterior',(1 - $filter['pagina']));
$filter['primeira'] = 1;
$filter['codigo'] = $request->get('codigo') ?: '';
$filter['page'] = $request->get('page') ?: 10;
$filter['total_registros'] = $contaBancariaMovimentacaoRepository->filterGridTotal($filter);
$filter['ultima'] = $this->verifica('ultima', $filter['total_registros'],$filter['page']);
$filter['proxima'] = $this->verifica('proxima', (1+ $filter['pagina']), $filter['ultima']);
$filter['dataInicial'] ='';
$filter['dataFinal'] = '';
$filter['conta'] = $request->get('conta') ?: '';
return $this->render('conta_bancaria_movimentacao/index.html.twig', [
'filtro' => $filter,
'contas_movimetacao' => $contaBancariaMovimentacaoRepository->filterGrid($filter),
]);
}
#[Route('/movimentacoes', name: 'app_conta_bancaria_movimentacao_publico', methods: ['GET'])]
public function conta_bancaria(ContaBancariaMovimentacaoRepository $contaBancariaMovimentacaoRepository, Request $request, ContaBancariaRepository $contaRepository): Response {
$filter['codigo'] = $request->get('codigo') ?: 0;
$filter['ano'] = $request->get('ano')?: date('Y');
$filter['mes'] = $request->get('mes')?: date('m');
$conta = $contaRepository->findOneBy(array('codigo'=>$filter['codigo']));
$lista = $contaBancariaMovimentacaoRepository->findBy(array('codigo'=>$filter['codigo'],'ano'=>$filter['ano'],'mes'=>$filter['mes']),array('data'=>'ASC'));
if ($request->get('impressao')) {
$filter['page'] = 'all';
if ($request->get('pdf')) {
$html = $this->renderView('conta_bancaria_movimentacao/impressao_pdf.html.twig', [
'filtro' => $filter,
'contas' => $lista,
'conta' => $conta,
]);
$dompdf = new Dompdf();
$dompdf->setPaper('A4', 'landscape');
$dompdf->set_option("isPhpEnabled", true);
$options = $dompdf->getOptions();
$options->setDefaultFont('Courier');
$dompdf->setOptions($options);
$dompdf->loadHtml($html);
$dompdf->render();
return new Response(
$dompdf->stream('resume', ["Attachment" => false]),
Response::HTTP_OK,
['Content-Type' => 'application/pdf']
);
}elseif($request->get('excel')){
$titulos = array("DATA","TIPO","VALOR","DESCRIÇÃO");
$rows[] = implode(';', $titulos);
foreach ($lista as $value) {
$data = array($value->getData() ? $value->getData()->format('d/m/Y') :null, $value->getTipo() . $value->getTipoDescricao() , $value->getValor(), $value->getDescricao());
$rows[] = implode(';', $data);
}
$content = implode("\n", $rows);
$response = new Response($content);
$response->headers->set('Content-Type', 'text/csv');
return $response;
}else{
return $this->render('conta_bancaria_movimentacao/impressao.html.twig', [
'filtro' => $filter,
'contas' => $lista,
'conta' => $conta,
]);
}
}
return $this->render('conta_bancaria_movimentacao/conta_bancaria_movimentacao.html.twig', [
'filtro' => $filter,
'contas' => $lista,
'conta' => $conta,
]);
}
private function verifica($str, $pagina, $page = null) {
if ($str == "anterior") {
if ($pagina < 1) {
return 1;
}
}
if ($str == "proxima") {
if ($pagina > $page) {
return $page;
}
return $pagina;
}
if ($str == "ultima") {
if($page == "all"){
$page = $pagina;
}
$valor = intdiv($pagina, $page);
if (($pagina % $page) > 0) {
return ++$valor;
} else {
return $valor;
}
}
}
/**
* @IsGranted("ROLE_ADMIN")
*/
#[Route('/new', name: 'app_conta_bancaria_movimetacao_new', methods: ['GET', 'POST'])]
public function new(Request $request, ContaBancariaMovimentacaoRepository $contaBancariaMovimentacaoRepository): Response
{
$contaMovimentacao = new ContaBancariaMovimentacao();
$form = $this->createForm(ContaBancariaMovimentacaoType::class, $contaMovimentacao);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$contaBancariaMovimentacaoRepository->save($contaMovimentacao, true);
return $this->redirectToRoute('app_conta_bancaria_movimentacao_index', [], Response::HTTP_SEE_OTHER);
}
return $this->renderForm('conta_bancaria_movimentacao/new.html.twig', [
'conta_bancarium' => $contaMovimentacao,
'form' => $form,
]);
}
/**
* @IsGranted("ROLE_ADMIN")
*/
#[Route('/{id}/edit', name: 'app_conta_bancaria_movimentacao_edit', methods: ['GET', 'POST'])]
public function edit(Request $request, ContaBancariaMovimentacao $contaMovimentacao, ContaBancariaMovimentacaoRepository $contaBancariaMovimentacaoRepository): Response
{
$form = $this->createForm(ContaBancariaMovimentacaoType::class, $contaMovimentacao);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$contaBancariaMovimentacaoRepository->save($contaMovimentacao, true);
return $this->redirectToRoute('app_conta_bancaria_movimentacao_index', [], Response::HTTP_SEE_OTHER);
}
return $this->renderForm('conta_bancaria_movimentacao/edit.html.twig', [
'conta_movimentacao' => $contaMovimentacao,
'form' => $form,
]);
}
/**
* @IsGranted("ROLE_ADMIN")
*/
#[Route('/{id}', name: 'app_conta_bancaria_movimentacao_delete', methods: ['POST'])]
public function delete(Request $request, ContaBancariaMovimentacao $contaBancarium, ContaBancariaMovimentacaoRepository $ContaBancariaMovimentacaoRepository): Response
{
if ($this->isCsrfTokenValid('delete'.$contaBancarium->getId(), $request->request->get('_token'))) {
$ContaBancariaMovimentacaoRepository->remove($contaBancarium, true);
}
return $this->redirectToRoute('app_conta_bancaria_movimentacao_index', [], Response::HTTP_SEE_OTHER);
}
}