novius / laravel-nova-menu
A Nova resource tool to manage menus in your application.
Installs: 12 615
Dependents: 0
Suggesters: 0
Security: 0
Stars: 8
Watchers: 6
Forks: 8
Open Issues: 0
Requires
- php: ^8.1
- illuminate/support: ^9.0 | ^10.0 | ^11.0
- laravel/nova: ^4.0
- novius/laravel-linkable: ^1.0
- novius/laravel-nova-order-nestedset-field: ^4.0
- spatie/laravel-sluggable: ^3.4.0
Requires (Dev)
- laravel/pint: ^1.7
- orchestra/testbench: ^9.2
This package is auto-updated.
Last update: 2024-12-13 16:30:22 UTC
README
A Nova tool to manage menus.
Requirements
- PHP >= 8.1
- Laravel Nova >= 4.0
- Laravel Framework >= 9.0 | >= 10.0 | >= 11.0
NOTE: These instructions are for Laravel >= 9.0 and Laravel Nova 4.0. If you are using prior version, please see the previous version's docs.
Installation
composer require novius/laravel-nova-menu
Then, launch migrations
php artisan migrate
Configuration
Some options that you can override are available.
php artisan vendor:publish --provider="Novius\LaravelNovaMenu\LaravelNovaMenuServiceProvider" --tag="config"
Edit default templates
Run:
php artisan vendor:publish --provider="Novius\LaravelNovaMenu\LaravelNovaMenuServiceProvider" --tag="views"
Usage
Blade directive
You can display menu with :
<x-laravel-nova-menu::menu menu="slug-of-menu" />
You can also display menu by passing the model instance :
<x-laravel-nova-menu::menu :menu="Menu::find(1)" />
By default a fallback to app()->getLocale() is activated.
If you want force a specific slug with no fallback you can call :
<x-laravel-nova-menu::menu menu="slug-of-menu" :localeFallback="false" />
If you want to use a specific view you can call :
<x-laravel-nova-menu::menu menu="slug-of-menu" view="partial/menu" />
Override views
You can override views with :
php artisan vendor:publish --provider="Novius\LaravelNovaMenu\LaravelNovaMenuServiceProvider" --tag="views"
Manage internal link possibilities
Laravel Nova Menu uses Laravel Linkable to manage linkable routes and models. Please read the documentation.
Customize tree passed to the view
<?php namespace App\Providers; use Novius\LaravelNovaMenu\LaravelNovaMenuService; class AppServiceProvider extends ServiceProvider { // ... public function boot() { /** * @var LaravelNovaMenuService $menu */ $menu = $this->app->get('laravel-nova-menu'); $menu->setTreeUsing(function(Menu $menu, array $tree) { // ... your actions on tree return $tree; }); } }
Customize tree building
<?php namespace App\Providers; use Novius\LaravelNovaMenu\LaravelNovaMenuService; class AppServiceProvider extends ServiceProvider { // ... public function boot() { /** * @var LaravelNovaMenuService $menu */ $menu = $this->app->get('laravel-nova-menu'); $menu->setBuildTreeUsing(function(Collection $items) { // ... your actions to build tree as an array return $tree; }); } }
Lint
Run php-cs with:
composer run-script lint
Contributing
Contributions are welcome! Leave an issue on Github, or create a Pull Request.
Licence
This package is under GNU Affero General Public License v3 or (at your option) any later version.