Creando módulos en Drupal 7
-
Upload
edgar-duenas -
Category
Technology
-
view
842 -
download
3
description
Transcript of Creando módulos en Drupal 7
Creando módulos en Drupal 7
Edgar DueñasSenior Web Developer
[email protected]@ieddu
http://www.pixtig.comhttp://www.linkedin.com/in/ieddu
¿Qué es Drupal?
Drupal es una plataforma de gestión de contenidos web muy potente que ofrece multitud de funcionalidades para el desarrollo web.
Drupal ha sido varias veces elegido el mejor CMS de código abierto a nivel mundial por:
● Por su estructura modular.● La consistencia de todo el sistema.● La calidad de su código y la seguridad. ● Estándares.● Accesibilidad y usabilidad web.
Drupal tiene licencia GNU/GPL y está escrito en PHP.
¿Qué es un módulo en Drupal?
El módulo (module) es un software que extiende las funcionalidades o características de Drupal.
Cuando crear un módulo
● Comunicación con sistemas externos.● Creación de funcionalidades muy a la medida.
Temas de hoy
✔ Ubicación del nuevo módulo.✔ Idioma base y codificación de los archivos.✔ Archivos principales del módulo: .info y .module.✔ La función t() para traducción de cadenas de texto.✔ Activación del módulo.✔ Ejemplo de desarrollo de un módulo.
Ubicación del módulo
sites/all/modules
En Drupal cada módulo dispone de su propio directorio, que recibe generalmente el mismo nombre que el módulo para simplificar la organización.
Importante
El nombre del directorio no debe contener espacios ni caracteres especiales.
Podemos utilizar el guion bajo como separador.
Idioma base y codificación
El idioma base siempre será el inglés
Drupal trabaja con UTF-8 en la codificación de archivos
Crear archivos con codificación UTF-8 sin BOM
Archivos principales del módulo
.info y .module
.info
Se trata de un archivo de texto escrito de formasimilar a un archivo php.ini, que contiene
información básica sobre el módulo(nombre, descripción, versión de Drupal, etc.)
El nombre debe ser similar al de la carpeta <nombre_modulo>.info
Ejemplo
sites/all/modules/primer_modulo/
.info
Puede contener otros campos como:
files (archivos, campo opcional). Drupal 7 permite el registro de código de forma dinámica, a través de funciones de autoload.
php (campo opcional). Indica la versión mínima de PHP requerida.
dependencies (dependencias, campo opcional). Nuestro módulo puede necesitar de otros módulos para su funcionamiento. El campo dependencies será un vector con los nombres de estos módulos requeridos.
.info
required (requerido, campo opcional). Especifica que el módulo actual es indispensable y siempre debe estar activado.
configure (configuración, campo opcional). Especifica la ruta a la página de configuración del módulo.
package (paquete, campo opcional). Cuando un módulo pertenece a un conjunto de módulos.
.module
El archivo .module incluye el código del módulo, en forma de funciones PHP. Es en este archivo donde se realizarán las llamada a los hooks.
El estándar para nombrar al archivo .module es similar al de los archivos .info, siguiendo el patrón <nombremodulo>.module.
El fichero .module no es más que un script PHP, de manera que la primera línea comienza con la marca de inicio de código PHP "<?php", pero no se cierra con este código ?>.
¿Qué es una hook?
Son funciones PHP que utilizamos en nuestros módulos, el nombre de las mismas se compone de la siguiente forma:
¿Para qué sirven las hooks?
Aumentan la funcionalidad de Drupal permitiendo a los módulos interactuar con el core.
De esta manera podemos alterar los comportamientos default de Drupal, y agregar nueva funcionalidad, si esos son los requerimientos para nuestro sitio.
La función t()
La función t() permite que el sistema pueda traducir las cadenas de texto al resto de idiomas activos en el sitio.
Activación del módulo
Ingresar al menu, ir a module, buscar, seleccionar y por ultimo grabar los cambios.
Tipos de módulos más usados
tipo bloquetipo página
Módulo de tipo bloque
Programando un bloque
hook_block_info(), define todos los bloques que nuestro módulo va a proveer.
hook_block_view(), construye el bloque.
hook_theme(), formateará la salida del tema hacia un archivo tpl
hook_block_info()
En el array $blocks definimos todos los bloques de nuestro módulo y proporcionamos las opciones por defecto de cada bloque.
hook_block_view()
En esta función definimos lo que se ve en cada bloque que implementa nuestro módulo. La variable $delta es la que nos identifica el bloque.
$block['content']
En esta variable llamamos a la función que contiene el contenido a imprimir.
Veamos el código y funcionamiento
Theming
Theming: maquetar el resultado
Ahora estamos introduciendo “Hola Mundo” en el array de variables que le vamos a pasar a la plantilla, y a continuación utilizamos la función theme() para generar el resultado de salida. Para ello la función theme() invoca el hook_theme().
hook_theme()
En nuestro hook_theme() estamos llamando a la plantilla (template): “saludar-hola-mundo”, para maquetar el callback: “saludar_hola_mundo”.
Creando un archivo de plantilla
El siguiente paso es crear nuestro archivo tpl que hemos definido en el hook_theme(), en nuestro caso se llama saludar-hola-mundo.tpl
Modulo de tipo pagina
hook_menu()
Sirve para crear una página, es decir, programar la respuesta para una determinada url.
Por ejemplo acceder desde:http://localhost/drupal/saludar/hola-mundo
hook_menu()
Lo que hemos hecho es añadir una url al array de elementos $items, y para esa dirección elegimos un título para la página y la función que implementa el contenido.
Función page callback
Veamos el código y funcionamiento
Form API
https://api.drupal.org/api/drupal/developer%21topics%21forms_api_reference.html/7
Ejemplo
¿Preguntas?