Con nuestro componente funcionando al 100% en su aspecto más básico, pasamos para el desarrollo de una nueva rama de nuestro sistema de comentarios, el módulo de los últimos comentarios insertados y publicados en el sitio web. ¡Manos a la obra!
Puede resultar extraño pasar a desarrollar un módulo, cuando el componente aún le faltan algunas cosas. Pero lo hacemos de esta manera para seguir lo que hasta ahora hemos ido consiguiendo, lograr un aspecto básico de nuestro sistema de comentarios. Una vez conseguido completamente el aspecto más básico de nuestro sistema, pues sería el momento entonces de llevarlo a otros niveles, agregando aspectos faltantes y adicionales. Creemos que este modelo de desarrollo nos permite ser más explícitos en los aspectos que explicamos, y logramos un mejor entendimiento por parte de ustedes.
Estructura del módulo
Entonces, el módulo “mod_mjcomments”. La conformación de la estructura del módulo es bien similar a las anteriores extensiones que hemos creado. En la imagen de abajo la pueden ver, en conjunto con la definición del archivo manifiesto del módulo:
<extension type="module" version="3.1" client="site" method="upgrade">
<name>mod_mjcomments</name>
<author>Carlos Rodriguez</author>
<creationDate>December 2015</creationDate>
<copyright>Copyright (C) 2016 Carlos Rodriguez. All rights reserved.</copyright>
<license>License http://www.gnu.org/licenses/gpl-3.0.html GNU/GPL</license>
<authorEmail>Esta dirección de correo electrónico está siendo protegida contra los robots de spam. Necesita tener JavaScript habilitado para poder verlo.</authorEmail>
<authorUrl>manualesjoomla.es</authorUrl>
<version>1.0.0</version>
<description>MOD_MJCOMMENTS_XML_DESCRIPTION</description>
<files>
<folder>language</folder>
<folder>module</folder>
<folder>layouts</folder>
<filename module="mod_mjcomments">mod_mjcomments.php</filename>
<filename>mod_mjcomments.xml</filename>
</files>
<media folder="media" destination="pkg_mjcommentsystem">
<folder>mod_mjcomments</folder>
</media>
</extension>
El manifiesto ya es bien familiar para nosotros. Aquí solo resaltaremos la carpeta “module” que hemos creado en los archivos del módulo. Si recuerdan, el desarrollo de la lógica del plugin lo realizamos en el mismo archivo de entrada del mismo. Pero ahora, usaremos otra variante. Crearemos un archivo llamado “comments.php” dentro de la carpeta “module” el cual nos va a servir de modelo para el módulo. Es decir, toda la lógica del módulo será llevada a cabo dentro de ese archivo, logrando crear dentro del módulo un ambiente MVC.
Empecemos por el modelo. El módulo nos va a renderizar los últimos comentarios insertados en el sitio, por lo que nuestro modelo debe proveer esta lista de comentarios. Mostraremos de cada elemento de la lista, el nombre del usuario que realizó el comentario, un fragmento (definido en caracteres a través de un parámetro del módulo) del texto de su comentario y un enlace con el nombre del artículo comentado. Según esto, el esqueleto del modelo nos quedaría de la siguiente forma:
Como bien hemos hablado durante todo este ciclo, estamos centralizando todo, por lo que nuestro módulo no es la excepción. Al igual que en el plugin, hemos añadido el modelo responsable de la obtención de una lista de comentarios (línea 17). Luego, en la línea 20 incorporamos el archivo helper del componente “com_content”, que es el que nos aporta la función “getArticleRoute” para generar el enlace a un determinado artículo. Ya a partir de la línea 27 empieza la clase perteneciente al modelo del módulo. Hemos escogido como nombre de clase “MjModuleComments”, porque vamos a registrar el prefijo “Mj” usando “JLoader::registerPrefix” (libraries\loader.php) logrando de esta forma poder utilizar este modelo en donde queramos dentro del módulo. Ya verán más adelante cuando definamos el punto de entrada del módulo. Luego pusimos nuestra clase, a heredar de la clase padre “EpaleModule”, pero, ¿existe esta clase dentro del core de Joomla?. No, esta clase no existe, ya que pertenece a la siguiente extensión que vamos a crear, una librería. Por lo que toca poner pausa al módulo y desviarnos un momento, e implementar esta librería rápidamente. ¿Porque crear ahora una librería? Como sabemos, el modelo del módulo lo usaremos para la obtención de los datos a mostrar por la vista. Pero, imaginemos que más adelante vamos a crear 5 módulos más, donde en cada uno de ellos van a existir funciones y procedimientos que se repiten una y otra vez. Ejemplo, obtener los archivos css y javascript del módulo. Tranquilos, que verán que es bien sencillo todo. La estructura de la librería es bien fácil: Como pueden ver, el manifiesto es bien similar a cualquier otro. Ahora editaremos el punto de entrada de la librería, el archivo “library.php”: Ya ven, nada del otro mundo, tan solo hemos registrado el espacio de nombre “Epale” para poder utilizar sus clases en cualquier extensión, así como lo hemos utilizado en el módulo de comentarios con la clase padre “EpaleModule”. Teniendo ya la librería registrada, ahora desarrollemos los procedimientos comunes para cualquier módulo, que es al final, lo que queremos lograr con nuestra librería. Para ello colocamos un archivo llamado “module.php” dentro de la carpeta “src/module” de la librería, conteniendo lo siguiente: Son bastantes líneas, pero son bien sencillas todas. La mayoría de las funciones son internas de la clase. Ya iremos viendo algunas, cuando sigamos con la programación del módulo. Agradecer aquí a Roberto Segura por brindar, a excepción de algunas modificaciones que hemos hecho, todas estas líneas de código en una de las emisiones de “Joomgouts”. Hemos terminado nuestra librería, por lo que añade otra extensión más a la cuenta. Ahora que hemos vuelto del pequeño desvío que hemos tomado, debemos retomar la programación del módulo. Nos habíamos quedado en la definición del modelo del módulo, pero antes de seguir con ella, ¿no quisieran probar que todo va saliendo bien? ¿que la librería se interconecta bien con nuestro módulo? Para los que tengan deseo, lo primero que debemos hacer es editar el manifiesto del paquete (pkg_mjcommentsystem.xml) para incluir las dos nuevas extensiones que hemos creado: Luego, editamos el punto de entrada del módulo, archivo “mod_mjcomments.php” y ponemos lo siguiente: En la línea 12, importamos nuestra librería con “JLoader::import”. La diferencia entre “import” y “registerPrefix” es que, “import” incluirá todo el archivo especificado en nuestro script, haciendo algunas convenciones de nombres específicos en joomla, mientras que “registerPrefix” nos permite incluir sólo las clases necesarias de los archivos del paquete especificado, ejemplo, en la línea 15 le decimos que nos incluya las clases con el prefijo “Mj” Listo. Ahora actualizamos el paquete y vamos al gestor de módulo, y publicamos el nuevo módulo en alguna posición del sitio. Cuando accedemos a la parte pública del sitio veremos algo como esto: Todo está funcionando de maravilla. Ahora podemos seguir con nuestro módulo tranquilamente, ya que sabemos que todo está muy bien interconectado. Retomando el camino que llevábamos, antes de desviarnos para crear la librería, estábamos programando el modelo del módulo, el archivo “comments.php” de la carpeta “module”. El modelo ya tiene el esqueleto armado, con tres funciones “getBaseLayoutData”, “getList” y “render”. La primera y la tercera función, son funciones heredadas de la clase padre “EpaleModule” (definida en la librería “Epale” que acabamos de crear). Empecemos por la primera, “getBaseLayoutData” la cual nos brinda, como bien indica el nombre, los datos básicos que podemos usar en los layout o vistas de nuestro módulo. Primero vamos a librería, y veamos que hace la función “getBaseLayoutData”. Esta función nos crea un array con tres elementos. El primero, son los parámetros del módulo, el cual los obtenemos con la función “getParams”. Así que este elemento tendrá aquellos parámetros que definamos en el manifiesto del módulo, más, los parámetros que incluye Joomla predeterminadamente. El segundo elemento del array, es la instancia de la clase, para poder acceder a sus funciones y variables que definamos o que ya estén definidas en la librería. El tercer elemento del array, es una cadena con el nombre del módulo en sí, la cual la usaremos como clase CSS del módulo. De esta forma, podemos definir estilos particulares para cada tipo de módulo. Sabiendo esto, desarrollemos ahora la función “getBaseLayoutData” en la clase del modelo del módulo. Editando el archivo “comments.php” quedaría de la siguiente forma: Primero, obtenemos el array con los elementos base para nuestro layout. Luego, en la línea 37, agregamos un elemento más, para almacenar el objetivo principal de este módulo, los últimos comentarios. Estos comentarios los obtendremos con la función “getList”, propia de la clase del modelo. Editemos entonces, la función principal de esta clase: ¿Qué les parece? ¿Muy simple? Es verdad que nuestro sistema aún es muy básico, pero no quita el hecho de que nos va quedando bien sencillo y escalable todo. La línea 50 de esta función “getList” ya es bien conocida por ustedes cuando trabajamos con el plugin. En este caso, obtenemos el modelo del componente de comentarios con el que vamos a trabajar en el módulo. Línea 53, 54 y 55. Recuerden que Joomla aplica un sistema de filtros, los cuales hemos ido usando en cada modelo. Primero (línea 53 y 54) establecemos la cantidad de comentarios a extraer. Si se fijan, utilizamos dos parámetros, “exclude_comments” y “count”, para establecer los límites. Es decir, el límite desde donde empieza hasta donde acaba. De esta forma, le podemos decir al modelo que nos devuelva, por ejemplo, los últimos 10 comentarios insertados en el sistema, pero, que de esos 10 comentarios, nadamas queremos los que están del 5 al 10. Ambos parámetros, pertenecen al módulo que estamos desarrollando, por lo que tenemos que definirlos porque aún no los hemos creado en el manifiesto del mismo. Pero terminemos de explicar primero esta función. En la línea 55, establecemos el filtro de publicación, para solo obtener aquellos comentarios que están publicados. Este filtro no lo tratamos dentro del modelo que estamos utilizando, por lo que tenemos otra tarea a llevar a cabo. Por último, en la línea 58 obtenemos los últimos comentarios insertados en el sistema, aplicando los filtros que hemos establecidos, así de simple. Noten, que en el modelo del componente “Formlist” usamos la función “getCommentsArticle” para obtener la lista de comentarios de un artículo en particular. Pero en el caso del módulo, hemos llamado directamente a la función “getItems” para que nos devuelva los comentarios de cualquier artículo. Antes de seguir, realicemos las tareas que han surgido. Primero, vamos al manifiesto del módulo para crear los parámetros que hemos utilizado anteriormente. Listo, dos campos de tipo “text” con un filtrado de “integer” conforman los dos parámetros. Hemos añadido un tercer parámetro llamado “layout”, para que el usuario desde la administración, establezca el layout que va a utilizar con el módulo. De esta forma, podemos crear diversas estructuras y diseños para el módulo. Este parámetro va a buscar dentro de la carpeta layouts del módulo, los layout existentes. Aún no hemos creado ninguno, por lo que el campo saldrá en blanco. Por último, recuerden colocar las cadenas de texto traducibles que hemos creado dentro del archivo de idioma del módulo. Primera tarea pendiente resuelta. La próxima es establecer el filtro de publicación en el modelo del componente, ya que nos hace falta para el módulo. Así que editemos el archivo “formlist.php”: [code start:105 lang:php]// Filter by published state $published = $this->getState('filter.published'); if (is_numeric($published)) { $query->where('a.state = ' . (int) $published); }[/code] Simples modificaciones, gran funcionalidad. Para concluir con el modelo del módulo, escribimos el cuerpo de la función “render”: Esta función es la encargada de renderizar todos los datos que hemos obtenido hasta este punto. En caso de que no se haya obtenido ningún comentario por algún error o algo, establecemos (línea 74) un layout diferente para mostrar un mensaje de error. La función encargada de esto es “setLayout” la cual pueden encontrar en la librería “Epale” que creamos. Todo listo con los modelos, así que ya podemos pasar a las vistas porque ya hemos hablado bastante de layout y no hemos creado ninguno. Primero, creamos el layout “_error” dentro de la carpeta “layouts”: Bien simple esta vista. ¿Probamos a ver si funciona? Para poder probar esto, necesitamos poner en forma al controlador del módulo, el archivo de entrada “mod_mjcomments.php”: Listo. Si actualizamos el paquete, y publicamos como es lógico, el módulo en alguna parte del sitio y borramos todos los comentarios que podamos tener en el gestor de comentarios para generar el error, nos damos cuenta que no surge efecto. El módulo sale en blanco cuando debería de salir un mensaje de error. ¿Cual es el problema? Nuestro módulo no puede renderizar el layout, porque en verdad no lo encuentra. Si vamos a la librería de nosotros, dentro del API de los módulos, abrimos el archivo “module.php” y en la función “getLayoutFolder” encargada de obtener el directorio del layout a renderizar, vemos que utiliza la función “getLayoutPath” de la clase “JModuleHelper” para lograrlo. Al ir entonces a “libraries\cms\module\helper.php” en busca de esta función (línea 279), vemos que en la línea 295 el directorio en donde busca los layout es “tmpl”. Y como el nombre del directorio que nosotros creamos es “layouts” provoca que el módulo no encuentre los layout que hemos creado. Solución, cambiar “layouts” por “tmpl”. También deben actualizar el manifiesto del módulo para que Joomla reconozca el cambio. Nota: Se pretende que a partir de la versión 3.5, ya los módulos soporten todo el sistema de layouts. Probemos de nuevo y actualicemos el paquete. ¡Perfecto! hemos renderizado el layout del error, aunque, no ha salido alguna información del error. Como el error que hemos provocado es el de que no existe ningún comentario realizado, agregamos un mensaje informando de lo ocurrido. Para ello actualizamos la función “render” del modelo del módulo, agregando un mensaje a través de la función de la librería “Epale”. Le asignamos un valor a la cadena de texto traducible y volvemos actualizar el paquete: ¡Ahora sí! Todo ha funcionado perfectamente. Ahora solo queda el layout del listado, pero con la antesala que hemos tenido con el layout del error, todo es más sencillo. Como bien establecimos en los parámetros del módulo, el nombre del siguinte layout es “latest”. Por lo que dentro de la carpeta “tmpl” creamos un archivo llamado “latest.php”: Aquí utilizamos los archivos “js” y “css” del módulo, por lo que utilizamos las funciones para cargar estos archivos definidas en la librería “Epale”. También tienen que crear ambos archivos dentro de la carpeta “media\mod_mjcomments\css y \js” del módulo. Luego, en la línea 30, hemos establecido el layout que en sí, nos va a mostrar el listado de los últimos comentarios realizados en el sitio. Este layout no será visible en la administración del módulo, solo el nombre “latest” será visible. ¿Pero por qué establecer otro layout para el cuerpo del listado de comentarios? Por ejemplo, si creamos un layout avanzado para el listado de los últimos comentarios, solo sería poner una línea parecida a la 30, pero con un nombre como “latest_advanced”. Luego, definimos un parámetro dentro de la configuración del módulo para que el usuario decida que diseño prefiere, para visualizar los últimos comentarios. Ahora imaginen que esta opción solo sea para usuarios suscritos. Infinidades de ventajas trae este esquema. Por último, creamos el archivo “latest_basic.php” que contendrá lo siguiente: Esta estructura recuerden que pertenece a bootstrap 3. Pero venga, probemos de una vez a ver que tal funciona. Primero, hagamos un par de comentarios en el sitio y luego actualicemos a ver que tal: ¡Epale! Hombre ha salido super bien todo. Bien fácil los módulos ¿verdad? Si se fijan en la estructura de la lista de comentarios, estamos asociando un enlace a cada uno de ellos ¿Porque? Como los comentarios son realizados en un artículo determinado, pues le ofreceremos al usuario la posibilidad de dar clic encima del comentario para ir al artículo relacionado. Pero esto lo haremos de forma separada. Traten de hacerlo ustedes, y luego comparamos soluciones en el próximo tutorial, donde incluiremos un pequeño apartado para esta pequeña tarea. De seguro debe seguirte molestando el tema diseño. Pero no te preocupes, que en el próximo o en los próximos tutoriales nos centraremos en la programación de la plantilla de este ciclo, por lo que llegó la hora de poner bonito todo. Como siempre, ya tienen disponible en Github el código fuente del paquete hasta este tutorial. ¡Nos vemos! Etiquetas: Desarrollo, Extensiones, Ciclo de desarrollo, Programación
/**
* @package MJ.Module
* @subpackage Comments
*
* @copyright Copyright (C) 2015 Carlos Rodriguez. All rights reserved.
* @license License http://www.gnu.org/licenses/gpl-3.0.html GNU/GPL
*/
defined('_JEXEC') or die;
// Proxy to the component site path
$comMjcomments_path = JPATH_SITE . '/components/com_mjcomments/';
$comContent_path = JPATH_SITE . '/components/com_content/';
// Add the Mjcomments site models
JModelLegacy::addIncludePath($comMjcomments_path . '/models', 'MjcommentsModel');
// Add the com_content route helpers
require_once $comContent_path . 'helpers/route.php';
/**
* Mj comments model class
*
*/
final class MjModuleComments extends EpaleModule
{
/**
* Get the base module layout data
*
* @return array
*/
public function getBaseLayoutData()
{
}
/**
* Get a list of comments from the formlist model
*
* @return mixed
*/
protected function getList($params)
{
}
/**
* Render the module
*
* @param array $layoutData Array containing the data to use in the layout
* @return string
*/
public function render($layoutData = array())
{
}
}Creación de la librería “Epale”. Complemento para los módulos.
<extension type="library" method="upgrade" version="3.1">
<name>Epale - Library</name>
<libraryname>epale</libraryname>
<creationDate>January 2015</creationDate>
<author>Carlos Rodriguez</author>
<authorEmail>Esta dirección de correo electrónico está siendo protegida contra los robots de spam. Necesita tener JavaScript habilitado para poder verlo.</authorEmail>
<authorUrl>manualesjoomla.es</authorUrl>
<copyright>Copyright (C) 2016 Carlos Rodriguez - All rights reserved.</copyright>
<license>License http://www.gnu.org/licenses/gpl-3.0.html GNU/GPL</license>
<version>1.0.0</version>
<description>Epale common libraries</description>
<files>
<folder>module</folder>
<filename>epale.xml</filename>
<filename>library.php</filename>
</files>
</extension>
/**
* @package Epale
* @subpackage Library
*
* @copyright Copyright (C) 2016 Carlos Rodriguez - All rights reserved.
* @license License http://www.gnu.org/licenses/gpl-3.0.html GNU/GPL
*/
defined('_JEXEC') or die;
define('EPALE_LIB_PATH', __DIR__);
// Global libraries autoloader
JLoader::registerPrefix('Epale', EPALE_LIB_PATH);
/**
* @package Epale
* @subpackage Library
*
* @copyright Copyright (C) 2016 Carlos Rodriguez - All rights reserved.
* @license License http://www.gnu.org/licenses/gpl-3.0.html GNU/GPL
*/
defined('_JEXEC') or die;
/**
* Modules base class
*
* @since 1.0
*/
abstract class EpaleModule
{
/**
* Latest error
*
* @var string
*/
protected $error;
/**
* Name of the module folder
*
* @var string
*/
protected $folderName;
/**
* Layout to render
*
* @var string
*/
protected $layout;
/**
* Module parameters
*
* @var JRegistry
*/
protected $params;
/**
* Constructor
*
* @param mixed $params array or JRegistry with the module parameters
*/
public function __construct($params = array())
{
$this->setParams($params);
}
/**
* Get the base module layout data
*
* @return array
*/
public function getBaseLayoutData()
{
return array(
'params' => $this->getParams(),
'moduleInstance' => $this,
'cssClass' => $this->getCssClass()
);
}
/**
* Get the module main CSS class
*
* @return string
*/
public function getCssClass()
{
return str_replace('_', '-', $this->getFolderName());
}
/**
* Get the latest error
*
* @return string
*/
public function getError()
{
return $this->error;
}
/**
* Get current instance name
*
* Example: in class "MjModuleSample" it will return "sample"
*
* @return string
*/
protected function getInstanceName()
{
$class = get_class($this);
$name = strstr($class, 'Module');
$name = str_replace('Module', '', $name);
return strtolower($name);
}
/**
* Get the module folder name
*
* @return string
*/
protected function getFolderName()
{
if (null === $this->folderName)
{
$this->folderName = 'mod_' . $this->getPrefix() . $this->getInstanceName();
}
return $this->folderName;
}
/**
* Get the active layout
*
* @return string
*/
public function getLayout()
{
if (null === $this->layout)
{
$params = $this->getParams();
$this->layout = $params->get('layout', '_:default');
}
return $this->layout;
}
/**
* Get the layout name. This cleans layouts from the modulelayout field
*
* @return string
*/
protected function getLayoutName()
{
$layout = $this->getLayout();
$layoutParts = explode(':', $layout);
return count($layoutParts) == 2 ? $layoutParts[1] : $layoutParts[0];
}
/**
* Return the folder of the active layout
*
* @return string
*/
protected function getLayoutFolder()
{
$path = JModuleHelper::getLayoutPath($this->getFolderName(), $this->getLayout());
return dirname($path);
}
/**
* Get the module parameters
*
* @return JRegistry
*/
public function getParams()
{
return $this->params;
}
/**
* Get the module prefix. Example: MjModuleSample will return Mj
*
* @return string
*/
protected function getPrefix()
{
$class = get_class($this);
$prefix = strstr($class, 'Module', true);
return strtolower($prefix);
}
/**
* Fast proxy to load overridable JS files from the module folder
*
* @param string $fileName JS file to load. Example: script.js
*
* @return void
*/
public function loadScript($fileName, $base = '')
{
$path = empty($base) ? $this->getFolderName() : $base . '/' . $this->getFolderName();
JHtml::script($path . '/' . $fileName, false, true);
}
/**
* Fast proxy to load overridable CSS files from the module folder
*
* @param string $fileName CSS file to load. Example: style.css
*
* @return void
*/
public function loadStylesheet($fileName, $base = '')
{
$path = empty($base) ? $this->getFolderName() : $base . '/' . $this->getFolderName();
JHtml::stylesheet($path . '/' . $fileName, false, true, false);
}
/**
* Render the module
*
* @param array $layoutData Array containing the data to use in the layout
*
* @return string
*/
public function render($layoutData = array())
{
$params = $this->getParams();
$options = array('debug' => $params->get('debug', false));
$layoutData = array_merge($this->getBaseLayoutData(), $layoutData);
return JLayoutHelper::render($this->getLayoutName(), $layoutData, $this->getLayoutFolder(), $options);
}
/**
* Set the error message
*
* @param string $message The error message
*
* @return MjModule Self instance for chaining
*/
protected function setError($message)
{
$this->error = $message;
return $this;
}
/**
* Set the active layout
*
* @param string $layout Layout name. Example: default
*
* @return MjModule Self instance for chaining
*/
public function setLayout($layout)
{
$this->layout = $layout;
return $this;
}
/**
* Set the module parameters
*
* @param mixed $params array or JRegistry witht the module parameters
*
* @return MjModule Self instance for chaining
*/
public function setParams($params)
{
if (is_array($params) || is_string($params))
{
$this->params = new JRegistry($params);
}
if ($params instanceof JRegistry || $params instanceof Joomla\Registry\Registry)
{
$this->params = $params;
}
else
{
$this->params = new JRegistry;
}
return $this;
}
}
<file type="library" id="lib_epale">libraries/epale</file>
<!-- Modules -->
<file type="module" id="mod_mjcomments" client="site">modules/site/comments</file>
/**
* @package MJ.Module
* @subpackage Comments
*
* @copyright Copyright (C) 2015 Carlos Rodriguez. All rights reserved.
* @license License http://www.gnu.org/licenses/gpl-3.0.html GNU/GPL
*/
defined('_JEXEC') or die;
JLoader::import('epale.library');
// Register our own prefix
JLoader::registerPrefix('Mj', __DIR__);
$moduleInstance = new MjModuleComments($params);
var_dump($moduleInstance); exit();
* Get the base module layout data
*
* @return array
*/
public function getBaseLayoutData()
{
$layoutData = parent::getBaseLayoutData();
$layoutData['items'] = $this->getList($layoutData['params']);
return $layoutData;
}
* Get a list of comments from the formlist model
*
* @return mixed
*/
protected function getList($params)
{
// Get an instance of the formlist model
$formlist = JModelLegacy::getInstance('Formlist', 'MjcommentsModel', array('ignore_request' => true));
// Set the filters based on the module params
$formlist->setState('list.start', (int) $params->get('exclude_comments', 0));
$formlist->setState('list.limit', (int) $params->get('count', 5));
$formlist->setState('filter.published', 1);
// Retrieve Comments
$comments = $formlist->getItems();
return $comments;
}
<fields name="params">
<fieldset name="basic">
<field
name="layout"
type="modulelayout"
default="_:latest"
label="MOD_MJCOMMENTS_COMMENTS_PARAMS_LAYOUT"
description="MOD_MJCOMMENTS_COMMENTS_PARAMS_LAYOUT_DESC"
/>
<field type="spacer" name="spacerbasic" hr="true" />
<field
name="exclude_comments"
type="text"
default="0"
filter="integer"
label="MOD_MJCOMMENTS_COMMENTS_PARAMS_EXCLUDE_COMMENTS"
description="MOD_MJCOMMENTS_COMMENTS_PARAMS_EXCLUDE_COMMENTS_DESC"
/>
<field
name="count"
type="text"
default="5"
filter="integer"
label="MOD_MJCOMMENTS_COMMENTS_PARAMS_COUNT"
description="MOD_MJCOMMENTS_COMMENTS_PARAMS_COUNT_DESC"
/>
</fieldset>
</fields>
</config>
; Copyright (C) 2015 Carlos Rodríguez. All rights reserved.
; License http://www.gnu.org/licenses/gpl-3.0.html GNU/GPL, see LICENSE
; System
MOD_MJCOMMENTS="MJ - Últimos comentarios"
MOD_MJCOMMENTS_XML_DESCRIPTION="Lista de los últimos comentarios publicados."
; Params
MOD_MJCOMMENTS_COMMENTS_PARAMS_COUNT="Cantidad de comentarios"
MOD_MJCOMMENTS_COMMENTS_PARAMS_COUNT_DESC="Cantidad de comentarios a mostrar dentro del módulo."
MOD_MJCOMMENTS_COMMENTS_PARAMS_EXCLUDE_COMMENTS="Excluir comentarios"
MOD_MJCOMMENTS_COMMENTS_PARAMS_EXCLUDE_COMMENTS_DESC="Cantidad de comentarios a excluir de la consulta. Tenga presente que el valor tiene que ser estrictamente menor que el valor de la opción \"Cantidad de comentarios\""
MOD_MJCOMMENTS_COMMENTS_PARAMS_LAYOUT="Plantilla"
MOD_MJCOMMENTS_COMMENTS_PARAMS_LAYOUT_DESC="Selecciona la plantilla que quieres usar en el módulo."
* Render the module
*
* @param array $layoutData Array containing the data to use in the layout
* @return string
*/
public function render($layoutData = array())
{
$layoutData = array_merge($this->getBaseLayoutData(), $layoutData);
if (empty($layoutData['comments']))
{
$this->setLayout('_error');
}
return parent::render($layoutData);
}
/**
* @package MJ.Module
* @subpackage Comments
*
* @copyright Copyright (C) 2015 Carlos Rodriguez. All rights reserved.
* @license License http://www.gnu.org/licenses/gpl-3.0.html GNU/GPL
*/
defined('_JEXEC') or die;
extract($displayData);
/**
* Layout variables
* -----------------
* @var string $cssClass Module CSS class
* @var string $cssId Module CSS identifier
* @var object $module Module data as it comes from Joomla
* @var MjModule $moduleInstance Module rendering this layout
* @var JRegistry $params Object with the module config
*/
$cssId = $cssId ? 'id="' . $cssId . '"' : null;
?>
<div class="<?php echo $cssClass; ?> alert alert-error" <?php echo $cssId; ?>>
<?php echo $moduleInstance->getError(); ?>
</div>
/**
* @package MJ.Module
* @subpackage Comments
*
* @copyright Copyright (C) 2015 Carlos Rodriguez. All rights reserved.
* @license License http://www.gnu.org/licenses/gpl-3.0.html GNU/GPL
*/
defined('_JEXEC') or die;
JLoader::import('epale.library');
// Register our own prefix
JLoader::registerPrefix('Mj', __DIR__);
// Load language
$lang = JFactory::getLanguage();
$lang->load('mod_mjcomments', __DIR__);
// Load instance
$moduleInstance = new MjModuleComments($params);
// Create unique css class
$cssId = !empty($module->id) ? $moduleInstance->getCssClass() . '-' . $module->id : null;
// Render layout
echo $moduleInstance->render(
array(
'module' => $module,
'cssId' => $cssId
)
);
/**
* @package MJ.Module
* @subpackage Comments
*
* @copyright Copyright (C) 2015 Carlos Rodriguez. All rights reserved.
* @license License http://www.gnu.org/licenses/gpl-3.0.html GNU/GPL
*/
defined('_JEXEC') or die;
extract($displayData);
/**
* Layout variables
* -----------------
* @var string $cssClass Module CSS class
* @var string $cssId Module CSS identifier
* @var object $module Module data as it comes from Joomla
* @var MjModule $moduleInstance Module rendering this layout
* @var JRegistry $params Object with the module config
*/
$moduleInstance->loadScript('script_mod_mjcomments.js');
$moduleInstance->loadStylesheet('style_mod_mjcomments.css');
$cssId = $cssId ? 'id="' . $cssId . '"' : null;
?>
<div class="<?php echo $cssClass; ?> latest" <?php echo $cssId; ?>>
<?php echo $moduleInstance->setLayout('latest_basic')->render($displayData); ?>
</div>
/**
* @package MJ.Module
* @subpackage Comments
*
* @copyright Copyright (C) 2015 Carlos Rodriguez. All rights reserved.
* @license License http://www.gnu.org/licenses/gpl-3.0.html GNU/GPL
*/
defined('_JEXEC') or die;
extract($displayData);
/**
* Layout variables
* -----------------
* @var string $cssClass Module CSS class
* @var string $cssId Module CSS identifier
* @var object $module Module data as it comes from Joomla
* @var MjModule $moduleInstance Module rendering this layout
* @var JRegistry $params Object with the module config
*/
?>
<div class="list-group">
<?php foreach ($comments as $comment) : ?>
<a href="#" class="list-group-item">
<h4 class="list-group-item-heading">
<?php echo $comment->visitor_name; ?>
</h4>
<p class="list-group-item-text">
<?php echo $comment->visitor_comments; ?>
</p>
</a>
<?php endforeach; ?>
</div>
¡Gracias a CComment! por facilitar los comentarios en ManualesJoomla.es!