MillwrightMenuBundle extends base functionality of KnpMenuBundle and adds configuration, route, translation and security context support. Each link on the site is a part of configured menu container, which supports translation, role and acl-based security, route params.
Basic Docs
-
It uses
JMSSecurityExtraBundle
annotations for configuring menu items visibility: role-based and acl-based security context support -
Menu options consist of two parts:
items
describes each menu item: labels, route|uri, translate, roletree
describes each menu container as hierarchy of menu items
-
items
can be configured from config file and annotations in controller class and actions -
We can juggle any configured menu items in containers
-
Menu twig helper supports route parameters, needed for changing menu items visibility on demand, based on acl
-
Menu options merged from multiple sources:
tree
section of config,item
section,@Menu
annotations in action method,@Menu
annotation in controller class
Require the bundle through composer
composer require zerkalica/millwright-menu-bundle dev-master
To start using the bundle, register it in your Kernel:
<?php
// app/AppKernel.php
public function registerBundles()
{
$bundles = array(
// ...
new Knp\Bundle\MenuBundle\KnpMenuBundle(),
new Millwright\MenuBundle\MillwrightMenuBundle(),
new Millwright\ConfigurationBundle\MillwrightConfigurationBundle(),
);
// ...
)
# app/config/config.yml
imports:
- { resource: menu.yml }
...
knp_menu:
twig: # use "twig: false" to disable the Twig extension and the TwigRenderer
template: MillwrightMenuBundle:Default:knp_menu.html.twig
templating: false # if true, enables the helper for PHP templates
default_renderer: twig # The renderer to use, list is also available by default
Any bundle can provide own menu or modify existing through millwright_menu.menu_options
tagged service:
<service id="millwright_menu.options" class="%millwright_configuration.options.class%">
<tag name="millwright_menu.menu_options" order="100"/>
<argument type="collection">
<argument key="items">%millwright_menu.items%</argument>
<argument key="tree">%millwright_menu.tree%</argument>
<argument key="renderers">%millwright_menu.renderers%</argument>
</argument>
</service>
order
attribute - order of provided menu.
First parameter is the collection of menu options.
By default one menu provided by MillwrightMenuBundle and configured in millwright_menu
section of the application config.
# app/config/menu.yml
millwright_menu:
renderers:
navigation: #menu type id
renderer: null # custom renderer
rendererOptions:
template: MillwrightMenuBundle:Default:knp_menu.html.twig
items: #menu items
homepage: #menu name, used for route name, if it not set in options
translateDomain: 'MillwrightMenuBundle'
roles: IS_AUTHENTICATED_ANONYMOUSLY
fos_user_registration_register:
translateDomain: 'MillwrightMenuBundle'
roles: ROLE_USER
fos_user_profile_show:
translateDomain: 'MillwrightMenuBundle'
showNonAuthorized: true #show link in menu for non-authorized user
roles: ROLE_USER
fos_user_change_password:
translateDomain: 'FOSUserBundle'
roles: ROLE_USER
label: 'change_password.submit'
test:
translateDomain: 'FOSUserBundle'
label: 'change_password.submit'
uri: 'http://www.google.com'
tree: #menu containers
user_admin: #user administration links container
type: navigation # menu type id
children:
fos_user_profile_show: ~
fos_user_change_password: ~
main: #main container
type: navigation # menu type id
children:
homepage: ~
test: ~
fos_user_registration_register: ~
fos_user_profile_show:
children:
fos_user_change_password: ~
Items section can be configured from annotations:
# src/Application/Millwright/CoreBundle/Controller/DefaultController.php
...
/**
* @Menu(translateDomain="MillwrightMenuBundle")
*/
class DefaultController extends Controller {
/**
* @Route("/user/{user}", name="showUser")
* @Template()
* @Secure(roles="ROLE_ADMIN")
* @SecureParam(name="user", permissions="EDIT")
* @Menu(showNonAuthorized=true, label="User edit")
*/
public function userAction(User $user) {
return array('content' => 'hello');
}
}
millwright_menu_render
supports additional route parameters, the other options are equivalent to knp_menu_render.
{{ millwright_menu_render('main', routeParams, options, renderer) }}
{{ millwright_menu_render('main') }}
We have a user collection, each user has acl permissions
{% for user in users %}
{{ millwright_menu_render('main', {user: user.id}) }}
{% endfor %}
# app/config/menu.yml
millwright_menu:
renderers:
<menu type>:
renderer: null # custom renderer
rendererOptions:
...
items:
<key>:
<item options>
...
tree:
<menu_name>:
type: <menu type>
children:
<items hierarchy>
items
section:
<key>
- used as default value for name, route and labeluri
- uri string, if no route parameter setlabel
- label text or translation string templatename
- name of menu item, used as default for routeattributes
- knp menu item optionslinkAttributes
- knp menu item optionschildrenAttributes
- knp menu item optionslabelAttributes
- knp menu item optionsdisplay
- knp menu item optionsdisplayChildren
- knp menu item optionstranslateDomain
- translation domaintranslateParameters
- translation parameterssecureParams
- copy of@SecureParam
JMSSecurityExtraBundle
annotationsroles
- copy of@Secure
JMSSecurityExtraBundle
annotationroute
- route name for uri generation, if not set and uri not set - loads from keyrouteAbsolute
- true for absolute url generationshowNonAuthorized
- show for non-authorized usersshowAsText
- if authorized and no access to item, show item as texticon
- icon class for menu item
tree
section:
type
- menu container typechildren
- submenu items
renderers
section:
<menu type>
- menu container typerenderer
- custom rendererrendererOptions
- options pass to menu renderer: template, etc
@Menu
annotation supports: label, translateDomain, translateParameters, name, showNonAuthorized, showAsText options.
//@todo sandbox
# src/Application/Millwright/CoreBundle/Controller/ArticleController.php
...
/**
* @Menu(translateDomain="MillwrightMenuBundle")
*/
class ArticleController extends Controller
{
/**
* @Route("/articles", name="article_index")
* @Template()
* @Secure(roles="ROLE_USER")
*/
public function indexAction() {
//
}
/**
* @Route("/article/create", name="article_create")
* @Template()
* @Secure(roles="ROLE_USER")
* @SecureParam(name="article", permissions="EDIT")
*/
public function createAction() {
//
}
/**
* @Route("/article/{article}", name="article_view")
* @Secure(roles="ROLE_USER")
* @SecureParam(name="article", permissions="VIEW")
* @Template()
*/
public function viewAction(Article $article) {
return array('article' => $article);
}
/**
* @Route("/article/{article}/edit", name="article_edit")
* @Template()
* @Secure(roles="ROLE_USER")
* @SecureParam(name="article", permissions="EDIT")
*/
public function editAction(Article $article) {
//
}
/**
* @Route("/article/{article}/delete", name="article_delete")
* @Template()
* @Secure(roles="ROLE_USER")
* @SecureParam(name="article", permissions="DELETE")
*/
public function deleteAction(Article $article) {
//
}
}
Menu file:
# app/config/menu.yml
millwright_menu:
tree:
article_index_actions:
type: menu
children:
article_create: ~
article_actions:
type: actions
children:
article_view: ~
article_edit: ~
article_delete: ~