4. Breadcrumb
The SonataSeoBundle
let’s you create your own breadcrumbs based on your different website modules (news, products catalog…). The bundle uses KnpMenuBundle to generate the breadcrumb. Please refer to related documentation.
4.1. Create your own breadcrumb
First, you need to create a BlockService to handle your breadcrumbs.
You can extend Sonata\SeoBundle\Block\Breadcrumb\BaseBreadcrumbMenuBlockService
:
namespace App\Block;
use Knp\Menu\ItemInterface;
use Sonata\BlockBundle\Block\BlockContextInterface;
use Sonata\SeoBundle\Block\Breadcrumb\BaseBreadcrumbMenuBlockService;
class MyCustomBreadcrumbBlockService extends BaseBreadcrumbMenuBlockService
{
public function handleContext(string $context): bool
{
return 'app.block.breadcrumb' === $context;
}
protected function getMenu(BlockContextInterface $blockContext): ItemInterface
{
$menu = $this->getMenu($blockContext);
$menu->addChild('my_awesome_action');
return $menu;
}
}
<!-- config/services.xml -->
<service id="app.bundle.block.breadcrumb" class="App\Block\MyCustomBreadcrumbBlockService">
<argument type="service" id="twig"/>
<argument type="service" id="knp_menu.factory"/>
<tag name="sonata.block"/>
<tag name="sonata.breadcrumb"/>
</service>
You can also override the breadcrumb order by defining a priority
:
<!-- config/services.xml -->
<service id="app.bundle.block.breadcrumb" class="App\Block\MyCustomBreadcrumbBlockService">
<argument type="service" id="twig"/>
<argument type="service" id="knp_menu.factory"/>
<tag name="sonata.block"/>
<tag name="sonata.breadcrumb" priority="-127"/>
</service>
And to render the breadcrumb, just use this Twig helper :
{{ sonata_block_render_event('breadcrumb', {
'context': 'my_custom_context',
'current_uri': app.request.requestUri
}) }}
You can also use the shortcut to render the current breadcrumb :
{{ sonata_seo_breadcrumb() }}