You are here

class RenderCheeseburgerMenuBlock in Cheeseburger Menu 8.4

Same name and namespace in other branches
  1. 8 src/Controller/renderCheeseburgerMenuBlock.php \Drupal\cheeseburger_menu\Controller\renderCheeseburgerMenuBlock
  2. 8.2 src/Controller/RenderCheeseburgerMenuBlock.php \Drupal\cheeseburger_menu\Controller\RenderCheeseburgerMenuBlock
  3. 8.3 src/Controller/RenderCheeseburgerMenuBlock.php \Drupal\cheeseburger_menu\Controller\RenderCheeseburgerMenuBlock

Class RenderCheeseburgerMenuBlock.

@package Drupal\cheeseburger_menu\Controller

Hierarchy

Expanded class hierarchy of RenderCheeseburgerMenuBlock

1 file declares its use of RenderCheeseburgerMenuBlock
CheeseburgerMenu.php in src/Plugin/Block/CheeseburgerMenu.php
Cheeseburger class extends BlockBase.
1 string reference to 'RenderCheeseburgerMenuBlock'
cheeseburger_menu.services.yml in ./cheeseburger_menu.services.yml
cheeseburger_menu.services.yml
1 service uses RenderCheeseburgerMenuBlock
render_cheeseburger_menu_lock.service in ./cheeseburger_menu.services.yml
Drupal\cheeseburger_menu\Controller\RenderCheeseburgerMenuBlock

File

src/Controller/RenderCheeseburgerMenuBlock.php, line 33
Controller used for rendering block.

Namespace

Drupal\cheeseburger_menu\Controller
View source
class RenderCheeseburgerMenuBlock extends ControllerBase {

  /**
   * The renderer.
   *
   * @var \Drupal\Core\Render\Renderer
   */
  protected $renderer;

  /**
   * The menu link tree.
   *
   * @var \Drupal\Core\Menu\MenuLinkTree
   */
  protected $menuTree;

  /**
   * The theme handler.
   *
   * @var \Drupal\Core\Extension\ThemeHandler
   */
  protected $themeHandler;

  /**
   * The breakpoint manager.
   *
   * @var \Drupal\breakpoint\BreakpointManager
   */
  protected $breakPointManager;

  /**
   * The route match interface.
   *
   * @var \Drupal\Core\Routing\RouteMatchInterface
   */
  protected $routeMatch;

  /**
   * Logger.
   *
   * @var \Drupal\Core\Logger\LoggerChannelFactory
   */
  protected $loggerChannelFactory;

  /**
   * Path matcher.
   *
   * @var \Drupal\Core\Path\PathMatcherInterface
   */
  protected $pathMatcher;

  /**
   * RenderCheeseburgerMenuBlock constructor.
   */
  public function __construct(Renderer $renderer, MenuLinkTree $menuLinkTree, ThemeHandler $themeHandler, BreakpointManager $breakpointManager, RouteMatchInterface $route_match, LoggerChannelFactoryInterface $loggerChannelFactory, PathMatcherInterface $path_matcher) {
    $this->renderer = $renderer;
    $this->menuTree = $menuLinkTree;
    $this->themeHandler = $themeHandler;
    $this->breakPointManager = $breakpointManager;
    $this->routeMatch = $route_match;
    $this->loggerChannelFactory = $loggerChannelFactory;
    $this->pathMatcher = $path_matcher;
  }

  /**
   * {@inheritdoc}
   */
  public static function create(ContainerInterface $container) {
    return new static($container
      ->get('renderer'), $container
      ->get('menu.link_tree'), $container
      ->get('theme_handler'), $container
      ->get('breakpoint.manager'), $container
      ->get('current_route_match'), $container
      ->get('logger.factory'), $container
      ->get('path.matcher'));
  }

  /**
   * {@inheritdoc}
   */
  public function content(Request $request) {
    $block_id = $request->request
      ->get('block_id');
    $current_route = $request->request
      ->get('current_route');
    $block = Block::load($block_id);
    if (!$block) {
      return new Response('<div>No such block</div>', 403);
    }
    $config = $block
      ->get('settings');
    $tree = $this
      ->renderTree($config, $current_route, $block
      ->getPlugin()
      ->getDerivativeId());
    $rendered_tree = $this->renderer
      ->render($tree);
    return new Response($rendered_tree);
  }

  /**
   * Render given tree.
   */
  public function renderTree($config, $current_route, $derivative_id = NULL) {
    $menus = [];
    foreach ([
      'menu' => 'Menu',
      'taxonomy_vocabulary' => 'Vocabulary',
    ] as $menu_key => $menu_label) {
      foreach ($config[$menu_key] as $id => $data) {
        switch ($data['title']) {
          case 'do_not_show':
            $title = '';
            $menu = $this
              ->entityTypeManager()
              ->getStorage($menu_key)
              ->load($id);
            $navigation_title = $menu
              ->label();
            break;
          case 'use_default':
            $menu = $this
              ->entityTypeManager()
              ->getStorage($menu_key)
              ->load($id);
            $navigation_title = $title = $menu
              ->label();
            break;
          case 'manual':
            $navigation_title = $title = $data['manual_title'];
            break;
        }
        $menus[] = [
          'tree' => $this
            ->{'get' . $menu_label . 'Tree'}($id, $config['depth']),
          'id' => $id,
          'menu_weight' => $data['menu_weight'],
          'title' => $title,
          'collapsible_title' => $data['collapsible_title'] ? '' : ' cheeseburger-menu__menu-list-item--expanded',
          'navigation_title' => $navigation_title,
        ];
      }
    }
    $additional_menus = [];

    // Cart show.
    if (array_key_exists('cart', $config) && $config['cart']['show']) {
      $additional_menus[] = [
        'id' => 'cart',
        'menu_weight' => $config['cart']['menu_weight'],
        'url' => '/cart',
        'title' => '',
        'navigation_title' => $this
          ->t('Cart'),
      ];
    }

    // Phone show.
    if (array_key_exists('phone', $config) && $config['phone']['show']) {
      if ($config['phone']['store'] == 0) {
        $additional_menus[] = [
          'id' => 'phone',
          'menu_weight' => $config['phone']['menu_weight'],
          'url' => 'tel:' . $config['phone']['manual_title'],
          'title' => '',
          'navigation_title' => $this
            ->t('Phone'),
        ];
      }
      else {
        if ($this
          ->moduleHandler()
          ->moduleExists('commerce_store')) {
          $store = Store::load($config['phone']['store']);
          if (!empty($store) && $store
            ->hasField('field_phone')) {
            if (!$store
              ->get('field_phone')
              ->isEmpty()) {
              $additional_menus[] = [
                'id' => 'phone',
                'menu_weight' => $config['phone']['menu_weight'],
                'url' => 'tel:' . $store
                  ->get('field_phone')->value,
                'title' => '',
                'navigation_title' => $this
                  ->t('Phone'),
              ];
            }
          }
        }
      }
    }
    if (array_key_exists('lang_switcher', $config) && $config['lang_switcher']['show']) {
      $languageTree = [];
      $route_name = $this->pathMatcher
        ->isFrontPage() ? '<front>' : '<current>';
      $links = $this
        ->languageManager()
        ->getLanguageSwitchLinks($derivative_id, Url::fromRoute($route_name));
      $languages = $this
        ->languageManager()
        ->getLanguages();
      foreach ($languages as $language) {
        if (isset($links->links[$language
          ->getId()])) {
          $languageTree[] = [
            'title' => $language
              ->getName(),
            'id' => $language
              ->getId(),
            'params' => [],
            'url' => $links->links[$language
              ->getId()]['url']
              ->setOption('language', $language)
              ->toString(),
            'children' => [],
            'entity_type_id' => 'lang',
          ];
        }
      }
      $additional_menus[] = [
        'id' => 'lang-switcher',
        'menu_weight' => $config['lang_switcher']['menu_weight'],
        'navigation_title' => $this
          ->t('Language switcher'),
        'title' => $this
          ->t('Language switcher'),
        'tree' => $languageTree,
      ];
    }
    $tree = array_merge($menus, $additional_menus);
    $this
      ->formTree($tree, $current_route, $config['active_state_enable']);
    foreach ($tree as &$tree_item) {
      $this
        ->moduleHandler()
        ->alter('cheeseburger_tree_item', $tree_item);
    }
    $this
      ->moduleHandler()
      ->alter('cheeseburger_tree', $tree);
    $render = [
      '#theme' => 'cheeseburger_menu',
      '#tree' => $tree,
      '#show_navigation' => $config['show_navigation'],
      '#parent_menu_as_link' => $config['parent_menu_as_link'],
    ];
    if ($config['active_state_enable']) {
      $render['#cache']['contexts'] = [
        'url',
      ];
    }
    return $render;
  }

  /**
   * Handles forming tree for menus.
   */
  public function formTree(&$tree, $current_url = FALSE, $active_state = TRUE) {
    $count_active = 0;
    if ($active_state) {
      foreach ($tree as $tree_key => $menu) {
        if (!array_key_exists('tree', $menu)) {
          continue;
        }
        $this
          ->activateMenuItem($tree[$tree_key]['tree'], $count_active, FALSE, $current_url);
      }
      if ($count_active === 0) {
        foreach ($tree as $tree_key => $menu) {
          if (!array_key_exists('tree', $menu)) {
            continue;
          }
          $this
            ->activateMenuItem($tree[$tree_key]['tree'], $count_active, TRUE, $current_url);
        }
      }
    }
    $this
      ->sortMenus($tree);
  }

  /**
   * If menu is active it activates it.
   */
  public function activateMenuItem(&$menu, &$count_active, $pos = FALSE, $url = FALSE) {
    if ($url === FALSE) {
      $url = Url::fromRouteMatch($this->routeMatch)
        ->toString();
    }
    foreach ($menu as $item_key => $menu_item) {
      if ($pos) {
        if (!empty($menu_item['url']) && strpos($url, $menu_item['url']) !== FALSE) {
          if ($url == '/' && $menu_item['url'] == '/' || $menu_item['url'] != '/') {
            $menu[$item_key]['active'] = 'active';
            $count_active++;
          }
        }
        else {
          $menu[$item_key]['active'] = '';
        }
      }
      else {
        if ($menu_item['url'] == $url) {
          $menu[$item_key]['active'] = 'active';
          $count_active++;
        }
        else {
          $menu[$item_key]['active'] = '';
        }
      }
      $this
        ->activateMenuItem($menu[$item_key]['children'], $count_active, $pos, $url);
    }
  }

  /**
   * Sorts menu based on menu_weight.
   */
  public function sortMenus(&$tree) {
    do {
      $change = FALSE;
      for ($i = 0; $i < count($tree) - 1; $i++) {
        if ($tree[$i]['menu_weight'] > $tree[$i + 1]['menu_weight']) {
          $temp = $tree[$i];
          $tree[$i] = $tree[$i + 1];
          $tree[$i + 1] = $temp;
          $change = TRUE;
        }
      }
    } while ($change === TRUE);
  }

  /**
   * Returning menu tree data.
   */
  public function getMenuTree($menu, $depth = NULL) {
    $menu_tree = $this->menuTree;
    $menu_tree_parameters = new MenuTreeParameters();
    $menu_tree_parameters
      ->onlyEnabledLinks();
    if (!is_null($depth) && is_numeric($depth) && $depth > 0) {
      $menu_tree_parameters
        ->setMaxDepth($depth);
    }
    $tree = $menu_tree
      ->load($menu, $menu_tree_parameters);
    $manipulators = [
      [
        'callable' => 'menu.default_tree_manipulators:checkAccess',
      ],
      [
        'callable' => 'menu.default_tree_manipulators:generateIndexAndSort',
      ],
    ];
    $tree = $menu_tree
      ->transform($tree, $manipulators);
    $menu_build = $menu_tree
      ->build($tree);
    $new_tree = [];
    if (array_key_exists('#items', $menu_build)) {
      if (is_array($menu_build['#items']) || is_object($menu_build['#items'])) {
        $new_tree = $this
          ->formatMenuArray($menu_build['#items']);
      }
    }
    return $new_tree;
  }

  /**
   * Formats menu.
   */
  public function formatMenuArray($items) {
    $new_tree = [];
    foreach ($items as $menu_data) {
      $temp_array = [];
      if ($menu_data['url']
        ->isRouted()) {
        $temp_array['title'] = $menu_data['title'];
        if (method_exists($menu_data['url'], 'getRouteParameters')) {
          $temp_array['params'] = $menu_data['url']
            ->getRouteParameters();
        }
        $url = Url::fromRoute($menu_data['url']
          ->getRouteName(), $temp_array['params']);
        $temp_array['url'] = $url
          ->toString();
        $options = $menu_data['url']
          ->getOptions();
        if (isset($options['fragment'])) {
          $temp_array['url'] .= '#' . $options['fragment'];
        }
        $temp_array['route_name'] = $menu_data['url']
          ->getRouteName();
        $temp_array['entity_type_id'] = 'menu_item';
      }
      elseif ($menu_data['url']
        ->isExternal()) {
        $temp_array['title'] = $menu_data['title'];
        $temp_array['url'] = $menu_data['url']
          ->toUriString();
        $options = $menu_data['url']
          ->getOptions();
        if (isset($options['fragment'])) {
          $temp_array['url'] .= '#' . $options['fragment'];
        }
        $temp_array['route_name'] = 'external_link';
        $temp_array['entity_type_id'] = 'menu_item';
      }
      elseif (isset($menu_data['title']) && isset($menu_data['url'])) {
        if (strpos($menu_data['url']
          ->toUriString(), 'base:') !== FALSE) {
          $temp_array['title'] = $menu_data['title'];
          $temp_array['url'] = $menu_data['url']
            ->setAbsolute(TRUE)
            ->toString();
          $temp_array['route_name'] = 'external_link';
          $temp_array['entity_type_id'] = 'menu_item';
        }
      }
      else {
        $this->loggerChannelFactory
          ->get('cheeseburger_menu')
          ->warning('Cheeseburger menu was not able to recognize menu link as external or internal. Menu link name: ' . $menu_data['title'] . '. Maybe go and save menu link again on current language.');
        continue;
      }

      // For easier identifying when altering.
      if (isset($menu_data['original_link'])) {
        if (method_exists($menu_data['original_link'], 'getPluginId')) {
          $temp_array['plugin_id'] = $menu_data['original_link']
            ->getPluginId();
        }
      }
      $temp_array['children'] = [];
      if (array_key_exists('below', $menu_data)) {
        $temp_array['children'] = $this
          ->formatMenuArray($menu_data['below']);
      }
      $new_tree[] = $temp_array;
    }
    return $new_tree;
  }

  /**
   * Formats vocabulary.
   */
  public function getVocabularyTree($vocabulary) {
    $vocabulary_tree = $this
      ->entityTypeManager()
      ->getStorage('taxonomy_term')
      ->loadTree($vocabulary);
    $tree = [];
    $parents = [];
    foreach ($vocabulary_tree as $term) {
      if (reset($term->parents) == 0) {
        $parents[] = $term;
      }
    }
    foreach ($parents as $term) {
      $tree[] = $this
        ->findVocabularyChild($this
        ->entityTypeManager()
        ->getStorage('taxonomy_term')
        ->load($term->tid));
    }
    return $tree;
  }

  /**
   * Searches for vocabulary child.
   */
  public function findVocabularyChild($term) {
    $icon = FALSE;
    if ($term
      ->hasField('field_icon')) {
      if (!empty($term
        ->get('field_icon')
        ->getValue())) {
        $icon = $term
          ->get('field_icon')->entity
          ->getFileUri();
        $icon = file_create_url($icon);
        $icon = file_url_transform_relative($icon);
      }
    }
    $langcode = $this
      ->languageManager()
      ->getCurrentLanguage(LanguageInterface::TYPE_CONTENT)
      ->getId();
    $translation_languages = $term
      ->getTranslationLanguages();
    if (array_key_exists($langcode, $translation_languages)) {
      $translation = $term
        ->getTranslation($langcode);
    }
    else {
      $translation = $term;
    }
    $term_tree = [
      'id' => $translation
        ->get('tid')->value,
      'title' => $translation
        ->getName(),
      'url' => $translation
        ->url(),
      'entity_type_id' => $translation
        ->getEntityTypeId(),
      'icon' => $icon,
      'children' => [],
    ];
    $ancestors = $this
      ->entityTypeManager()
      ->getStorage('taxonomy_term')
      ->loadChildren($term
      ->get('tid')->value);
    foreach ($ancestors as $ancestor) {
      $term_tree['children'][] = $this
        ->findVocabularyChild($ancestor);
    }
    return $term_tree;
  }

  /**
   * Get all menu link names.
   */
  public function getAllMenuLinkNames() {
    $all_menus = Menu::loadMultiple();
    $menus = [];
    foreach ($all_menus as $id => $menu) {
      $menus[$id] = $menu
        ->label();
    }
    asort($menus);
    return $menus;
  }

  /**
   * Get all taxonomy term names.
   */
  public function getAllTaxonomyTermNames() {
    if (!$this
      ->moduleHandler()
      ->moduleExists('taxonomy')) {
      return [];
    }
    $all_taxonomies = $this
      ->entityTypeManager()
      ->getStorage('taxonomy_vocabulary')
      ->loadMultiple();
    $menus = [];
    foreach ($all_taxonomies as $id => $menu) {
      $menus[$id] = $menu
        ->label();
    }
    asort($menus);
    return $menus;
  }

  /**
   * Returning breakpoint data for default theme.
   */
  public function returnBreakpointsForDefaultTheme() {

    /** @var \Drupal\Core\Extension\ThemeHandler $theme_handler */
    $theme_handler = $this->themeHandler;

    /** @var \Drupal\breakpoint\BreakpointManager $breakpoint_manager */
    $breakpoint_manager = $this->breakPointManager;
    $groups = $breakpoint_manager
      ->getGroups();
    $list = [];
    foreach ($groups as $group) {
      if (is_object($group)) {
        $group = $group
          ->getUntranslatedString();
      }
      $breakpoints = $breakpoint_manager
        ->getBreakpointsByGroup($group);
      foreach ($breakpoints as $key => $breakpoint) {
        if ($breakpoint
          ->getProvider() == $theme_handler
          ->getDefault()) {
          $list[$key]['mediaQuery'] = $breakpoint
            ->getMediaQuery();
          $list[$key]['label'] = $breakpoint
            ->getLabel();
          if (is_object($list[$key]['label'])) {
            $list[$key]['label'] = $list[$key]['label']
              ->__toString();
          }
        }
      }
    }
    return $list;
  }

}

Members

Namesort descending Modifiers Type Description Overrides
ControllerBase::$configFactory protected property The configuration factory.
ControllerBase::$currentUser protected property The current user service. 1
ControllerBase::$entityFormBuilder protected property The entity form builder.
ControllerBase::$entityManager protected property The entity manager.
ControllerBase::$entityTypeManager protected property The entity type manager.
ControllerBase::$formBuilder protected property The form builder. 2
ControllerBase::$keyValue protected property The key-value storage. 1
ControllerBase::$languageManager protected property The language manager. 1
ControllerBase::$moduleHandler protected property The module handler. 2
ControllerBase::$stateService protected property The state service.
ControllerBase::cache protected function Returns the requested cache bin.
ControllerBase::config protected function Retrieves a configuration object.
ControllerBase::container private function Returns the service container.
ControllerBase::currentUser protected function Returns the current user. 1
ControllerBase::entityFormBuilder protected function Retrieves the entity form builder.
ControllerBase::entityManager Deprecated protected function Retrieves the entity manager service.
ControllerBase::entityTypeManager protected function Retrieves the entity type manager.
ControllerBase::formBuilder protected function Returns the form builder service. 2
ControllerBase::keyValue protected function Returns a key/value storage collection. 1
ControllerBase::languageManager protected function Returns the language manager service. 1
ControllerBase::moduleHandler protected function Returns the module handler. 2
ControllerBase::redirect protected function Returns a redirect response object for the specified route. Overrides UrlGeneratorTrait::redirect
ControllerBase::state protected function Returns the state storage service.
LinkGeneratorTrait::$linkGenerator protected property The link generator. 1
LinkGeneratorTrait::getLinkGenerator Deprecated protected function Returns the link generator.
LinkGeneratorTrait::l Deprecated protected function Renders a link to a route given a route name and its parameters.
LinkGeneratorTrait::setLinkGenerator Deprecated public function Sets the link generator service.
LoggerChannelTrait::$loggerFactory protected property The logger channel factory service.
LoggerChannelTrait::getLogger protected function Gets the logger for a specific channel.
LoggerChannelTrait::setLoggerFactory public function Injects the logger channel factory.
MessengerTrait::$messenger protected property The messenger. 29
MessengerTrait::messenger public function Gets the messenger. 29
MessengerTrait::setMessenger public function Sets the messenger.
RedirectDestinationTrait::$redirectDestination protected property The redirect destination service. 1
RedirectDestinationTrait::getDestinationArray protected function Prepares a 'destination' URL query parameter for use with \Drupal\Core\Url.
RedirectDestinationTrait::getRedirectDestination protected function Returns the redirect destination service.
RedirectDestinationTrait::setRedirectDestination public function Sets the redirect destination service.
RenderCheeseburgerMenuBlock::$breakPointManager protected property The breakpoint manager.
RenderCheeseburgerMenuBlock::$loggerChannelFactory protected property Logger.
RenderCheeseburgerMenuBlock::$menuTree protected property The menu link tree.
RenderCheeseburgerMenuBlock::$pathMatcher protected property Path matcher.
RenderCheeseburgerMenuBlock::$renderer protected property The renderer.
RenderCheeseburgerMenuBlock::$routeMatch protected property The route match interface.
RenderCheeseburgerMenuBlock::$themeHandler protected property The theme handler.
RenderCheeseburgerMenuBlock::activateMenuItem public function If menu is active it activates it.
RenderCheeseburgerMenuBlock::content public function
RenderCheeseburgerMenuBlock::create public static function Instantiates a new instance of this class. Overrides ControllerBase::create
RenderCheeseburgerMenuBlock::findVocabularyChild public function Searches for vocabulary child.
RenderCheeseburgerMenuBlock::formatMenuArray public function Formats menu.
RenderCheeseburgerMenuBlock::formTree public function Handles forming tree for menus.
RenderCheeseburgerMenuBlock::getAllMenuLinkNames public function Get all menu link names.
RenderCheeseburgerMenuBlock::getAllTaxonomyTermNames public function Get all taxonomy term names.
RenderCheeseburgerMenuBlock::getMenuTree public function Returning menu tree data.
RenderCheeseburgerMenuBlock::getVocabularyTree public function Formats vocabulary.
RenderCheeseburgerMenuBlock::renderTree public function Render given tree.
RenderCheeseburgerMenuBlock::returnBreakpointsForDefaultTheme public function Returning breakpoint data for default theme.
RenderCheeseburgerMenuBlock::sortMenus public function Sorts menu based on menu_weight.
RenderCheeseburgerMenuBlock::__construct public function RenderCheeseburgerMenuBlock constructor.
StringTranslationTrait::$stringTranslation protected property The string translation service. 1
StringTranslationTrait::formatPlural protected function Formats a string containing a count of items.
StringTranslationTrait::getNumberOfPlurals protected function Returns the number of plurals supported by a given language.
StringTranslationTrait::getStringTranslation protected function Gets the string translation service.
StringTranslationTrait::setStringTranslation public function Sets the string translation service to use. 2
StringTranslationTrait::t protected function Translates a string to the current language or to a given language.
UrlGeneratorTrait::$urlGenerator protected property The url generator.
UrlGeneratorTrait::getUrlGenerator Deprecated protected function Returns the URL generator service.
UrlGeneratorTrait::setUrlGenerator Deprecated public function Sets the URL generator service.
UrlGeneratorTrait::url Deprecated protected function Generates a URL or path for a specific route based on the given parameters.