Вывод случайного изображения фотогалереи — различия между версиями

Материал из Umicms
Перейти к:навигация, поиск
Строка 4: Строка 4:
 
'''Реализация:'''  
 
'''Реализация:'''  
  
В данном варианте мы будем использовать механизм формирования выборок selector. <br/>В файл '''\classes\modules\custom.php''' добавим код custom макроса '''getLinkToRandomPhoto('''):
+
В данном случае мы будем использовать механизм формирования выборок '''selector'''. <br/>В файл '''\classes\modules\custom.php''' добавим код custom макроса '''getLinkToRandomPhoto('''):
  
 
<source lang="php">
 
<source lang="php">

Версия 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" />