PHPackages                             agence-adeliom/sylius-easy-crud-plugin - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Admin Panels](/categories/admin)
4. /
5. agence-adeliom/sylius-easy-crud-plugin

ActiveSylius-plugin[Admin Panels](/categories/admin)

agence-adeliom/sylius-easy-crud-plugin
======================================

Easy CRUD plugin for Sylius.

v2.0.9(2mo ago)33.0k—8.3%[1 issues](https://github.com/agence-adeliom/sylius-easy-crud-plugin/issues)1MITPHPPHP ^8.2 || ^8.3 || ^8.4 || ^8.5CI passing

Since Jun 16Pushed 2mo ago1 watchersCompare

[ Source](https://github.com/agence-adeliom/sylius-easy-crud-plugin)[ Packagist](https://packagist.org/packages/agence-adeliom/sylius-easy-crud-plugin)[ RSS](/packages/agence-adeliom-sylius-easy-crud-plugin/feed)WikiDiscussions 2.x Synced 1mo ago

READMEChangelog (10)Dependencies (68)Versions (57)Used By (1)

Sylius Easy CRUD Plugin
=======================

[](#sylius-easy-crud-plugin)

[![Easy crud banner](docs/screens/easy_crud.jpg "Easy crud banner")](docs/screens/easy_crud.jpg)

[Overview](#overview) • [Installation](#installation) • [Quick Start](#quick-start) • [Documentation](#documentation)

---

Overview
--------

[](#overview)

#### **Sylius Easy CRUD Plugin** is an abstraction layer that helps building CRUD interfaces in Sylius e-commerce.

[](#sylius-easy-crud-plugin-is-an-abstraction-layer-that-helps-building-crud-interfaces-in-sylius-e-commerce)

🧩 Define your entire CRUD interface (list, create, edit, show, delete) in a single `configureFields()` method on a `App\Admin\ResourceAdmin` class based on Sylius resources — similar to EasyAdminBundle, but integrated with Sylius!

🚀 With this `Admin class` this plugin generates automatically all CRUD interfaces for you: `Grid`, `Creation/Edition forms`, `Show page`, and preconfigured CRUD `Actions`. It also provides a rich set of `form field types` that helps you build forms with minimal code.

✨ Transform Symfony entities / Sylius resources into fully functional admin interfaces in minutes!

[![Post CRUD example](docs/screens/easy_crud_posts.png "Post CRUD example")](docs/screens/easy_crud_posts.png)

```
class PostAdmin extends AbstractAdmin
{
    /**
     * @return iterable
     */
    public function configureFields(string $pageName, ?string $context = null): iterable
    {

        yield TabField::new('tab1', 'Tab 1');

        yield ColumnField::new('tab1_left')
            ->setSize(ColumnSizeEnum::WIDE_8_OF_12);

        yield TranslationField::new('translations')
            ->addField(
                Field::new('name')
                ->setDisabled(false)
                ->setRequired(true)
            )
            ->onlyOnForms();

        yield ColumnField::new('tab1_right')
            ->setSize(ColumnSizeEnum::WIDE_4_OF_12);

        yield IconField::new('icon')
            ->onlyOnForms();

        yield CheckboxField::new('enabled');

        ...

    }

    /**
     * @return iterable
     */
    public function configureFilters(): iterable
    {
        yield BooleanFilter::create('enabled')
            ->setLabel('Enabled');
    }

    public function configureActions(string $pageName): Actions
    {
        return parent::configureActions($pageName)
            ->remove(Crud::PAGE_EDIT, Action::DELETE);
    }
}
```

### What Makes It Easy?

[](#what-makes-it-easy)

- **🚀 Rapid Development**: Generate complete CRUD interfaces in minutes with Symfony Maker commands
- **🎨 Rich Field Types**: 18+ specialized fields (Image, WYSIWYG, CodeEditor, Slug, Sortable Collections, and more)
- **🌍 i18n Ready**: Built-in translatable content mapped to Sylius Translation system
- **🧩 Highly Extensible**: Custom field configurators, actions, and form types
- **😎 Centralized configuration**: CRUD configuration in a single Admin class per resource

### Why we built this plugin

[](#why-we-built-this-plugin)

In our previous Symfony projects we were familiar with EasyAdminBundle and developed [several bundles based on it](https://github.com/search?q=org%3Aagence-adeliom+easy-&type=repositories). When we migrated to Sylius, we looked for a fast and efficient way to reuse those bundles, so we tried to integrate the missing parts:

- The EasyAdmin abstraction layer to allow building forms, lists and show pages in a single Admin class.
- Our previous CMS features.

We have used this bundle in production on several projects and decided to share it with the community.

It does not fully comply (yet) with last Sylius guidelines, so please use this plugin with caution.

### A duo: Easy CRUD + Happy CMS

[](#a-duo-easy-crud--happy-cms)

Alongside this plugin, we migrated our other EasyAdmin-based bundles — which provided content management (CMS) features — into a separate plugin called [Happy CMS](https://github.com/agence-adeliom/sylius-happy-cms-plugin). It is an alternative for building CMS features in Sylius.

---

Installation
------------

[](#installation)

### 1. Install via Composer

[](#1-install-via-composer)

```
composer require agence-adeliom/sylius-easy-crud-plugin
composer require --dev symfony/maker-bundle
```

### 2. Enable the Bundle

[](#2-enable-the-bundle)

Add the plugin to `config/bundles.php`:

```
