MenuItemChecker.php 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. <?php
  2. /**
  3. * Copyright © Magento, Inc. All rights reserved.
  4. * See COPYING.txt for license details.
  5. */
  6. namespace Magento\Backend\Block;
  7. use Magento\Backend\Model\Menu\Item;
  8. /**
  9. * Class MenuItemChecker
  10. */
  11. class MenuItemChecker
  12. {
  13. /**
  14. * Check whether given menu item is currently selected.
  15. *
  16. * It is used in backend menu to highlight active menu item.
  17. *
  18. * @param Item|false $activeItem Can be false if menu item is inaccessible
  19. * but was triggered directly using controller. It is a legacy code behaviour.
  20. * @param Item $item
  21. * @param int $level
  22. * @return bool
  23. */
  24. public function isItemActive($activeItem, Item $item, $level)
  25. {
  26. $output = false;
  27. if ($level == 0
  28. && $activeItem instanceof \Magento\Backend\Model\Menu\Item
  29. && $this->isActiveItemEqualOrChild($activeItem, $item)
  30. ) {
  31. $output = true;
  32. }
  33. return $output;
  34. }
  35. /**
  36. * @param Item $activeItem,
  37. * @param Item $item
  38. * @return bool
  39. */
  40. private function isActiveItemEqualOrChild($activeItem, $item)
  41. {
  42. return ($activeItem->getId() == $item->getId())
  43. || ($item->getChildren()->get($activeItem->getId()) !== null);
  44. }
  45. }