agence-adeliom/sylius-easy-crud-plugin

Easy CRUD plugin for Sylius.

Installs: 0

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 0

Forks: 0

Type:sylius-plugin

pkg:composer/agence-adeliom/sylius-easy-crud-plugin


README

Sylius Easy CRUD Plugin

Easy crud banner

OverviewInstallationQuick StartDocumentation

Overview

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

class PostAdmin extends AbstractAdmin
{
    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');
    
    ...
}

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

In our previous Symfony projects we were familiar with EasyAdminBundle and developed several bundles based on it. 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

Alongside this plugin, we migrated our other EasyAdmin-based bundles — which provided content management (CMS) features — into a separate plugin called Happy CMS. It is an alternative for building CMS features in Sylius.

Installation

1. Install via Composer

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

2. Enable the Bundle

Add the plugin to config/bundles.php:

<?php

return [
    // ...
    Adeliom\SyliusEasyCrudPlugin\SyliusEasyCrudPlugin::class => ['all' => true],
   
    Symfony\Bundle\MakerBundle\MakerBundle::class => ['dev' => true, 'test' => true],
];

3. Import Configuration

In config/packages/_sylius.yaml:

imports:
    - { resource: "@SyliusEasyCrudPlugin/config/config.yaml" }

4. Import Routes

In config/routes.yaml:

sylius_easy_crud:
    resource: "@SyliusEasyCrudPlugin/config/routes.yaml"

5. Install Assets

php bin/console assets:install

Quick Start

Step 1: Generate an Entity

Create a new entity with translation support:

php bin/console make:easy-crud:create-entity Post
php bin/console doc:mig:diff
php bin/console doc:mig:mig

This generates:

  • src/Entity/Post.php
  • src/Entity/PostTranslation.php
  • src/Repository/PostRepository.php

Step 2: Generate the CRUD

Create a complete CRUD interface for your entity:

php bin/console make:easy-crud:create-crud Post

This generates:

  • src/Admin/PostAdmin.php - CRUD configuration class
  • Updates config/routes.yaml - Adds admin routes
  • Updates config/packages/sylius_resources.yaml - Registers Sylius resource
  • Updates src/Menu/AdminMenuListener.php - Adds menu entry

Step 3: Configure Your CRUD

Edit src/Admin/PostAdmin.php: Configure your fields in the configureFields() or your filters with configureFilters() method.

Discover available fields

Step 4: Access Your CRUD

Navigate to your Sylius admin panel and find your new "Posts" menu entry. You now have a fully functional CRUD interface!

Documentation

📚 User Guides

If this plugin helped you, please consider giving it a ⭐ on GitHub!

Made with ❤️ by Adeliom

License PHP Version Sylius Version