Download the PHP package alshenetsky/easyadmin-breadcrumbs without Composer
On this page you can find all versions of the php package alshenetsky/easyadmin-breadcrumbs. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download alshenetsky/easyadmin-breadcrumbs
More information about alshenetsky/easyadmin-breadcrumbs
Files in alshenetsky/easyadmin-breadcrumbs
Package easyadmin-breadcrumbs
Short Description A bundle that allows you to add breadcrumbs to EasyAdmin
License MIT
Informations about the package easyadmin-breadcrumbs
easyadmin-breadcrumbs
A bundle that allows you to add breadcrumbs to EasyAdmin
Installation
This bundle requires EasyAdmin 4.5 or higher, PHP 8.0 or higher and Symfony 5.4 or higher. Run the following command to install it in your application:
Documentation
Concept
EasyAdmin, as we know, does not have functionality for placing breadcrumbs on admin pages. Navigation in the admin area is based on the GET request data, packed into a class named AdminContext. Transitions between controller methods are implemented by generating the URL to the desired CRUD and, if necessary, applying filters to it. So it becomes difficult to build a breadcrumb tree, because you need to somehow store the hierarchy of controllers without losing filters and controllers' connections to each other.
This bundle allows you to recreate such a hierarchy. You create a Breadcrumb class, which in turn creates a reference to the parent Breadcrumb, and so on.
Creating breadcrumb hierarchy
Such a class must implement the BreadcrumbInterface. The easiest way to do it is to inherit the AbstractBreadcrumb class, which already implements this interface and contains useful methods, reducing the number of boilerplate:
Every Breadcrumb class will match against current url by getType()
and getEntityFqdn()
methods. So the breadcrumb from this example will appear on the UserController::index
page.
Method getType()
returns BreadcrumbType
enum which is perfectly matched with Crud::PAGE_* constants in EasyAdmin bundle.
Additionally, you can implement supports()
method if you need more complex logic whether to display breadcrumb on the page:
Let's go deeper into the navigation tree. Where there is a list of users, there will most likely be a user edit. Let's create a second level breadcrumb:
You may see some previously unfamiliar methods.
- The first one is
getParent()
. It forms a link between the child and parent breadcrumb. - The second one is
gather()
. It gathers the data from the current query (only if the given breadcrumb is defined as current) and stores it in the BreadcrumbData class, which serves as a data store. - The third one is
configure()
. It receivesBreadcrumbData
object (the one we generated in thegather()
method). Based on this data we can configure the name and the URL for this breadcrumb. ThesetEntityId()
call here is an auxiliary method call that allows us to add anentityId
key to the URL generator and use the default URL generation logic for the rest. But we're free to completely override this mechanism by callingsetUrl()
instead:
That's it. Now we have two levels of breadcrumb navigation:
Users -> Editing user John Doe
Now go deeper. Assume that on the user's edit page we have a link to the user's orders, which are displayed in the OrdersController. Assume that on the user's edit page we have a link to the user's orders, which are displayed in the OrdersController. Most likely you'll make a custom Action on the user's edit page and create a link for it that leads to OrdersController::index and sets a filter for it ('user' => ['comparison' => '=', 'value' => $user->getId()]]
). It is easy to breadcrumb the next level of nesting:
Users -> Editing user John Doe -> User orders
The last method you should know about is provide()
. It also receives BreadcrumbData which is gathered in gather()
, but returns another BreadcrumbData
class to populate parent breadcrumb with it. You SHOULD provide very same keys that your parent breadcrumb needs.
You see, being on a different page (in a different context) invokes gather()
method only on the current breadcrumb, and the parent breadcrumbs get theirs BreadcrumbData
via the provide()
method up the chain. This is how the breadcrumb hierarchy is formed. You can form as many nesting levels as you wish.
Summary:
- use
configure()
method to set url and name of the breadcrumb fromBreadcrumbData
- use
gather()
method to gatherBreadcrumbData
from current context (only for the CURRENT breadcrumb) - use
provide()
method to sendBreadcrumbData
to parent breadcrumb with very same keys that parent breadcrumb needs.
Handling exceptions
By using EasyAdmin filters when displaying a list of child items, you may find that when you reset the filters, you end up outside the breadcrumb structure. To avoid encountering 500 errors, throw a BreadcrumbNotApplicableException
in any of the configure
, gather
, or provide
methods. This error will be handled correctly and the breadcrumbs will not be rendered.
Placing breadcrumbs on the page:
- Override EadyAdmin
layout.html
twig template by creating filetemplates/bundles/EasyAdminBundle/layout.html.twig
- Place
{{ breadcrumbs() }}
there, incontent_header_wrapper
block for example:
Contribution
Contributions are very welcome!
TODO list:
- add tests
- add static analysis tool
- configure CI
License
This software is published under the MIT License
All versions of easyadmin-breadcrumbs with dependencies
easycorp/easyadmin-bundle Version ^4.5
symfony/dependency-injection Version ^5.4|^6.0|^7.0
symfony/http-kernel Version ^5.4|^6.0|^7.0
symfony/config Version ^5.4|^6.0|^7.0