Creando módulos en Drupal 7

Post on 07-Dec-2014

842 views 3 download

description

Comparto mi presentación dada para el DrupalCamp Guatemla 2013 que consiste en una guía para iniciar a desarrollar módulos en Drupal 7. El código de ejemplo esta en https://www.dropbox.com/s/ek1lrbhg9bmsvcv/modules.zip

Transcript of Creando módulos en Drupal 7

Creando módulos en Drupal 7

Edgar DueñasSenior Web Developer

edgar@pixtig.com@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?

Gracias

Charla impartida por:Edgar Dueñas

edgar@pixtig.com