Drupal → Программно вывести термины словаря в виде дерева с подсчётом количества материалов

28.04.2012

Ранее писал, как программно вывести термины словаря с подсчётом количества материалов и как программно вывести термины словаря в виде дерева. Теперь очередь объединить эти два способа и программно вывести термины словаря в виде дерева с подсчётом количества материалов:

Термины словаря в виде дерева

Код:

/**
 * Return rendered taxonomy tree
 */
function mymodule_taxonomy_tree_output($vid) {
  $terms = db_query("
    SELECT td.tid, td.name, th.parent, (
      SELECT COUNT(*)
      FROM {taxonomy_index} ti
      LEFT JOIN {node} n ON ti.nid = n.nid
      WHERE ti.tid = td.tid AND n.status = 1
    ) node_count
    FROM {taxonomy_term_data} td
    INNER JOIN {taxonomy_term_hierarchy} th ON th.tid = td.tid
    WHERE vid = :vid
    ORDER BY weight
  ", array(':vid' => $vid))->fetchAll();
  
  return theme('item_list', array('items' => mymodule_taxonomy_tree_format_terms($terms)));
}
 
/**
 * Format terms in tree.
 */
function mymodule_taxonomy_tree_format_terms($terms, $parent = 0, &$node_count = 0) {
  $items = array();
  $node_count = 0;
 
  foreach ($terms as $term) {
    if ($term->parent == $parent) {
      $children = mymodule_taxonomy_tree_format_terms($terms, $term->tid, $childs_node_count);
      $node_count_current = $term->node_count + $childs_node_count;
      $node_count += $node_count_current;
      $items[] = array(
        'data' => l($term->name, 'catalog/' . $term->tid) . ' (' . $node_count_current . ')',
        'children' => $children,
      );
    }
  }
 
  return $items;
}

Использование:

echo mymodule_taxonomy_tree_output(1);

Для вывода плоского списка можно воспользоваться Views — Как с помощью Views 3 вывести список терминов с количеством помеченных ими нод.

Update 06.02.2013: добавил подсчёт количества нод у дочерних терминов.

Написанное актуально для
Drupal 7
Похожие записи

Комментарии

Гость
05.09.2012, 17:33

А есть возможность при открытой ноде как-то передавать active-trail термину в списке?

zviryatko
07.02.2013, 00:14

А может все таки о кешах упомянешь, а то твой блог читаем много новичков... ;)

Гость
05.03.2013, 01:40

А как сделать, чтобы нулевые термины не отображались?
Спасибо!

Андрей
31.03.2013, 02:35

Добрый вечер!
Подскажите, можно ли зная tid дочернего термина, вывести имя термина родителя?

Раньше использовал модуль Hierarchical Select, который хранил оба параметра в поле.
Теперь же перешел на shs, он лучше дружит с views, но хранит в поле только значение дочернего термина, отсюда и такая проблема.

Гость
18.02.2014, 16:40

По умолчанию выводится простой список с вложенными списками дочерних терминов.
Можно ли вывести такое дерево сеткой, т.е. обернуть родителя и влож. список дивом?

Alexander
19.01.2015, 16:20

А для i18n-дерева код будет сильно отличаться?

Добавить комментарий