Après avoir créé notre entité à l'affichage.
Symfony va nous simplifier la vie en initialisant les différents fichiers pour faire un crud (Created, Read, Update, Delete)
Nous allons supprimer ce que l'on a déjà fait, c'est à dire le Controller/ArticleController.php
et le Form/ArticleType.php
puis nous allons repasser par make pour faire notre crud
# php bin/console make:crud
Il va se faire à partir d'une entité existante, dans notre cas Article
Nous pouvons voir la création des différentes méthodes dans notre controller
namespace App\Controller;
use App\Entity\Article;
use App\Form\Article1Type;
use App\Repository\ArticleRepository;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
/**
* @Route("/article")
*/
class ArticleController extends AbstractController
{
/**
* @Route("/", name="article_index", methods={"GET"})
*/
public function index(ArticleRepository $articleRepository): Response
{
return $this->render('article/index.html.twig', [
'articles' => $articleRepository->findAll(),
]);
}
/**
* @Route("/new", name="article_new", methods={"GET","POST"})
*/
public function new(Request $request): Response
{
$article = new Article();
$form = $this->createForm(Article1Type::class, $article);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$entityManager = $this->getDoctrine()->getManager();
$entityManager->persist($article);
$entityManager->flush();
return $this->redirectToRoute('article_index');
}
return $this->render('article/new.html.twig', [
'article' => $article,
'form' => $form->createView(),
]);
}
/**
* @Route("/{id}", name="article_show", methods={"GET"})
*/
public function show(Article $article): Response
{
return $this->render('article/show.html.twig', [
'article' => $article,
]);
}
/**
* @Route("/{id}/edit", name="article_edit", methods={"GET","POST"})
*/
public function edit(Request $request, Article $article): Response
{
$form = $this->createForm(Article1Type::class, $article);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$this->getDoctrine()->getManager()->flush();
return $this->redirectToRoute('article_index', [
'id' => $article->getId(),
]);
}
return $this->render('article/edit.html.twig', [
'article' => $article,
'form' => $form->createView(),
]);
}
/**
* @Route("/{id}", name="article_delete", methods={"DELETE"})
*/
public function delete(Request $request, Article $article): Response
{
if ($this->isCsrfTokenValid('delete'.$article->getId(), $request->request->get('_token'))) {
$entityManager = $this->getDoctrine()->getManager();
$entityManager->remove($article);
$entityManager->flush();
}
return $this->redirectToRoute('article_index');
}
}
Après avoir créé nos fichiers, nous allons nous intéresser aux nouvelles fonctions qui sont: new
, edit
, delete
/**
* @Route("/new", name="article_new", methods={"GET","POST"})
*/
public function new(Request $request): Response
{
$article = new Article();
$form = $this->createForm(Article1Type::class, $article);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$entityManager = $this->getDoctrine()->getManager();
$entityManager->persist($article);
$entityManager->flush();
return $this->redirectToRoute('article_index');
}
return $this->render('article/new.html.twig', [
'article' => $article,
'form' => $form->createView(),
]);
}
Tout d'abord nous pouvons observer que nous lui injectons la class Request
, c'est un pilier de HttpFondation
tout comme Response
, je vous invite à voir la documentation https://symfony.com/doc/current/components/http_foundation.html.
Il va nous servir à récupérer nos $_GET
, $_POST
, $_SERVER
et bien plus encore.
Nous utilisons un le composant de symfony qui est le Form
. https://symfony.com/doc/current/forms.html