spatie / laravel-menu by spatie

Html menu generator for Laravel
1,706,156
880
27
Package Data
Maintainer Username: spatie
Maintainer Contact: sebastiandedeyne@gmail.com (Sebastian De Deyne)
Package Create Date: 2016-02-22
Package Last Update: 2024-02-27
Home Page: https://freek.dev/414-a-modern-package-to-generate-html-menus
Language: PHP
License: MIT
Last Refreshed: 2024-03-28 03:11:36
Package Statistics
Total Downloads: 1,706,156
Monthly Downloads: 43,622
Daily Downloads: 1,551
Total Stars: 880
Total Watchers: 27
Total Forks: 83
Total Open Issues: 0

Html Menu Generator for Laravel

Latest Version on Packagist Software License Build Status Quality Score StyleCI Total Downloads

This is the Laravel version of our menu package adds some extras like convenience methods for generating URLs and macros.

Documentation is available at https://docs.spatie.be/menu.

Upgrading from version 1? There's a guide for that!

Menu::macro('main', function () {
    return Menu::new()
        ->action('HomeController@index', 'Home')
        ->action('AboutController@index', 'About')
        ->action('ContactController@index', 'Contact')
        ->setActiveFromRequest();
});
<nav class="navigation">
    {!! Menu::main() !!}
</nav>

Spatie is a webdesign agency based in Antwerp, Belgium. You'll find an overview of all our open source projects on our website.

Install

You can install the package via composer:

$ composer require spatie/laravel-menu

Usage

Documentation is available at https://docs.spatie.be/menu.

Upgrading to 2.0

Upgrading to 2.0 should be pretty painless for most use cases.

  • Link builder methods have been renamed and now have a to prefix: Link::toAction, Link::toRoute and Link::toUrl.
  • See spatie/menu's upgrade guide for more.

New features...

  • Added: Added a View item implementation to use blade views as menu items

Changelog

Please see CHANGELOG for more information what has changed recently.

Testing

$ phpunit

Contributing

Please see CONTRIBUTING for details.

Security

If you discover any security related issues, please email freek@spatie.be instead of using the issue tracker.

Postcardware

You're free to use this package, but if it makes it to your production environment we highly appreciate you sending us a postcard from your hometown, mentioning which of our package(s) you are using.

Our address is: Spatie, Samberstraat 69D, 2060 Antwerp, Belgium.

We publish all received postcards on our company website.

Credits

Support us

Spatie is a webdesign agency based in Antwerp, Belgium. You'll find an overview of all our open source projects on our website.

Does your business depend on our contributions? Reach out and support us on Patreon. All pledges will be dedicated to allocating workforce on maintenance and new awesome stuff.

License

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