Merge branch 'Marvin'
This commit is contained in:
@@ -4,6 +4,8 @@ namespace App\Controller;
|
||||
|
||||
use App\Entity\Sortie;
|
||||
use App\Form\SortieType;
|
||||
use App\Repository\LieuRepository;
|
||||
use App\Repository\VilleRepository;
|
||||
use Doctrine\ORM\EntityManagerInterface;
|
||||
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
||||
use Symfony\Component\HttpFoundation\Request;
|
||||
@@ -18,25 +20,23 @@ class SortieController extends AbstractController
|
||||
{
|
||||
$sortie = new Sortie();
|
||||
|
||||
// Créer le formulaire
|
||||
// Créez le formulaire sans options spéciales
|
||||
$form = $this->createForm(SortieType::class, $sortie);
|
||||
|
||||
// Traiter la requête
|
||||
$form->handleRequest($request);
|
||||
|
||||
if ($form->isSubmitted() && $form->isValid()) {
|
||||
// Sauvegarder dans la base de données
|
||||
// Sauvegarde dans la base de données
|
||||
$entityManager->persist($sortie);
|
||||
$entityManager->flush();
|
||||
|
||||
// Rediriger après soumission
|
||||
$this->addFlash('success', 'Sortie créée avec succès !');
|
||||
$this->addFlash('success', 'La sortie a été créée avec succès.');
|
||||
|
||||
return $this->redirectToRoute('sortie_create');
|
||||
}
|
||||
|
||||
// Afficher le formulaire
|
||||
return $this->render('sortie/create.html.twig', [
|
||||
'form' => $form->createView(),
|
||||
]);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -3,6 +3,8 @@
|
||||
namespace App\Controller;
|
||||
|
||||
use App\Entity\Ville;
|
||||
use App\Repository\LieuRepository;
|
||||
use App\Repository\VilleRepository;
|
||||
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
||||
use Symfony\Component\HttpFoundation\JsonResponse;
|
||||
use Symfony\Component\HttpFoundation\Response;
|
||||
@@ -10,19 +12,36 @@ use Symfony\Component\Routing\Attribute\Route;
|
||||
|
||||
class VilleController extends AbstractController
|
||||
{
|
||||
#[Route('/get-lieux/{id}', name: 'get_lieux')]
|
||||
public function getLieux(Ville $ville): JsonResponse
|
||||
{
|
||||
$lieux = $ville->getLieux();
|
||||
|
||||
$data = [];
|
||||
#[Route('/get-lieux/{id}', name: 'get_lieux', methods: ['GET'])]
|
||||
public function getLieux(string $id, VilleRepository $villeRepository, LieuRepository $lieuRepository): JsonResponse
|
||||
{
|
||||
// Trouve la ville correspondant à l'ID (GUID)
|
||||
$ville = $villeRepository->find($id);
|
||||
|
||||
if (!$ville) {
|
||||
return new JsonResponse(['error' => 'Ville non trouvée'], Response::HTTP_NOT_FOUND);
|
||||
}
|
||||
|
||||
// Trouve tous les lieux associés à la ville
|
||||
$lieux = $lieuRepository->findBy(['ville' => $ville]);
|
||||
$response = [];
|
||||
|
||||
foreach ($lieux as $lieu) {
|
||||
$data[] = [
|
||||
$response[] = [
|
||||
'id' => $lieu->getIdLieu(),
|
||||
'nom' => $lieu->getNom(),
|
||||
'rue' => $lieu->getRue(),
|
||||
'codePostal' => $lieu->getVille()->getCodePostal(),
|
||||
'latitude' => $lieu->getLatitude(),
|
||||
'longitude' => $lieu->getLongitude(),
|
||||
];
|
||||
}
|
||||
|
||||
return new JsonResponse($data);
|
||||
return new JsonResponse($response);
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user