<?php
namespace App\Controller;
use App\Entity\Operations;
use App\Form\OperationsType;
use App\Repository\OperationsRepository;
use Doctrine\ORM\EntityManagerInterface;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
/**
* @Route("/operations")
*/
class OperationsController extends AbstractController
{
/**
* @Route("/", name="app_operations_index", methods={"GET"})
*/
public function index(OperationsRepository $operationsRepository): Response
{
$this->denyAccessUnlessGranted('IS_AUTHENTICATED_FULLY');
return $this->render('operations/index.html.twig', [
'operations' => $operationsRepository->findAll(),
]);
}
/**
* @Route("/new", name="app_operations_new", methods={"GET", "POST"})
*/
// public function new(Request $request, OperationsRepository $operationsRepository, Security $security): Response
public function new(Request $request, EntityManagerInterface $entityManager ): Response
{
$this->denyAccessUnlessGranted('IS_AUTHENTICATED_FULLY');
// $operation = new Operations($security);
$operation = new Operations();
$form = $this->createForm(OperationsType::class, $operation);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
// $operationsRepository->add($operation, true, $security);
$operation->setUsers($this->getUser());
$entityManager->persist($operation);
$entityManager->flush();
return $this->redirectToRoute('app_operations_index', [], Response::HTTP_SEE_OTHER);
}
return $this->renderForm('operations/new.html.twig', [
'operation' => $operation,
'form' => $form,
]);
}
/**
* @Route("/{id}", name="app_operations_show", methods={"GET"})
*/
public function show(Operations $operation): Response
{
$this->denyAccessUnlessGranted('IS_AUTHENTICATED_FULLY');
return $this->render('operations/show.html.twig', [
'operation' => $operation,
]);
}
/**
* @Route("/{id}/edit", name="app_operations_edit", methods={"GET", "POST"})
*/
public function edit(Request $request, Operations $operation, EntityManagerInterface $entityManager ): Response
{
$this->denyAccessUnlessGranted('IS_AUTHENTICATED_FULLY');
$form = $this->createForm(OperationsType::class, $operation);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
// $operationsRepository->add($operation, true);
$operation->setUpdatedAt(new \DateTimeImmutable());
$entityManager->persist($operation);
$entityManager->flush();
return $this->redirectToRoute('app_operations_index', [], Response::HTTP_SEE_OTHER);
}
return $this->renderForm('operations/edit.html.twig', [
'operation' => $operation,
'form' => $form,
]);
}
/**
* @Route("/{id}", name="app_operations_delete", methods={"POST"})
*/
public function delete(Request $request, Operations $operation, OperationsRepository $operationsRepository): Response
{
$this->denyAccessUnlessGranted('IS_AUTHENTICATED_FULLY');
if ($this->isCsrfTokenValid('delete'.$operation->getId(), $request->request->get('_token'))) {
$operationsRepository->remove($operation, true);
}
return $this->redirectToRoute('app_operations_index', [], Response::HTTP_SEE_OTHER);
}
}