Часть 4. Добавление помошника
"Помошник" (Helper) - вспомогательные файл для модуля, в котором можно оперировать данными. Например, в нем можно получать данные из БД или оперировать какими-то другими данными. В данном случае этот файл будет просто возвращать значение "Hello World"
helper.php
<?php
/**
* @package Joomla.Tutorials
* @subpackage Module
* @copyright (C) 2012 http://jomla-code.ru
* @license License GNU General Public License version 2 or later; see LICENSE.txt
*/
// No direct access.
defined('_JEXEC') or die('(@)|(@)');
class modHelloworldHelper
{
public static function getList(&$params)
{
$html = 'Hello World';
return $html;
}
}
Данный файл подключается в точке входа
mod_helloworld.php
<?php
/**
* @package Joomla.Tutorials
* @subpackage Module
* @copyright (C) 2012 http://jomla-code.ru
* @license License GNU General Public License version 2 or later; see LICENSE.txt
*/
// No direct access.
defined('_JEXEC') or die('(@)|(@)');
// Подключаем файл помошника
require_once dirname(__FILE__).'/helper.php';
// Выполняем getList метод из помошника
$list = modHelloworldHelper::getList($params);
require JModuleHelper::getLayoutPath('mod_helloworld', $params->get('layout', 'default'));
Теперь в макете вывода можно использовать объект или переменную $list. В данном случае это просто переменная, поэтому просто выведем ее.
tmpl/default.php
<?php
/**
* @package Joomla.Tutorials
* @subpackage Module
* @copyright (C) 2012 http://jomla-code.ru
* @license License GNU General Public License version 2 or later; see LICENSE.txt
*/
// No direct access.
defined('_JEXEC') or die('(@)|(@)');
echo $list;
?>
Не забываем добавлять этот файл в XML описание модуля.
mod_helloworld.xml
<?xml version="1.0" encoding="utf-8"?>
<extension type="module" version="2.5.0" method="upgrade">
<!-- Названия модуля -->
<name>mod_helloworld</name>
<!-- Следующие элементы являются не обязательными,
информация об авторе, копирайте и т.п. -->
<creationDate>November 2010</creationDate>
<author>SomeBody</author>
<authorEmail>Этот адрес электронной почты защищен от спам-ботов. У вас должен быть включен JavaScript для просмотра.</authorEmail>
<authorUrl>http://www.joomla-code.ru</authorUrl>
<copyright>Copyright Info</copyright>
<license>License Info</license>
<!-- Версия модуля запишется в БД таблица extension -->
<version>0.0.1</version>
<!-- Описание, не обязательно, по умолчанию использеуется имя модуля -->
<description>MOD_HELLOWORLD_XML_DESCRIPTION</description>
<!-- Обратите внимание на атрибут folder, он указывает из
какой директории будут копироваться файлы -->
<files>
<filename module="mod_helloworld">mod_helloworld.php</filename>
<filename>mod_helloworld.xml</filename>
<filename>index.html</filename>
<filename>helper.php</filename>
<folder>tmpl</folder>
</files>
<config>
<fields name="params">
<!-- Основные параметры для модуля -->
<fieldset name="basic">
<field name="text" type="text"
label="MOD_HELLOWORLD_TEXT_FIELD_LABEL"
description="MOD_HELLOWORLD_TEXT_FIELD_DESC" />
</fieldset>
<!-- Дополнительные параметры для модуля -->
<fieldset name="advanced">
<field name="layout" type="modulelayout"
label="JFIELD_ALT_LAYOUT_LABEL"
description="JFIELD_ALT_MODULE_LAYOUT_DESC" />
</fieldset>
</fields>
</config>
<!-- Файлы локализации -->
<languages folder="language">
<language tag="ru-RU">ru-RU/ru-RU.mod_helloworld.ini</language>
<language tag="ru-RU">ru-RU/ru-RU.mod_helloworld.sys.ini</language>
</languages>
</extension>
