Вывод случайного изображения фотогалереи — различия между версиями
Материал из Umicms
Stexe (обсуждение | вклад) |
Stexe (обсуждение | вклад) |
||
Строка 29: | Строка 29: | ||
Пример вызова макроса: | Пример вызова макроса: | ||
<source lang="xml"> | <source lang="xml"> | ||
− | <img src="{document('udata://custom/getLinkToRandomPhoto')}/udata" alt="photo" title="random photo" /> | + | <img src="{document('udata://custom/getLinkToRandomPhoto')}/udata}" alt="photo" title="random photo" /> |
</source> | </source> |
Версия 09:17, 27 апреля 2014
Актуально для версии 2.9.6
Задача: Выводить путь до изображения случайной фотографии.
Реализация:
В данном варианте мы будем использовать механизм формирования выборок selector.
В файл \classes\modules\custom.php добавим код custom макроса getLinkToRandomPhoto():
public function getLinkToRandomPhoto() {
$photos = new selector('pages');
$photos->types('object-type')->name('photoalbum', 'photo');
$photos->order('rand');
$randomPhoto = $photos->first;
if ( $randomPhoto instanceof iumiHierarchyElement ) {
$imagePath = $randomPhoto->getValue('photo')->getFilePath();
$imagePath = preg_replace('/^\./', '', $imagePath, 1);
return $imagePath;
}
return '';
}
TPL-шаблонизатор
Пример вызова макроса:
<img src="%custom getLinkToRandomPhoto()%" alt="photo" title="random photo" />
XSLT-шаблонизатор
Пример вызова макроса:
<img src="{document('udata://custom/getLinkToRandomPhoto')}/udata}" alt="photo" title="random photo" />