You are here

MenuHierarchy.php in Views (for Drupal 7) 8.3

File

lib/Drupal/views/Plugin/views/sort/MenuHierarchy.php
View source
<?php

/**
 * @file
 * Definition of Drupal\views\Plugin\views\sort\MenuHierarchy.
 */
namespace Drupal\views\Plugin\views\sort;

use Drupal\Core\Annotation\Plugin;

/**
 * Sort in menu hierarchy order.
 *
 * Given a field name of 'p' this produces an ORDER BY on p1, p2, ..., p9;
 * and optionally injects multiple joins to {menu_links} to sort by weight
 * and title as well.
 *
 * This is only really useful for the {menu_links} table.
 *
 * @Plugin(
 *   id = "menu_hierarchy"
 * )
 */
class MenuHierarchy extends SortPluginBase {
  protected function defineOptions() {
    $options = parent::defineOptions();
    $options['sort_within_level'] = array(
      'default' => FALSE,
    );
    return $options;
  }
  public function buildOptionsForm(&$form, &$form_state) {
    parent::buildOptionsForm($form, $form_state);
    $form['sort_within_level'] = array(
      '#type' => 'checkbox',
      '#title' => t('Sort within each hierarchy level'),
      '#description' => t('Enable this to sort the items within each level of the hierarchy by weight and title.  Warning: this may produce a slow query.'),
      '#default_value' => $this->options['sort_within_level'],
    );
  }
  public function query() {
    $this
      ->ensureMyTable();
    $max_depth = isset($this->definition['max depth']) ? $this->definition['max depth'] : MENU_MAX_DEPTH;
    for ($i = 1; $i <= $max_depth; ++$i) {
      if ($this->options['sort_within_level']) {
        $definition = array(
          'table' => 'menu_links',
          'field' => 'mlid',
          'left_table' => $this->tableAlias,
          'left_field' => $this->field . $i,
        );
        $join = drupal_container()
          ->get('plugin.manager.views.join')
          ->createInstance('standard', $definition);
        $menu_links = $this->query
          ->add_table('menu_links', NULL, $join);
        $this->query
          ->add_orderby($menu_links, 'weight', $this->options['order']);
        $this->query
          ->add_orderby($menu_links, 'link_title', $this->options['order']);
      }

      // We need this even when also sorting by weight and title, to make sure
      // that children of two parents with the same weight and title are
      // correctly separated.
      $this->query
        ->add_orderby($this->tableAlias, $this->field . $i, $this->options['order']);
    }
  }

}

Classes

Namesort descending Description
MenuHierarchy Sort in menu hierarchy order.