2 // vim: set expandtab tabstop=4 softtabstop=4 shiftwidth=4:
3 // +----------------------------------------------------------------------+
5 // +----------------------------------------------------------------------+
6 // | Copyright (c) 1997-2003 The PHP Group |
7 // +----------------------------------------------------------------------+
8 // | This source file is subject to version 2.02 of the PHP license, |
9 // | that is bundled with this package in the file LICENSE, and is |
10 // | available at through the world-wide-web at |
11 // | http://www.php.net/license/2_02.txt. |
12 // | If you did not receive a copy of the PHP license and are unable to |
13 // | obtain it through the world-wide-web, please send a note to |
14 // | license@php.net so we can mail you a copy immediately. |
15 // +----------------------------------------------------------------------+
16 // | Created: Mon Apr 14 16:23:22 2003
17 // | Author: Martin Marrese <mmarre@mecon.gov.ar>
18 // +----------------------------------------------------------------------+
27 #require_once 'PEAR.php';
31 require_once 'Pagina.php';
34 //Require Agregados por MMARRE, no pasan por el xmi2code
35 require_once 'ImagenAnimada.php';
36 require_once 'Menu.php';
37 require_once 'MenuHorizontal.php';
38 require_once 'MenuVertical.php';
41 // +X2C Class 16 :Seccion
43 * Clase seccion para el manejo de las secciones
47 class Seccion extends Pagina {
49 * Nombre de la seccion.
58 * Este es el nombre de la imagen
67 * Hijos (menu) de la seccion.
76 * Valor string del tipo de menu de la seccion
78 * @var string $tipoMenu
85 * Lugar en donde esta el sistema.
87 * @var string $directorio
97 * Constructor. Recibe como parametro el nombre de la seccion
99 * @param array $seccion Array con la informacion de la seccion
100 * @param string $directorio Dir en donde esta el sistema
107 function Seccion($seccion, $directorio) // ~X2C
109 $this->_nombre = $seccion['nombre'];
110 $this->_imagen = new ImagenAnimada($seccion['imagenComun']);
111 $this->_tipoMenu = $seccion['tipoMenu'];
112 $this->_directorio = $directorio;
113 parent::Pagina($seccion['link']);
114 $this->_cargarHijos($seccion['hijos']);
120 * Funcion que devuelve un string con el html a imprimir por pantalla.
122 * @param string $link_sel Indica la pagina a la cual se quiere acceder.
128 function toHtml($link_sel) // ~X2C
130 if ($this->_verifSeccionSeleccionada($link_sel)) {
131 $tmp = "<a href=\"".$this->_link."\"><img name=\"".$this->_nombre."\" src=\"images/".$this->_imagen->_imgSelect."\" border=\"0\" alt=\"".$this->_imagen->_alt."\"></a>";
134 $tmp = "<a href=\"".$this->_link."\" onMouseOut=\"MM_swapImgRestore()\" onMouseOver=\"MM_displayStatusMsg('".$this->_nombre."'); MM_swapImage('".$this->_nombre."','','images/".$this->_imagen->_imgMouseOn."',1); return document.MM_returnValue\" MM_swapImage('".$this->_nombre."','','images/".$this->_imagen->_imgMouseOn."',1)><img name=\"".$this->_nombre."\" src=\"images/".$this->_imagen->_imgComun."\" border=\"0\" alt=\"".$this->_imagen->_alt."\"></a>";
142 * Carga el array con los objetos hijos de la seccion
144 * @param array $hijos Array con los datos de los hijos de la seccion
150 function _cargarHijos($hijos) // ~X2C
152 $this->_hijos = array ();
153 foreach ($hijos as $hijo) {
154 if ($this->_tipoMenu == 'vertical') {
155 $tmp = new MenuVertical ($hijo);
157 elseif ($this->_tipoMenu == 'horizontal') {
158 $tmp = new MenuHorizontal ($hijo);
161 $tmp = new Menu (null,$hijo);
163 array_push($this->_hijos, $tmp);
168 // +X2C Operation 117
170 * Devuelve un string con el tipo de menu de la seccion
176 function darTipoMenu() // ~X2C
178 return $this->_tipoMenu;
183 // +X2C Operation 121
185 * Funcion que devuelve el string del titulo de la seccion
191 function tituloToHtml() // ~X2C
193 $TABLA = new HTML_Table('width=760 align="center" bgcolor="#336699" cellspacing="0" cellpadding="0" border="0"');
194 $row = array('<font face="Arial, Helvetica, sans-serif" size="3" color="#FFFFFF"><b>'.$this->_darTitulo().'</b></font>');
195 $TABLA->addRow($row,'height="1" bgcolor="#336699" align="left"');
196 return $TABLA->toHtml();
200 // +X2C Operation 122
202 * Funcion que devuelve el string del titulo a mostrar en pantalla
208 function _darTitulo() // ~X2C
210 return $this->_nombre;
214 // +X2C Operation 127
216 * Funcion que se encarga de desserializar el array asociativo paginas-secciones.
222 function _desSerializarArraySecciones() // ~X2C
224 $tmp = PRE_DIR.$this->_directorio.POST_DIR.ARRAYSECCIONES_SERIALIZADO;
225 $s = implode("", @file($tmp));
226 return unserialize($s);
230 // +X2C Operation 129
232 * Funcion que se encarga de verificar si la pagina a la cual se quiere acceder pertenece a la seccion que estoy dibujando. Se utiliza como agregado en toHtml.
233 Devuelve 1 si pertenece a la seccion, en caso contrario 0.
235 * @param string $link_sel Nombre de la pagina a la cual se quiere acceder.
241 function _verifSeccionSeleccionada($link_sel) // ~X2C
243 $tmp = $this->_desSerializarArraySecciones();
244 if (isset($tmp) && array_key_exists($link_sel,$tmp) && $tmp[$link_sel] == $this->_nombre) {
245 $_SESSION['tipoMenu'] = $this->_tipoMenu;
246 $_SESSION['menuHtml'] = $this->_menuToHtml();
253 // +X2C Operation 132
255 * Funcion que se encarga de devolver el html del menu a incluir en la pagina (menu vertical, horizontal o titulo segun corresponda)
261 function _menuToHtml() // ~X2C
263 if ($this->_tipoMenu == 'oculto') {
264 return $this->tituloToHtml();
266 elseif ($this->_tipoMenu == 'horizontal') {
268 foreach ($this->_hijos as $hijo) {
269 array_push($row,$hijo->toHtml());
271 $TABLA = new HTML_Table('width=760 align="center" bgcolor="#CCCCCC" cellspacing="0"');
272 $TABLA->addRow($row,'bgcolor="#CCCCCC" align="center"');
275 elseif ($this->_tipoMenu == 'vertical') {
276 $TABLA = new HTML_Table('width=200 align="center" bgcolor="#FFFFFF" cellspacing="0"');
277 foreach ($this->_hijos as $hijo) {
278 $row = array ($hijo->toHtml());
279 $TABLA->addRow($row,'bgcolor="#FFFFFF" align="left"');
286 } // -X2C Class :Seccion