<?php
namespace App\Controller;
use App\Entity\Module;
use App\Form\ModuleType;
use App\Repository\CycleRepository;
use App\Repository\ModuleRepository;
use App\Repository\UserRepository;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
use Symfony\Component\HttpFoundation\JsonResponse;
#[Route('/module')]
class ModuleController extends AbstractController
{
#[Route('/', name: 'app_module_index', methods: ['GET'])]
public function index(ModuleRepository $moduleRepository): Response
{
$id = $this->get('security.token_storage')->getToken()->getUser()->getId();
$role=$this->get('security.token_storage')->getToken()->getUser()->getRoles();
if($role[0]=="ROLE_TEACHER"){
$modules=$moduleRepository->moduleByformateur($id);
}else{
$modules=$moduleRepository->findAll();
}
return $this->render('module/index.html.twig', [
'modules' => $modules,
]);
}
#[Route('/new', name: 'app_module_new', methods: ['GET', 'POST'])]
public function new(Request $request, ModuleRepository $moduleRepository,CycleRepository $cycleRepository,UserRepository $userRepository): Response
{
$module = new Module();
$form = $this->createForm(ModuleType::class, $module);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$moduleRepository->save($module, true);
return $this->redirectToRoute('app_module_index', [], Response::HTTP_SEE_OTHER);
}
return $this->renderForm('module/new.html.twig', [
'module' => $module,
'form' => $form,
]);
}
#[Route('/{id}', name: 'app_module_show', methods: ['GET'])]
public function show(Module $module): Response
{
return $this->render('module/show.html.twig', [
'module' => $module,
]);
}
#[Route('/{id}/edit', name: 'app_module_edit', methods: ['GET', 'POST'])]
public function edit(Request $request, Module $module, ModuleRepository $moduleRepository,CycleRepository $cycleRepository): Response
{
$form = $this->createForm(ModuleType::class, $module);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$moduleRepository->save($module, true);
return $this->redirectToRoute('app_module_index', [], Response::HTTP_SEE_OTHER);
}
return $this->renderForm('module/edit.html.twig', [
'module' => $module,
'form' => $form,
]);
}
#[Route('/{id}', name: 'app_module_delete', methods: ['POST'])]
public function delete(Request $request, Module $module, ModuleRepository $moduleRepository): Response
{
if ($this->isCsrfTokenValid('delete'.$module->getId(), $request->request->get('_token'))) {
$moduleRepository->remove($module, true);
}
return $this->redirectToRoute('app_module_index', [], Response::HTTP_SEE_OTHER);
}
}