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['nombre'],$hijo['link'], $hijo['imagenComun']);
157 elseif ($this->_tipoMenu == 'Horizontal') {
158 $tmp = new MenuHorizontal ($hijo['nombre'],$hijo['link'], $hijo['imagenComun']);
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;
182 // +X2C Operation 119
184 * Funcion que devuelve un string con el html a imprimir por pantalla del menu de la seccion.
190 function menuToHtml() // ~X2C
192 trigger_error('Not implemented!', E_USER_WARNING);
196 // +X2C Operation 121
198 * Funcion que devuelve el string del titulo de la seccion
204 function tituloToHtml() // ~X2C
206 $TABLA = new HTML_Table('width=760 align="center" bgcolor="#336699" cellspacing="0" cellpadding="0" border="0"');
207 $row = array('<font face="Arial, Helvetica, sans-serif" size="3" color="#FFFFFF"><b>'.$this->_darTitulo().'</b></font>');
208 $TABLA->addRow($row,'height="1" bgcolor="#336699" align="left"');
209 return $TABLA->toHtml();
213 // +X2C Operation 122
215 * Funcion que devuelve el string del titulo a mostrar en pantalla
221 function _darTitulo() // ~X2C
223 return $this->_nombre;
227 // +X2C Operation 127
229 * Funcion que se encarga de desserializar el array asociativo paginas-secciones.
235 function _desSerializarArraySecciones() // ~X2C
237 $tmp = PRE_DIR.$this->_directorio.POST_DIR.ARRAYSECCIONES_SERIALIZADO;
238 $s = implode("", @file($tmp));
239 return unserialize($s);
243 // +X2C Operation 129
245 * 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.
246 Devuelve 1 si pertenece a la seccion, en caso contrario 0.
248 * @param string $link_sel Nombre de la pagina a la cual se quiere acceder.
254 function _verifSeccionSeleccionada($link_sel) // ~X2C
256 $tmp = $this->_desSerializarArraySecciones();
258 foreach ($tmp as $t) {
259 // echo $t[$link_sel].' == '.$this->_nombre .'<BR>';
260 if (isset($t) && $t[$link_sel] == $this->_nombre) {
261 $_SESSION['tipoMenu'] = $this->_tipoMenu;
269 } // -X2C Class :Seccion