tourze/easy-admin-menu-bundle

EasyAdmin 菜单管理组件,提供灵活的菜单配置和管理功能

Installs: 13 595

Dependents: 107

Suggesters: 0

Security: 0

Stars: 0

Watchers: 1

Forks: 0

Open Issues: 0

Type:symfony-bundle

pkg:composer/tourze/easy-admin-menu-bundle

1.0.0 2025-10-31 15:41 UTC

This package is auto-updated.

Last update: 2025-11-01 19:15:45 UTC


README

English | 中文

PHP Version Latest Version License Build Status Quality Score Total Downloads Code Coverage

A Symfony bundle for simplified menu management in EasyAdmin backend systems. This bundle provides easy-to-use tools for organizing menus and generating admin links.

Table of Contents

Features

  • Simplified menu organization and management
  • Attribute-based menu provider registration with #[MenuProvider]
  • Easy link generation for EasyAdmin CRUD pages
  • Entity class extraction from URLs
  • Integration with KnpMenuBundle for menu rendering
  • Automatic service configuration and DI

Requirements

  • PHP 8.1 or higher
  • Symfony 6.4 or higher
  • EasyAdmin Bundle 4.x
  • KnpMenuBundle 3.7 or higher

Installation

Install the bundle using Composer:

composer require tourze/easy-admin-menu-bundle

The bundle will be automatically registered if you're using Symfony Flex. Otherwise, add it manually to config/bundles.php:

// config/bundles.php
return [
    // ...
    Tourze\EasyAdminMenuBundle\EasyAdminMenuBundle::class => ['all' => true],
];

Configuration

The bundle works out of the box with default configuration. No additional configuration is required for basic usage.

Custom Menu Factory

You can customize the menu factory by defining your own service:

# config/services.yaml
services:
    easy-admin-menu.factory:
        class: Knp\Menu\MenuFactory
        # Add your custom configuration here

Quick Start

1. Create a Menu Provider

Create a menu provider class and mark it with the #[MenuProvider] attribute:

<?php

namespace App\Menu;

use Knp\Menu\ItemInterface;
use Tourze\EasyAdminMenuBundle\Attribute\MenuProvider;
use Tourze\EasyAdminMenuBundle\Service\MenuProviderInterface;

#[MenuProvider]
class MainMenuProvider implements MenuProviderInterface
{
    public function __invoke(ItemInterface $item): void
    {
        $item->addChild('Dashboard', [
            'route' => 'admin_dashboard'
        ]);
        
        $item->addChild('Users', [
            'route' => 'admin',
            'routeParameters' => [
                'crudAction' => 'index',
                'crudControllerFqcn' => UserCrudController::class
            ]
        ]);
    }
}

2. Generate Admin Links

Use the LinkGeneratorInterface to generate EasyAdmin CRUD links:

<?php

namespace App\Controller;

use App\Entity\User;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Tourze\EasyAdminMenuBundle\Service\LinkGeneratorInterface;

class DashboardController extends AbstractController
{
    public function __construct(
        private readonly LinkGeneratorInterface $linkGenerator,
    ) {
    }
    
    public function index()
    {
        // Generate list page URL for User entity
        $userListUrl = $this->linkGenerator->getCurdListPage(User::class);
        
        // Extract entity class from URL
        $someUrl = 'https://example.com/admin?crudControllerFqcn=App\\Controller\\Admin\\UserCrudController';
        $entityClass = $this->linkGenerator->extractEntityFqcn($someUrl);
        // Result: App\Entity\User (if UserCrudController has getEntityFqcn() method)
        
        return $this->render('dashboard/index.html.twig', [
            'userListUrl' => $userListUrl,
        ]);
    }
}

3. Collect and Render Menus

The bundle automatically collects all menu providers and makes them available through the MenuCollectorInterface:

<?php

namespace App\Controller;

use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Tourze\EasyAdminMenuBundle\Service\MenuCollectorInterface;

class MenuController extends AbstractController
{
    public function __construct(
        private readonly MenuCollectorInterface $menuCollector,
    ) {
    }
    
    public function mainMenu()
    {
        $menu = $this->menuCollector->mainMenu($this->getUser());
        
        return $this->render('menu/main.html.twig', [
            'menu' => $menu,
        ]);
    }
}

Advanced Usage

Multiple Menu Providers

You can create multiple menu providers for different sections:

#[MenuProvider]
class AdminMenuProvider implements MenuProviderInterface
{
    public function __invoke(ItemInterface $item): void
    {
        $item->addChild('Admin Section', ['uri' => '#'])
            ->addChild('Users', ['route' => 'admin_users'])
            ->addChild('Settings', ['route' => 'admin_settings']);
    }
}

#[MenuProvider]
class ContentMenuProvider implements MenuProviderInterface
{
    public function __invoke(ItemInterface $item): void
    {
        $item->addChild('Content', ['uri' => '#'])
            ->addChild('Articles', ['route' => 'admin_articles'])
            ->addChild('Categories', ['route' => 'admin_categories']);
    }
}

API Reference

LinkGeneratorInterface

  • getCurdListPage(string $entityClass): string - Generate CRUD list page URL for an entity
  • extractEntityFqcn(string $url): ?string - Extract entity FQCN from admin URL

MenuProviderInterface

  • __invoke(ItemInterface $item): void - Add menu items to the root menu

MenuCollectorInterface

  • mainMenu(?UserInterface $user = null): ItemInterface - Collect and return the main menu

Testing

Run the test suite:

./vendor/bin/phpunit packages/easy-admin-menu-bundle/tests

Contributing

Please see CONTRIBUTING.md for details on how to contribute to this project.

License

The MIT License (MIT). Please see License File for more information.