Новости Joomla

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

griz_bear

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
Здравствуйте, только начал изучать программирование для Joomla, поэтому просьба великим программистам сильно не ругаться =) Хочется, чтобы из БД данные выводились в модуль на главной странице.

Вот листинг:

файл mod_videolist.xml

Код
<?xml version="1.0" encoding="utf-8"?>
<extension type="module" version="1.7" client="site" method="upgrade">
<name>Video List</name>
<creationDate>28.03.2012</creationDate>
<author>Author Company</author>
<authorUrl>http://www.site.ru</authorUrl>
<copyright></copyright>
<license>Open Source License, GNU GPL</license>
<version>1.0</version>
<description>Description</description>

<files>
<filename module="mod_videolist">mod_videolist.php</filename>
<filename>index.html</filename>
<filename>helper.php</filename>
<filename>mod_videolist.xml</filename>
<folder>tmpl</folder>
<filename>tmpl/index.html</filename>
<filename>tmpl/default.php</filename>
</files>

<language folder="language">
<language tag="en-GB">en-GB.mod_videolist.ini"></language>
<language tag="ru-RU">ru-RU.mod_videolist.ini"></language>
</language>

<config>
<fields name="params">
<fieldset name="Базовые настройки" label="Базовые настройки">
<field name="source_cat" type="category" extension="com_content" multiple="true" default="" label="JCATEGORY" description="Укажите желаемую категорию раздела для вывода превью"/>
<field name="amout_of_rows" type="text" default="" label="Число рядов" description="Укажите желаемую категорию раздела для вывода превью"/>
<field name="module_width" type="text" default="100%" size="5" label="Ширина модуля" description="Ширина модуля"/>
</fieldset>
<fieldset name="Настройка видео" label="Настройка видео">
<field name="width" default="200" type="text" label="Ширина" description="Ширина видео"/>
<field name="height" default="150" type="text" label="Высота" description="Высота видео"/>
</fieldset>
</fields>
</config>
</extension>

файл mod_videolist.php

Код
<?php

defined ('_JEXEC') or die('Restricted Access');

require_once(dirname(__FILE__).DS.'helper.php');

$list = modVideoListHelper::getList($params);

require(JModuleHelper::getLayoutPath('mod_videolist'));

файл helper.php
Код
<?php

defined ('_JEXEC') or die('Restricted Access');

class modVideoListHelper {

public function getList(&$params){
$db = &JFactory::getDBO();
$source_cat = $params->get('source_cat');
$query = 'SELECT * FROM `#_content` WHERE `catid` = $source_cat';
$db->setQuery($query);
$list = $db->loadObjectList();
return  $list;
}
}

файл default.php
Код
<?php

defined ('_JEXEC') or die('Restricted Access');

foreach($list as $row) {
echo $row->title;
}

В результате на главную выводится ошибка вместо title выбранной в админке категории: Warning: Invalid argument supplied for foreach() in Z:\home\site.ru\www\modules\mod_videolist\tmpl\default.php on line 12

В чем ошибка не пойму, помогите пожалуйста.....заранее спасибо.
*

griz_bear

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
Спасибо, частично заработало =)

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

если я оставляю так, как есть

Код
class modVideoListHelper {

public function getList(&$params){
$db = &JFactory::getDBO();
$source_cat = $params->get('source_cat');
$query = 'SELECT * FROM `#__content` WHERE catid = $source_cat';
$db->setQuery($query);
$list = $db->loadObjectList();
return  $list;
}
}

и если проверить переменную $source_cat, через echo, то она возвращает не idcat(в моем случае должно быть 77), а Array, в то время как запросу нужно именно число. Как записать правильно? =)
*

griz_bear

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
Что никто не знает?  :(
*

griz_bear

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
Спасибо большущее, все перепробовал =).
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться