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';
39 require_once 'MenuOculto.php';
42 // +X2C Class 16 :Seccion
44 * Clase seccion para el manejo de las secciones
48 class Seccion extends Pagina {
50 * Nombre de la seccion.
59 * Este es el nombre de la imagen
68 * Hijos (menu) de la seccion.
77 * Valor string del tipo de menu de la seccion
79 * @var string $tipoMenu
86 * Lugar en donde esta el sistema.
88 * @var string $directorio
96 * @var string $menuHtml
106 * Constructor. Recibe como parametro el nombre de la seccion
108 * @param array $seccion Array con la informacion de la seccion
109 * @param string $directorio Dir en donde esta el sistema
116 function Seccion($seccion, $directorio) // ~X2C
118 if (array_key_exists('nombre',$seccion)) {
119 $this->_nombre = $seccion['nombre'];
121 if (array_key_exists('imagenComun',$seccion)) {
122 $this->_imagen = new ImagenAnimada($seccion['imagenComun']);
124 if (array_key_exists('tipoMenu',$seccion)) {
125 $this->_tipoMenu = $seccion['tipoMenu'];
127 if (!is_null($directorio)) {
128 $this->_directorio = $directorio;
130 if (array_key_exists('link',$seccion)) {
131 parent::Pagina($seccion['link']);
133 if (array_key_exists('hijos',$seccion)) {
134 $this->_cargarHijos($seccion['hijos']);
141 * Funcion que devuelve un string con el html a imprimir por pantalla.
143 * @param string $link_sel Indica la pagina a la cual se quiere acceder.
149 function toHtml($link_sel) // ~X2C
151 if (isset($_SESSION['deshabilitar_links']) && $_SESSION['deshabilitar_links']) {
157 $link_start = '<a href="'.$this->_link.'">';
158 $link_start2 = '<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)>';
162 if ($this->verifSeccionSeleccionada($link_sel)) {
163 $sec = $link_start."<img name=\"".$this->_nombre."\" src=\"images/".$this->_imagen->_imgSelect."\" border=\"0\" alt=\"".$this->_imagen->_alt."\">".$link_end;
166 $sec = $link_start2."<img name=\"".$this->_nombre."\" src=\"images/".$this->_imagen->_imgComun."\" border=\"0\" alt=\"".$this->_imagen->_alt."\">".$link_end;
175 * Carga el array con los objetos hijos de la seccion
177 * @param array $hijos Array con los datos de los hijos de la seccion
183 function _cargarHijos($hijos) // ~X2C
185 if ($this->_tipoMenu == 'vertical'){
186 $tmp = new MenuVertical($this->_directorio);
188 elseif ($this->_tipoMenu == 'horizontal') {
189 $tmp = new MenuHorizontal($this->_directorio);
192 $tmp = new MenuOculto($this->_directorio);
194 foreach ($hijos as $hijo) {
195 $tmp->agregarComponente($hijo);
197 $this->_hijos = $tmp;
201 // +X2C Operation 127
203 * Funcion que se encarga de desserializar el array asociativo paginas-secciones.
209 function _desSerializarArraySecciones() // ~X2C
211 $tmp = PRE_DIR.$this->_directorio.POST_DIR.ARRAYSECCIONES_SERIALIZADO;
212 $s = implode("", @file($tmp));
213 return unserialize($s);
217 // +X2C Operation 129
219 * 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.
220 Devuelve 1 si pertenece a la seccion, en caso contrario 0.
222 * @param string $link_sel Nombre de la pagina a la cual se quiere acceder.
228 function verifSeccionSeleccionada($link_sel) // ~X2C
230 $tmp = $this->_desSerializarArraySecciones();
232 if (isset($tmp) && array_key_exists($this->_nombre,$tmp)) {
233 foreach ($tmp[$this->_nombre] as $t) {
234 if ($link_sel == $t) {
245 // +X2C Operation 202
248 * @param string $link_sel Nombre de la seccion seleccionada
249 * @param bool $ultimo Indica si es el ultimo componente del menu.....en caso de serlo, debe mostrar la imagen con codito
255 function toHtmlVertical($link_sel, $ultimo = false) // ~X2C
257 $style = "text-decoration:none";
259 if (isset($_SESSION['deshabilitar_links']) && $_SESSION['deshabilitar_links']) {
264 $link_start = '<a href="'.$this->_link.'" style="'.$style.'">';
269 if ($this->verifSeccionSeleccionada($link_sel)) {
271 $sec[] = $link_start.'<img src="/www/images/carp2_f3" border="0">'.$link_end;
274 $sec[] = $link_start.'<img src="/www/images/carp1_f3" border="0">'.$link_end;
279 $sec[] = $link_start.'<img src="/www/images/carp2_f2" border="0">'.$link_end;
282 $sec[] = $link_start.'<img src="/www/images/carp1_f2" border="0">'.$link_end;
286 $sec[] = '<font face="Arial, Helvetica, sans-serif" size="1" color=""><b>'.$link_start.' '.$this->_nombre.$link_end.'</b></font>';
291 } // -X2C Class :Seccion