Ene 6 2009

Construyendo el portal de Tery Software - Menus animados con kwicks

Continuando con los artículos de la creación de nuestro portal corporativo, continuamos con la creación de los menús. Generalmente los menús son generados por Drupal de manera automática; sin embargo, estos menus son sencillos links en HTML y buscábamos algo animado. Decidimos emplear un plugin desarrollado en J-Query que proporciona menús de acordeón llamado kwicks.

Específicamente el ejemplo #1 se ajustaba a una idea que nos surgió de que los personajes de nuestro logo empujaran los menus. Por ser desarrollado sobre J-Query existía una alta posibilidad de que pudiera integrarse con Drupal y de hecho así lo fué, pero ¿ Como hacer que se integrara completamente con la potente gestión de contenido que ofrece Drupal ?.

Dado que Drupal esta desarrollado sobre PHP y es un CMS bastante personalizable, decidimos crear un pequeño script que embedido en el template generara el algoritmo necesario en HTML y JavaScript para cada menu existente.

La manera como se obtuvieron los menús existentes fue capturando la variable $primary_links que es una arreglo y empleando las variables contenidas en dicho arreglo para cada menú. El array $primary_links consta de los siguientes registros por cada menu:

$primary_links => array(1) {
	["some_menu"]=>  array(3) {
		["attributes"]=>  array(1) {
			["title"]=>  string(33) "Titulo al posar el cursor"
		}
		["href"]=>  string(6) "node/6"
		["title"]=>  string(9) "Principal"
	}
}

El número de elementos que contendrá el array $primary_links depende directamente del número de menús que hallan sido creados. Para que un menú se muestre animado con kwicks debe cada opción estar codificada así:

<ul class="kwicks">
	<li id="kwick1">Menu 1</li>
	<li id="kwick2">Menu 2</li>
</ul>

De modo que lo que hacemos es emplear la sentencia de control foreach para que por cada elemento del arreglo nos genere un menú siguiendo el patrón anterior. Para organizar y estilizar de una mejor manera, decidimos dentro de cada <li> declarar un <h2>(Por ser un subtitulo creemos que es semánticamente correcto) y un <label>. Tambíen cabe mencionar que en el script se emplea una variable de control $n a fin de que los identificadores no se repitan y no incumpla el XHTML. Por último era necesario recuperar el alias de url en ves de la url original, ya que de emplear la original nuestro usuarios estarían siendo dirigidos a páginas del tipo “node/#”. A continuación el pequeño script debidamente comentado. Este script fue insertado en un <div$gt; dentro del template principal (page.tpl.php). ver acerca de PHPTemplate y maqueteado en Drupal.

<div id="kwickmenu">
<ul class="kwicks">
<h2 class="main_links">
					<label>
					<a title="'.$option[" href="../../../../'.$nombre["> '.$option["title"].'
					</a>
					</label></h2>
';}
		/*De lo contrario imprimir sin el alias (path original)*/
		else {
		echo '
	<li id="kwick'.$n.'">
<h2 class="main_links">
					<label>
					<a title="'.$option[" href="../../../../'.$option["> '.$option["title"].'
					</a>
					</label></h2>
</li>
';}
		$n++;		/* Incrementamos el identificador para la siguiente iteración*/
		}
		?&gt;</ul>
</div>

comentado. Este script fue insertado dentro del template principal (page.tpl.php). ver acerca de PHPTemplate y maqueteado en Drupal.

De esta manera se integraron los menús con Drupal. Es importante hacer referencia a las hojas de estilo y scripts que vienen contenido en el paquete de kwicks para que funcione correctamente. El resultado se puede apreciar en nuestra web TerySoftware, un menú animado haciendo uso de un efecto de acordeón.