diff --git a/framework/widgets/Menu.php b/framework/widgets/Menu.php index 32d8dd284c..19a76e8239 100644 --- a/framework/widgets/Menu.php +++ b/framework/widgets/Menu.php @@ -60,7 +60,8 @@ class Menu extends Widget * otherwise, [[labelTemplate]] will be used. * - visible: boolean, optional, whether this menu item is visible. Defaults to true. * - items: array, optional, specifies the sub-menu items. Its format is the same as the parent items. - * - active: boolean, optional, whether this menu item is in active state (currently selected). + * - active: boolean or closure that returns boolean, optional, whether this menu item is in active state (currently selected). + * When using a closure, its signature should be `function ($item, $hasActiveChild, $widget)`. * If a menu item is active, its CSS class will be appended with [[activeCssClass]]. * If this option is not set, the menu item will be set active automatically when the current request * is triggered by `url`. For more details, please refer to [[isItemActive()]]. @@ -285,6 +286,8 @@ class Menu extends Widget } else { $items[$i]['active'] = false; } + } elseif ($item['active'] instanceof \Closure) { + $active = $items[$i]['active'] = call_user_func($item['active'], $item, $hasActiveChild, $this); } elseif ($item['active']) { $active = true; }