suppr table ville
This commit is contained in:
@@ -26,54 +26,48 @@ class SortieController extends AbstractController
|
||||
ParticipantRepository $participantRepository,
|
||||
EtatRepository $etatRepository
|
||||
): Response {
|
||||
$sortie = new Sortie();
|
||||
|
||||
$token = $tokenStorage->getToken();
|
||||
$userConnect = $token?->getUser();
|
||||
|
||||
// Vérifier si l'utilisateur est connecté
|
||||
$userConnect = $tokenStorage->getToken()?->getUser();
|
||||
if (!$userConnect) {
|
||||
$this->addFlash('error', 'Vous devez être connecté pour créer une sortie.');
|
||||
return $this->redirectToRoute('app_login');
|
||||
}
|
||||
|
||||
$sortie = new Sortie();
|
||||
$form = $this->createForm(SortieType::class, $sortie);
|
||||
$form->handleRequest($request);
|
||||
|
||||
if ($form->isSubmitted() && $form->isValid()) {
|
||||
$lieuId = $form->get('lieu')->getData();
|
||||
$lieu = $lieuRepository->find($lieuId);
|
||||
|
||||
// Vérifier le lieu
|
||||
$lieu = $form->get('lieu')->getData();
|
||||
if (!$lieu) {
|
||||
$this->addFlash('error', 'Le lieu sélectionné est invalide.');
|
||||
$this->addFlash('error', 'Veuillez sélectionner un lieu valide.');
|
||||
return $this->redirectToRoute('sortie_create');
|
||||
}
|
||||
|
||||
$sortie->setLieu($lieu);
|
||||
|
||||
// Vérifier le participant (organisateur)
|
||||
$participant = $participantRepository->find($userConnect->getIdParticipant());
|
||||
|
||||
if (!$participant) {
|
||||
$this->addFlash('error', 'Impossible de déterminer le site de l\'utilisateur.');
|
||||
$this->addFlash('error', 'Impossible de trouver votre profil.');
|
||||
return $this->redirectToRoute('sortie_create');
|
||||
}
|
||||
|
||||
$sortie->setSite($participant->getSite());
|
||||
|
||||
$etat = $etatRepository->find('019349ba-38ca-7a39-93c3-62f046671525');
|
||||
// Définir les relations et l'état initial
|
||||
$etat = $etatRepository->findOneBy(['libelle' => 'Créée']);
|
||||
if (!$etat) {
|
||||
$this->addFlash('error', 'État non trouvé.');
|
||||
$this->addFlash('error', 'Erreur interne : état introuvable.');
|
||||
return $this->redirectToRoute('sortie_create');
|
||||
}
|
||||
|
||||
$sortie->setEtat($etat);
|
||||
|
||||
$sortie->setOrganisateur($participant);
|
||||
$sortie->setLieu($lieu)
|
||||
->setSite($participant->getSite())
|
||||
->setEtat($etat)
|
||||
->setOrganisateur($participant);
|
||||
|
||||
$entityManager->persist($sortie);
|
||||
$entityManager->flush();
|
||||
|
||||
$this->addFlash('success', 'La sortie a été créée avec succès.');
|
||||
|
||||
return $this->redirectToRoute('home');
|
||||
}
|
||||
|
||||
@@ -84,64 +78,54 @@ class SortieController extends AbstractController
|
||||
}
|
||||
|
||||
#[Route('/view/{id}', name: 'view', methods: ['GET'])]
|
||||
public function view(string $id, EntityManagerInterface $entityManager, TokenStorageInterface $tokenStorage): Response
|
||||
{
|
||||
$token = $tokenStorage->getToken();
|
||||
$userConnect = $token?->getUser();
|
||||
|
||||
public function view(
|
||||
string $id,
|
||||
EntityManagerInterface $entityManager,
|
||||
TokenStorageInterface $tokenStorage
|
||||
): Response {
|
||||
$sortie = $entityManager->getRepository(Sortie::class)->find($id);
|
||||
|
||||
if (!$sortie) {
|
||||
$this->addFlash('error', 'La sortie demandée n\'existe pas.');
|
||||
$this->addFlash('error', 'Cette sortie n\'existe pas.');
|
||||
return $this->redirectToRoute('home');
|
||||
}
|
||||
|
||||
$profile = $this->getUser();
|
||||
|
||||
return $this->render('sortie/view.html.twig', [
|
||||
'sortie' => $sortie,
|
||||
'profile' => $userConnect,
|
||||
'profile' => $tokenStorage->getToken()?->getUser(),
|
||||
]);
|
||||
}
|
||||
|
||||
#[Route('/inscription/{id}', name: 'inscription', methods: ['POST'])]
|
||||
public function inscription(string $id, EntityManagerInterface $entityManager, TokenStorageInterface $tokenStorage): Response
|
||||
{
|
||||
$token = $tokenStorage->getToken();
|
||||
$userConnect = $token?->getUser();
|
||||
|
||||
public function inscription(
|
||||
string $id,
|
||||
EntityManagerInterface $entityManager,
|
||||
TokenStorageInterface $tokenStorage
|
||||
): Response {
|
||||
$userConnect = $tokenStorage->getToken()?->getUser();
|
||||
if (!$userConnect) {
|
||||
$this->addFlash('error', 'Vous devez être connecté pour vous inscrire.');
|
||||
return $this->redirectToRoute('app_login');
|
||||
}
|
||||
|
||||
$sortie = $entityManager->getRepository(Sortie::class)->find($id);
|
||||
|
||||
if (!$sortie) {
|
||||
$this->addFlash('error', 'La sortie demandée n\'existe pas.');
|
||||
$this->addFlash('error', 'Cette sortie n\'existe pas.');
|
||||
return $this->redirectToRoute('home');
|
||||
}
|
||||
|
||||
// Conditions supplémentaires pour l'inscription
|
||||
if ($sortie->getEtat()->getLibelle() !== 'Ouverte') {
|
||||
$this->addFlash('error', 'Vous ne pouvez pas vous inscrire à cette sortie car elle n\'est pas ouverte.');
|
||||
return $this->redirectToRoute('sortie_view', ['id' => $id]);
|
||||
}
|
||||
|
||||
if ($sortie->getParticipants()->contains($userConnect)) {
|
||||
$this->addFlash('error', 'Cette sortie n\'est pas ouverte aux inscriptions.');
|
||||
} elseif ($sortie->getParticipants()->contains($userConnect)) {
|
||||
$this->addFlash('error', 'Vous êtes déjà inscrit à cette sortie.');
|
||||
return $this->redirectToRoute('sortie_view', ['id' => $id]);
|
||||
} elseif ($sortie->getParticipants()->count() >= $sortie->getNbInscriptionsMax()) {
|
||||
$this->addFlash('error', 'Cette sortie est complète.');
|
||||
} else {
|
||||
$sortie->addParticipant($userConnect);
|
||||
$entityManager->flush();
|
||||
$this->addFlash('success', 'Votre inscription a été validée.');
|
||||
}
|
||||
|
||||
if ($sortie->getParticipants()->count() >= $sortie->getNbInscriptionsMax()) {
|
||||
$this->addFlash('error', 'Le nombre maximum d\'inscriptions a été atteint pour cette sortie.');
|
||||
return $this->redirectToRoute('sortie_view', ['id' => $id]);
|
||||
}
|
||||
|
||||
$sortie->addParticipant($userConnect);
|
||||
$entityManager->flush();
|
||||
|
||||
$this->addFlash('success', 'Vous êtes inscrit à la sortie avec succès !');
|
||||
|
||||
return $this->redirectToRoute('sortie_view', ['id' => $id]);
|
||||
}
|
||||
|
||||
@@ -154,17 +138,14 @@ class SortieController extends AbstractController
|
||||
LieuRepository $lieuRepository
|
||||
): Response {
|
||||
$sortie = $entityManager->getRepository(Sortie::class)->find($id);
|
||||
|
||||
if (!$sortie) {
|
||||
$this->addFlash('error', 'La sortie demandée n\'existe pas.');
|
||||
$this->addFlash('error', 'Cette sortie n\'existe pas.');
|
||||
return $this->redirectToRoute('home');
|
||||
}
|
||||
|
||||
$token = $tokenStorage->getToken();
|
||||
$userConnect = $token?->getUser();
|
||||
|
||||
$userConnect = $tokenStorage->getToken()?->getUser();
|
||||
if ($userConnect->getIdParticipant() !== $sortie->getOrganisateur()->getIdParticipant()) {
|
||||
$this->addFlash('error', 'Vous n\'avez pas l\'autorisation de modifier cette sortie.');
|
||||
$this->addFlash('error', 'Vous ne pouvez pas modifier cette sortie.');
|
||||
return $this->redirectToRoute('home');
|
||||
}
|
||||
|
||||
@@ -172,17 +153,13 @@ class SortieController extends AbstractController
|
||||
$form->handleRequest($request);
|
||||
|
||||
if ($form->isSubmitted() && $form->isValid()) {
|
||||
$lieuId = $form->get('lieu')->getData();
|
||||
$lieu = $lieuRepository->find($lieuId);
|
||||
|
||||
$lieu = $form->get('lieu')->getData();
|
||||
if ($lieu) {
|
||||
$sortie->setLieu($lieu);
|
||||
}
|
||||
|
||||
$entityManager->flush();
|
||||
|
||||
$this->addFlash('success', 'La sortie a été mise à jour avec succès.');
|
||||
|
||||
$this->addFlash('success', 'Les modifications ont été enregistrées.');
|
||||
return $this->redirectToRoute('sortie_view', ['id' => $sortie->getIdSortie()]);
|
||||
}
|
||||
|
||||
@@ -192,5 +169,4 @@ class SortieController extends AbstractController
|
||||
'profile' => $userConnect,
|
||||
]);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user