11. Ajouter, modifier un Equipement
11.1. Ajouter un équipement
Dans le cas de l'ajout d'un équipement :
<?php
// src/Controller/EquipementController.php
namespace App\Controller;
use App\Entity\Equipement;
use App\Form\EquipementType;
use App\Repository\EquipementRepository;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
use Doctrine\ORM\EntityManagerInterface;
class EquipementController extends AbstractController
{
// ...
/**
* Créer un nouvel équipement en affichant un formulaire
* de saisie des informations
*/
#[Route('/equipement/ajouter', name: 'equipement_ajouter')]
public function ajouter(Request $request): Response
{
$equipement = new Equipement();
$form = $this->createForm(EquipementType::class, $equipement);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$this->repository->save($equipement, true);
return $this->redirectToRoute('equipement_lister');
}
return $this->render('equipement/ajouter.html.twig', [
'form' => $form->createView(),
]);
}
// ...
}
?>
On crée le fichier src/Form/EquipementType.php.
<?php
namespace App\Form;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolver;
use Symfony\Component\Form\Extension\Core\Type\TextType;
use Symfony\Component\Form\Extension\Core\Type\NumberType;
use App\Entity\Equipement;
class EquipementType extends AbstractType
{
public function buildForm
(FormBuilderInterface
$builder, array $options)
{
$builder
->add('eq_libelle', TextType::class, [
'label' => 'Libellé',
'required' => true,
])->add('eq_prix', NumberType::class, [
'label' => 'Prix',
'required' => true,
]);
}
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefaults([
'data_class' => Equipement::class
]);
}
}
?>
Enfin, il faut générer le template TWIG lié à l'ajout d'un équipement.
{# templates/equipement/ajouter.html.twig #}
<section>
<h2>Ajout d'un équipement</h2>
{{ form_start(form) }}
{{ form_row(form.eq_libelle) }}
{{ form_row(form.eq_prix) }}
<button type="submit">Ajouter</button>
{{ form_end(form) }}
11.2. Modifier un équipement
<?php
// src/Controller/EquipementController.php
namespace App\Controller;
use App\Entity\Equipement;
use App\Form\EquipementType;
use App\Repository\EquipementRepository;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
use Doctrine\ORM\EntityManagerInterface;
class EquipementController extends AbstractController
{
// ...
/**
* Modifier un équipement étant donné son id
*/
#[Route('/equipement/modifier/{id}', name: 'equipement_modifier')]
public function modifier(Request $request, int $id): Response
{
$equipement = $this->repository->find($id);
if (!$equipement) {
throw $this->createNotFoundException('Aucun équipement avec l\'identifiant ' . $id . ' n\'a été trouvé');
}
$form = $this->createForm(EquipementType::class, $equipement);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$this->repository->save($equipement, true);
return $this->redirectToRoute('equipement_lister');
}
return $this->render('equipement/modifier.html.twig', [
'form' => $form->createView(),
]);
}
}
{# templates/equipement/modifier.html.twig #}
<section>
<h2>Modification d'un équipement</h2>
{{ form_start(form) }}
{{ form_start(form) }}
{{ form_widget(form) }}
<button type="submit">Enregistrer</button>
{{ form_end(form) }}