The CRUD Bundle provides a quick and easy way to generate Create, Read, Update, and Delete actions for any given entity in your Symfony projects. This bundle is designed to simplify entity management by automating CRUD operations while remaining flexible and easy to customize.
Additionally, it integrates list generation through the jeandanyel/list-bundle, offering a customizable solution for displaying and managing your data.
This bundle is actively under development, with upcoming features such as role management and event handling. Contributions to the project are always welcome 🥳.
To use this bundle, simply create an Entity, its corresponding Repository, a FormType, a ListType and a Controller that extends the abstract class AbstractCrudController
.
Use the CrudController
attribute to specify the Entity, FormType, and ListType classes as parameters.
namespace App\Controller;
use App\Entity\Article;
use App\Form\ArticleType;
use App\List\ArticleListType;
use Jeandanyel\CrudBundle\Attribute\CrudController;
use Jeandanyel\CrudBundle\Controller\AbstractCrudController;
#[CrudController(entityClass: Article::class, formTypeClass: ArticleType::class, listTypeClass: ArticleListType::class)]
class ArticleController extends AbstractCrudController
{
}
This configuration will automatically set up CRUD actions for the Article
entity.
The routes for the CRUD actions are automatically generated by the bundle using the RouteLoader
. This means you don't have to manually configure the routes for each entity.
The bundle provides default templates used for the list
, create
, and update
actions.
If these templates do not meet your needs, you can create your own custom templates by following the naming convention based on your entity and the desired action. Your custom template will take priority over the default ones.
The format to follow for your custom templates is templates/{entity}/{action}.html.twig
.
For example, if you want to create a custom template for the Article
entity and the update
action, the Twig file should be created at templates/article/update.html.twig
.
Method | Route name | Route | Template |
---|---|---|---|
AbstractCrudController::list |
crud_{entity}_list | /{entity}/list | @JeandanyelCrud/crud/list.html.twig |
AbstractCrudController::create |
crud_{entity}_create | /{entity}/create | @JeandanyelCrud/crud/create.html.twig |
AbstractCrudController::update |
crud_{entity}_update | /{entity}/update/{id} | @JeandanyelCrud/crud/update.html.twig |
AbstractCrudController::delete |
crud_{entity}_delete | /{entity}/delete/{id} | - |
The CRUD includes events that allow developers to hook into specific CRUD actions, such as saving an entity. These events are dispatched during CRUD operations and can be used to perform additional logic or validations.
Event Name | Description |
---|---|
EntityBeforeSaveEvent |
Triggered before an entity is saved to the database. |
EntityAfterSaveEvent |
Triggered after an entity has been saved to the database. |
The following example demonstrates how to use EntityBeforeSaveEvent
to perform operations before an entity is saved:
namespace App\EventListener;
use App\Entity\Article;
use Jeandanyel\CrudBundle\Event\EntityBeforeSaveEvent;
use Symfony\Component\EventDispatcher\Attribute\AsEventListener;
#[AsEventListener(EntityBeforeSaveEvent::class)]
class ArticleCrudBeforeSaveListener
{
public function __invoke(EntityBeforeSaveEvent $event)
{
$entity = $event->getEntity();
if ($entity instanceof Article) {
// Perform operations before saving the Article entity.
}
}
}