0 Пользователей и 1 Гость просматривают эту тему.
  • 2 Ответов
  • 234 Просмотров
*

leonid.m

  • Осваиваюсь на форуме
  • 27
  • 0 / 0
Добрый день
Появилась проблема. Слайдер выводит все материалы, даже в архиве и в корзине. Как сделать, чтобы выводились только опубликованные?
Код слайдера
Код
<?php
defined('_JEXEC') or die;
$order = $params->get('order');
$catid = $params->get('cat_id');
$animation = $params->get('animation');
$jqueryLoad = $params->get('jqueryLoad');
$slidedirection = $params->get('slideDirection');
$slideshowspeed = $params->get('slideshowSpeed');
$animationduration = $params->get('animationDuration');
$slideshow = ($params->get('slideshow') == 1)? 'true' : 'false';
$directionnav = ($params->get('directionNav') == 1)? 'true' : 'false';
$controlnav = ($params->get('controlNav') == 1)? 'true' : 'false';
$keyboardnav = ($params->get('keyboardNav') == 1)? 'true' : 'false';
$mousewheel = ($params->get('mousewheel') == 1)? 'true' : 'false';
$randomize = ($params->get('randomize') == 1)? 'true' : 'false';
$animationloop = ($params->get('animationLoop') == 1)? 'true' : 'false';
$pauseonaction = ($params->get('pauseOnAction') == 1)? 'true' : 'false';
$pauseonhover = ($params->get('pauseOnHover') == 1)? 'true' : 'false';
$flexsliderBgColor = $params->get('flexsliderBgColor');
$rand = rand(10000,20000);

// CSS, JS
JHTML::stylesheet('modules/mod_fl_slider/theme/css/fl_slider.css');
JHTML::script('modules/mod_fl_slider/theme/js/jquery.flexslider.js');

$db = JFactory::getDbo();
$query = $db->getQuery(true);
$query
->select($db->quoteName(array('id', 'title', 'introtext', 'urls')))
->from($db->quoteName('#__content'))
->where($db->quoteName('catid'). ' = ' . (int)$catid)
->order('ordering DESC');
$db->setQuery($query);
$content = $db->loadObjectlist();
?>

<?php echo '<script type="text/javascript">'; ?>
<?php echo 'jQuery(window).load(function() {
jQuery(\'#favsimple-'.$rand.'\').flexslider({
  animation: "'.$animation.'",
  slideDirection: "'.$slidedirection.'",
  slideshow: '.$slideshow.',';
if ($slideshow == "true") { echo '
      slideshowSpeed: '.$slideshowspeed.',
  animationDuration: '.$animationduration.','; }
echo            'directionNav: '.$directionnav.',
  controlNav: '.$controlnav.',
  keyboardNav: '.$keyboardnav.',
  mousewheel: '.$mousewheel.',
  randomize: '.$randomize.',
  animationLoop: '.$animationloop.',
  pauseOnAction: '.$pauseonaction.',
  pauseOnHover: '.$pauseonhover.'
  });
});
</script>'; ?>

<div id="favsimple-<?php echo $rand; ?>" class="flexslider">
<ul class="slides">
<?php
foreach($content as $show) {
$id_content = $show->id;
$query = $db->getQuery(true);
$query
->select($db->quoteName('value'))
->from($db->quoteName('#__fields_values'))
->where($db->quoteName('item_id').'='.$id_content)
->where($db->quoteName('field_id').'="1"');
$db->setQuery($query);
$res = $db->loadResult();
$urls=json_decode($show->urls);
$url=($urls->urla);
$query = $db->getQuery(true);
$query
->select($db->quoteName('value'))
->from($db->quoteName('#__fields_values'))
->where($db->quoteName('item_id').'='.$id_content)
->where($db->quoteName('field_id').'="2"');
$db->setQuery($query);
$data = $db->loadResult();
?>
<li class="img_slider" style="background-image:url('<?php echo $res;?>')!important; background-position:center !important;">
<div class="color_slider"></div>
<div class="container">

<div class="data_slider">
<?php echo $data; ?>
</div>
<h1 class="title_slider">
<?php echo $show->title; ?>
</h1>
<div class="intro_slider">
<?php echo $show->introtext; ?>
</div>
<a class="button" href="<?php echo $url ?>">Подробнее
</a>
</div>
</li>
<?php } unset($show); unset($content); ?>
</ul>
</div>
*

kern.USR

  • Давно я тут
  • 808
  • 61 / 1
В запрос
Код
$query
->select($db->quoteName(array('id', 'title', 'introtext', 'urls')))
->from($db->quoteName('#__content'))
->where($db->quoteName('catid'). ' = ' . (int)$catid)
->order('ordering DESC');
Добавте ещё одно условие, перед `order` :
Код
->where($db->quoteName('state'). ' = 1');

Должно вывести только опубликованные неархивные материалы
*

leonid.m

  • Осваиваюсь на форуме
  • 27
  • 0 / 0
Добавте ещё одно условие, перед `order` :
Код
->where($db->quoteName('state'). ' = 1');

Должно вывести только опубликованные неархивные материалы
Спасибо! Помогло
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Слайдер

Автор Merk

Ответов: 0
Просмотров: 62
Последний ответ 27.02.2019, 08:24:48
от Merk
Объединить материалы

Автор ebonydabster

Ответов: 3
Просмотров: 90
Последний ответ 21.02.2019, 16:08:29
от effrit
Порядок вывода в модуле "Материалы - Последние новости"

Автор kik84

Ответов: 0
Просмотров: 62
Последний ответ 12.02.2019, 13:14:24
от kik84
Как вывести все материалы из подкатегорий?

Автор Lemonez

Ответов: 4
Просмотров: 130
Последний ответ 06.02.2019, 07:10:28
от Lemonez
В Родительской категории сортирует материалы не по дате а по расположению катего

Автор artbavial

Ответов: 1
Просмотров: 122
Последний ответ 15.01.2019, 22:59:41
от artbavial