9. Ajouter, Modifier un Véhicule
9.1. Ajouter un véhicule
Dans le cas de l'ajout d'un véhicule, il faut penser qu'un conducteur doit être associé au véhicule.
<?php
//...
class VehiculeController extends AbstractController
{
// ...
/**
* Ajout d'un nouveau véhicule
*/
#[Route('/vehicule/ajouter', name: 'vehicule_ajouter')]
public function ajouter(Request $request): Response
{
$vehicule = new Vehicule();
$form = $this->createForm(VehiculeType::class, $vehicule);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$this->repository->save($vehicule, true);
return $this->redirectToRoute('vehicule_lister');
}
return $this->render('vehicule/ajouter.html.twig', [
'form' => $form->createView(),
]);
}
}
?>
On crée le fichier src/Form/VehiculeType.php.
<?php
namespace App\Form;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\Form\Extension\Core\Type\DateTimeType;
use Symfony\Component\Form\Extension\Core\Type\DateType;
use Symfony\Component\Form\Extension\Core\Type\TextType;
use Symfony\Component\OptionsResolver\OptionsResolver;
use App\Entity\Vehicule;
use App\Entity\Conducteur;
use Symfony\Bridge\Doctrine\Form\Type\EntityType;
class VehiculeType extends AbstractType
{
public function buildForm
(FormBuilderInterface
$builder, array $options)
{
$builder
->add('ve_marque', TextType::class, [
'label' => 'Marque',
'required' => true,
])->add('ve_modele', TextType::class, [
'label' => 'Modèle',
'required' => true,
])->add('ve_conducteur', EntityType::class, [
'class' => Conducteur::class,
'choice_label' => 'CoNom',
'label' => 'Conducteur'
])->add('ve_date', DateType::class, [
'label' => 'Date d\'acquisition',
'widget' => 'single_text',
// prevents rendering it as type="date", to avoid HTML5 date pickers
'html5' => true,
//'help' => 'Utiliser jj-mm-aaaa',
//'data' => new \DateTime()
]);
}
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefaults([
'data_class' => Vehicule::class
]);
}
}
?>
Enfin, il faut générer le template TWIG lié à l'ajout d'un véhicule.
{# templates/vehicule/ajouter.html.twig #}
<style>
div#vehicule_ve_date_help {
margin-left: 150px;
background: lightgray;
}
</style>
<section>
<h2>Ajout d'un véhicule</h2>
{{ form_start(form) }}
{{ form_start(form) }}
{{ form_widget(form) }}
<button type="submit">Ajouter</button>
{{ form_end(form) }}
9.2. Modifier un véhicule
<?php
// ...
class VehiculeController extends AbstractController
{
// ...
/**
* Modifier un véhicule étant donné son id
*/
#[Route('/vehicule/modifier/{id}', name: 'vehicule_modifier')]
public function modifier(Request $request, int $id): Response
{
$vehicule = $this->repository->find($id);
if (!$vehicule) {
throw $this->createNotFoundException('Aucun véhicule avec l\'identifiant ' . $id . ' n\'a été trouvé');
}
$form = $this->createForm(VehiculeType::class, $vehicule);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$this->repository->save($vehicule, true);
return $this->redirectToRoute('vehicule_lister');
}
return $this->render('vehicule/modifier.html.twig', [
'form' => $form->createView(),
]);
}
}
?>
{# templates/vehicule/modifier.html.twig #}
<style>
div#vehicule_ve_date_help {
margin-left: 150px;
background: lightgray;
}
</style>
<section>
<h2>Modification d'un véhicule</h2>
{{ form_start(form) }}
{{ form_start(form) }}
{{ form_widget(form) }}
<button type="submit">Enregistrer</button>
{{ form_end(form) }}