This router loads a category matching the given request uri to categories slugs. It utilizes the cmf routing package heavily and registers the provided listing router as a chained cmf router through the service tag "router".
$ composer require bestit/commercetools-listing-slug-router-bundle
#!yaml
best_it_ct_listing_slug_router:
# Which controller-method should be used on a positive match?
controller: 'BestIt\Frontend\ListingBundle\Controller\ListingController::indexAction'
# Which priority has this router in the cmf chaining?
priority: 0
# Service id for the repositry loading categories with their slug. You should fulfill the provided interface.
repository: ~
# Which route name is used for a positive match?
route: best_it_frontend_listing_listing_index
Just use the standard symfony path
function in twig for generating routes. It requires the route name as name and the param slug
with the seo url.
Additional arguments will be passed as query.
Example:
{# /apple #}
{{ path('best_it_frontend_listing_listing_index', {'slug' => 'apple') }}
{# /apple?page=1&view=list #}
{{ path('best_it_frontend_listing_listing_index', {'page' => 1, slug' => 'apple', 'view' => 'list') }}
- The lib folder could be moved to a separate repo.