notebrainslab/filament-menu-manager

A powerful Filament v4 & v5 plugin for managing menus with multiple locations, drag & drop reordering, Eloquent model support, auto-save, and dark theme.

Maintainers

Package info

github.com/notebrainslab/filament-menu-manager

pkg:composer/notebrainslab/filament-menu-manager

Statistics

Installs: 306

Dependents: 0

Suggesters: 0

Stars: 0

Open Issues: 0

1.0.0 2026-02-23 06:50 UTC

This package is auto-updated.

Last update: 2026-02-23 06:51:17 UTC


README

Latest Version on Packagist License

A powerful Filament v4 & v5 plugin for managing navigation menus with:

  • Multiple Locations — Primary, Footer, Sidebar, or any custom location
  • Drag & Drop Reordering — Powered by SortableJS with nested support
  • Button Reordering — Up ↑ Down ↓ Indent → Outdent ← for accessibility
  • Built-in Panels — Custom Links panel and Eloquent Model Sources panel
  • Eloquent Model Compatible — Add Posts, Pages, or any model as menu items
  • Auto Save — Debounced auto-save on every change (configurable)
  • Dark Theme — Full dark mode support via CSS custom properties

Requirements

Dependency Version
PHP ^8.2
Laravel ^12.0
Filament ^4.0 | ^5.0
Livewire ^3.0 | ^4.0

Installation

1. Install via Composer

composer require notebrainslab/filament-menu-manager

2. Publish and run migrations

php artisan filament-menu-manager:install
# or manually:
php artisan vendor:publish --tag="filament-menu-manager-migrations"
php artisan migrate

3. Register the plugin in your Panel Provider

use NoteBrainsLab\FilamentMenuManager\FilamentMenuManagerPlugin;

public function panel(Panel $panel): Panel
{
    return $panel
        ->plugin(
            FilamentMenuManagerPlugin::make()
                ->locations([
                    'primary' => 'Primary',
                    'footer'  => 'Footer',
                ])
        );
}

Configuration

Publish the config file (Optional):

php artisan vendor:publish --tag="filament-menu-manager-config"

Publish the resource files (Optional):

php artisan vendor:publish --tag="filament-menu-manager-views"

Plugin API (Fluent)

FilamentMenuManagerPlugin::make()
    ->locations(['primary' => 'Primary', 'footer' => 'Footer'])
    ->modelSources([\App\Models\Post::class, \App\Models\Page::class])
    ->navigationGroup('Content')
    ->navigationIcon('heroicon-o-bars-3')
    ->navigationSort(10)
    ->navigationLabel('Menus');

Eloquent Model Sources

To make an Eloquent model selectable in the Models panel, add the trait:

use NoteBrainsLab\FilamentMenuManager\Concerns\HasMenuItems;

class Post extends Model
{
    use HasMenuItems;

    // Optional: override the defaults
    public function getMenuLabel(): string  { return $this->title; }
    public function getMenuUrl(): string    { return route('posts.show', $this); }
    public function getMenuTarget(): string { return '_self'; }
    public function getMenuIcon(): ?string  { return 'heroicon-o-document'; }
}

Then register the model in the plugin:

FilamentMenuManagerPlugin::make()
    ->modelSources([\App\Models\Post::class])

Render Menus in Blade

@php
    $manager = app(\NoteBrainsLab\FilamentMenuManager\MenuManager::class);
    $menus   = $manager->menusForLocation('primary');
    $menu    = $menus->first();
    $tree    = $menu?->getTree() ?? [];
@endphp

@foreach($tree as $item)
    <a href="{{ $item['url'] }}" target="{{ $item['target'] }}">{{ $item['title'] }}</a>
    @if(!empty($item['children']))
        {{-- render children --}}
    @endif
@endforeach

Testing

composer test

Changelog

See CHANGELOG.md.

License

MIT License. See LICENSE.