Menu manager used for build hierarchical menu. This is automatically look of user role and permision then return menus that he has access.
use mdm\admin\components\MenuHelper;
use yii\bootstrap\Nav;
echo Nav::widget([
'items' => MenuHelper::getAssignedMenu(Yii::$app->user->id)
]);
Return of mdm\admin\components\MenuHelper::getAssignedMenu()
has default format like:
[
[
'label' => $menu['name'],
'url' => [$menu['route']],
'items' => [
[
'label' => $menu['name'],
'url' => [$menu['route']]
],
....
]
],
[
'label' => $menu['name'],
'url' => [$menu['route']],
'items' => [
[
'label' => $menu['name'],
'url' => [$menu['route']]
]
]
],
....
]
where $menu
variable correspond with a record of table menu
. You can customize
return format of mdm\admin\components\MenuHelper::getAssignedMenu()
by provide a callback to this method.
The callback must have format function($menu){}
. E.g:
You can add html options attribute to Your menu, for example "title". When You create a menu, in field data (textarea) fill this :
return ['title'=>'Title of Your Link Here'];
and then in Your view:
$callback = function($menu){
$data = eval($menu['data']);
return [
'label' => $menu['name'],
'url' => [$menu['route']],
'options' => $data,
'items' => $menu['children']
];
}
$items = MenuHelper::getAssignedMenu(Yii::$app->user->id, null, $callback);
Default result is get from cache
. If you want to force regenerate, provide boolean true
as forth parameter.
You can modify callback function for advanced usage.
Second parameter of mdm\admin\components\MenuHelper::getAssignedMenu()
used to get menu on it's own hierarchy.
E.g. Your menu structure:
- Side Menu
- Menu 1
- Menu 1.1
- Menu 1.2
- Menu 1.3
- Menu 2
- Menu 2.1
- Menu 2.2
- Menu 2.3
- Menu 1
- Top Menu
- Top Menu 1
- Top Menu 1.1
- Top Menu 1.2
- Top Menu 1.3
- Top Menu 2
- Top Menu 3
- Top Menu 4
- Top Menu 1
You can get 'Side Menu' chldren by calling
$items = MenuHelper::getAssignedMenu(Yii::$app->user->id, $sideMenuId);
It will result in
- Menu 1
- Menu 1.1
- Menu 1.2
- Menu 1.3
- Menu 2
- Menu 2.1
- Menu 2.2
- Menu 2.3
If you have NavBar
menu items and want to filtering according user login. You can use Helper class
use mdm\admin\components\Helper;
$menuItems = [
['label' => 'Home', 'url' => ['/site/index']],
['label' => 'About', 'url' => ['/site/about']],
['label' => 'Contact', 'url' => ['/site/contact']],
['label' => 'Login', 'url' => ['/user/login']],
[
'label' => 'Logout (' . \Yii::$app->user->identity->username . ')',
'url' => ['/user/logout'],
'linkOptions' => ['data-method' => 'post']
],
['label' => 'App', 'items' => [
['label' => 'New Sales', 'url' => ['/sales/pos']],
['label' => 'New Purchase', 'url' => ['/purchase/create']],
['label' => 'GR', 'url' => ['/movement/create', 'type' => 'receive']],
['label' => 'GI', 'url' => ['/movement/create', 'type' => 'issue']],
]]
];
$menuItems = Helper::filter($menuItems);
echo Nav::widget([
'options' => ['class' => 'navbar-nav navbar-right'],
'items' => $menuItems,
]);
You can also check for individual route.
use mdm\admin\components\Helper;
if(Helper::checkRoute('delete')){
echo Html::a(Yii::t('rbac-admin', 'Delete'), ['delete', 'id' => $model->name], [
'class' => 'btn btn-danger',
'data-confirm' => Yii::t('rbac-admin', 'Are you sure to delete this item?'),
'data-method' => 'post',
]);
}
When you use GridView
, you can also filtering button visibility.
use mdm\admin\components\Helper;
'columns' => [
...
[
'class' => 'yii\grid\ActionColumn',
'template' => Helper::filterActionColumn('{view}{delete}{posting}'),
]
]
It will check authorization access of button and show or hide it.