Вывод списка тегов всех постов блогов — различия между версиями

Материал из Umicms
Перейти к:навигация, поиск
 
(не показана 1 промежуточная версия 1 участника)
Строка 2: Строка 2:
 
  [[category:Верстка в XSLT]]
 
  [[category:Верстка в XSLT]]
 
  [[category:Верстка в TPL]]
 
  [[category:Верстка в TPL]]
 +
[[Категория:Модуль Блоги20]]
 +
'''Актуально для версии 2.9'''
 +
 
<p>
 
<p>
 
'''Задача''':
 
'''Задача''':
Строка 118: Строка 121:
 
</source>
 
</source>
 
<p style="text-align: right;">
 
<p style="text-align: right;">
'''Листинг 4. Пример использования макроса в XSLT'''
+
'''Листинг 5. Пример использования макроса в XSLT'''
 
</p>
 
</p>
 
<source lang="html4strict">
 
<source lang="html4strict">
 
<xsl:value-of select="document('udata://blogs20/tagList/20/')/lines/tag/." disable-output-escaping="yes" />
 
<xsl:value-of select="document('udata://blogs20/tagList/20/')/lines/tag/." disable-output-escaping="yes" />
 
</source>
 
</source>

Текущая версия на 11:52, 5 июня 2013

Актуально для версии 2.9

Задача:

Вывести по шаблону список тегов всех постов блогов.

Решение:

Для решения данной задачи воспользуемся протоколом выборки данных - "Selector". Напишем макрос, который с помощью Selector'a будет формировать список тегов и выводить их по шаблону:

Листинг 1. Код макроса

/*
  @param String 
    $template - шаблон вывода для TPL
  @param Integer
    $limit - количество выводимых тегов
 */
public function tagList($template = 'default', $limit = false) {
  $posts = new selector('pages');
  $posts->types('hierarchy-type')->name('blogs20', 'post');
    
  $tags = array();
  foreach($posts as $post)
    $tags = array_merge($tags, $post->tags);
    
  $tags = array_values(array_unique($tags));
    
  if(!$template)
    $template = 'default';

  list($tags_block, $tags_block_tag, $tags_block_empty) = 
    def_module::loadTemplates('blogs20/tags/'.$template, 'tags_block', 'tags_block_tag', 'tags_block_empty');

  $total = count($tags);
  if($total > 0) {
    if($limit)
      $total = (($limit < $total) ? $limit : $total);
    
    $lines = array();
    for($i = 0; $i < $total; $i++) {
      $line_arr = array();
      $line_arr['tag'] = $tags[$i];
    
      $lines[] = def_module::parseTemplate($tags_block_tag, $line_arr, $tags);
    }
    
    $block_arr = array();
    $block_arr['void:lines'] = $lines;
 
    return def_module::parseTemplate($tags_block, $block_arr);
  } else {
    return $tags_block_empty;
  }
}

Код макроса поместим в файл "/classes/modules/blogs20/__custom.php" после строки "//TODO: Write here your own macroses". Теперь нам нужно добавить разрешения для макроса. Для этого создадим в той же директории файл "permissions.custom.php" со следующим содержанием:

Листинг 2. Добавление разрешений

<?php
$permissions = Array(
  'common' => array('tagList')
);
?>

Если Вы используете TPL шаблонизатор, также необходимо сделать шаблон, по которому будет организован вывод тегов. В папке "/tpls/blogs20/" создаём папку "tags", а в ней создаём файл "default.tpl" и размещаем в нём текст:

Листинг 3. Шаблон вывода тегов для TPL

<?php
$FORMS = Array();

$FORMS['tags_block'] = <<<END

<div>%lines%</div>

END;

$FORMS['tags_block_tag'] = <<<END

<span> - <b>%tag%</b> - </span>

END;

$FORMS['tags_block_empty'] = <<<END

<b>Пусто!</b>

END;

?>

Блок "tags_block" - контейнер списка тегов, внутри блока используется макрос %lines%, на его место подставляется код, указанный в блоке "tags_block_tag". Блок "tags_block_tag" предназначен для отдельно взятого тега, текст тега доступен через макрос %tag%. Блок "tags_block_empty" подставляется в том случае, если список тегов пуст.

Примеры использования макроса:

Листинг 4. Пример использования макроса в TPL

%blogs20 tagList(20)%

Листинг 5. Пример использования макроса в XSLT

<xsl:value-of select="document('udata://blogs20/tagList/20/')/lines/tag/." disable-output-escaping="yes" />