Вывод всех меток в виде дерева для сайта на MaxSite CMS

Вывод всех меток в виде дерева для сайта на MaxSite CMS

27 февраля 2011 г. Sadovnik Просмотров: 288 RSS
MaxSite CMS практика ,

В предыдущей статье на эту тему Вывод меток сайта деревом я пытался придумать алгоритм, отображающий метки сайта в виде дерева на основе связей между метками по записям.

Но есть другой вариант.

Можно использовать для группировки меток группировку статей, которым присвоены метки, по категориям. Например: http://filsadovnik.ru/all_tags.

Итак, мы получаем все категории и затем, для каждой категории, находим множество всех меток, которые присвоены статьям, принадлежащим данной категории.

Есть разные варианты отображения. Например, метки, отображаемые у родительской категории уже могут не отображаться у дочерних; можно использовать древообразное представление или нет; и т. д.

Получить древообразный массив категорий мы можем при помощи функции mso_cat_array.

Вид полученного массива будет следующий.

  1.  [15] = Array(
  2.  [category_id] = 15
  3.  [category_id_parent] = 0
  4.  [category_type] = page
  5.  [category_name] = Тестовая рубрика
  6.  [category_desc] =
  7.  [category_slug] = test
  8.  [category_menu_order] = 0
  9.  [pages_count] = 2
  10.  [childs] =Array (
  11.   [16] = Array ( [category_id] =16 )
  12.   [17] = Array ( [category_id] =17 )
Для осуществления вывода мы придумаем рекуррентную функцию tags2categoryout. Этой функции скармливается массив, описанный выше, полученный в результате вызова функции mso_cat_array; а в результате получаем список категорий и меток, полученных по связи через страницы.

Функция получится следующая.

  1.  function tags2categoryout($all = array() , $par = array())
  2.  {
  3.   $out = '';
  4.   foreach ($all as $a)
  5.   {
  6.   $CI = & get_instance();
  7.   $CI->db->select('category.category_name , meta_value, COUNT(meta_value) AS meta_count');
  8.   $CI->db->where('category.category_type', 'page');
  9.   $CI->db->where('category.category_id', $a['category_id']);
  10.   $CI->db->where( array ( 'meta_key' => 'tags', 'meta_table' => 'page' ) );
  11.   $CI->db->join('page', 'page.page_id = meta.meta_id_obj' );
  12.   $CI->db->group_by('meta_value');
  13.   $CI->db->join('cat2obj', 'cat2obj.page_id = page.page_id');
  14.   $CI->db->join('category', 'cat2obj.category_id = category.category_id');
  15.   //$CI->db->join('page', 'page.page_id = cat2obj.page_id', 'left');
  16.   if ($query = $CI->db->get('meta')) $result = $query->result_array(); // здесь все
  17.   else $result = array();
  18.   $out .= '<H2><a href ="' . getinfo('site_url') . 'category/' . $a['category_slug'] . '">' . $a['category_name'] . '</a></H2>';
  19.   $i=false;
  20.   foreach ($result as $tag)
  21.   {
  22.   if ($i) $out .= ' , '; else $i=true;
  23.   $out .= '<a href ="' . getinfo('site_url') . 'tag/' . $tag['meta_value'] . '">' . $tag['meta_value'] . '<sup>' . $tag['meta_count'] . '</sup></a>' ;
  24.   }
  25.   if (isset ($a['childs']) and $a['childs']) $out .= tags2categoryout($a['childs'] , $par);
  26.   }
  27.   return $out;
  28.  }

Поскольку, функция получения дерева рубрик ресурсоемкая - не забываем о кешировании.

Файл, готовый для использования находится в архиве.

Заливаем этот файл в templates/my_template/type/ и наблюдаем результат по адресу, соответствующему имени файла, например: http://filsadovnik.ru/all_tags.

Похожие страницы
Комментариев: 1
  1. Сергей (профиль) 10 января 2012 в 22:09:44 (ссылка)

    Очень класс. Буду делать!

    Благодарности.

    Не получится, буду беспокоить.

    www. заработает выложу

Оставьте комментарий!

Используйте нормальные имена. Ваш комментарий будет опубликован после проверки.

Если вы уже зарегистрированы как комментатор или хотите зарегистрироваться, укажите пароль и свой действующий email. При регистрации на указанный адрес придет письмо с кодом активации и ссылкой на ваш персональный аккаунт, где вы сможете изменить свои данные, включая адрес сайта, ник, описание, контакты и т.д., а также подписку на новые комментарии.

Авторизация: Авторизация MaxSite CMS. Facebook.

grin LOL cheese smile wink smirk rolleyes confused surprised big surprise tongue laugh tongue rolleye tongue wink raspberry blank stare long face ohh grrr gulp oh oh downer red face sick shut eye hmmm mad angry zipper kiss shock cool smile cool smirk cool grin cool hmm cool mad cool cheese vampire snake excaim question

(обязательно)