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 'Seccion.php';
28 require_once 'ImagenAnimada.php';
29 require_once 'include/lib/HTML/Table.php';
31 define ('PRE_DIR' , '/var/www/intranet/www/sistemas/');
32 define ('POST_DIR' , '/conf/');
33 define ('SISTEMA_CONF_SECCIONES' , 'confSecciones.php');
34 define ('MENU_SERIALIZADO' , 'MenuSerializado');
35 define ('ARRAYSECCIONES_SERIALIZADO', 'ArraySeccionesSerializado');
37 // +X2C Class 14 :Menu
39 * Clase para el manejo de los menues y secciones de los sistemas.
45 * Nombre del directorio en donde se encuentra el sistema;.
47 * @var string $directorio
54 * Array de array con los componentes del menu
56 * @var array $componentes
63 * Variable que contiene la tabla general de menues que se va a mostrar en pantalla
72 * Variable que contiene el titulo de la seccion seleccionada
81 * Array con los objetos seccion.
83 * @var array $secciones
91 * @var string $componentesVertical
95 var $_componentesVertical;
101 * Constructor. Recibe como parametro el directorio en donde se encuentra el sistema.
103 * @param string $directorio Nombre del directorio en donde se encuentra el sistema.
109 function Menu($directorio = null) // ~X2C
111 $this->_componentes = array (); //Inicializo vacio el array de componentes del menu
112 $this->_componentesVertical = array (); //Inicializo vacio el array de componentes del menu
113 $this->_secciones = array (); //Inicializo vacio el array de los objetos secciones
114 $this->_tabla = new HTML_Table('width=760 align="center" bgcolor="#FFFFFF" cellspacing="0" cellpadding="0" border="0"');
115 $this->_directorio = $directorio;
121 * Funcion que se encarga de generar el archivo que despues sera utilizado con la funcion EVAL.
127 function _generarArchivo() // ~X2C
129 $s = serialize($this);
130 $fp = fopen(PRE_DIR.$this->_directorio.POST_DIR.MENU_SERIALIZADO,'w');
138 * Funcion que se encarga de obtener el archivo con los datos del objeto para ser utilizado con la funcion EVAL.
140 * @param string $directorio Nombre del directorio en donde se encuentra el sistema instalado
146 function _obtenerArchivo($directorio) // ~X2C
148 $s = implode("", @file(PRE_DIR.$directorio.POST_DIR.MENU_SERIALIZADO));
149 return unserialize($s);
156 * Funcion que obtiene el archivo de configuracion de secciones.
162 function _obtenerConfSecciones() // ~X2C
164 $archivo = include SISTEMA_CONF_SECCIONES;
171 * Funcion que arma a partir de la configuracion de las secciones el array con los objetos seccion.
173 * @param array $confSec Array con la informacion de las secciones
179 function _armarArraySecciones($confSec) // ~X2C
181 $linksel = $_SERVER['PHP_SELF'];
183 $cuenta = count ($confSec);
185 foreach ($confSec as $sec) {
186 $tmp = new Seccion ($sec, $this->_directorio);
187 array_push($this->_componentes,$tmp->toHtml($linksel));
191 array_push($this->_componentesVertical, $tmp->toHtmlVertical($linksel,$ultimo));
193 array_push($this->_secciones,$tmp);
199 // +X2C Operation 126
201 * Funcion que se encarga de serializar el array asociativo paginas-secciones. Se utilizara en la clase seccion para identificar a que seccion pertenece la pagina a la cual se quiere acceder.
207 function _serializarArraySecciones() // ~X2C
209 $secciones = include SISTEMA_CONF_SECCIONES;
213 foreach ($secciones as $sec) { //Chequeo las secciones
214 $tmp[$sec['nombre']] = array ($sec['link']);
215 if (array_key_exists('hijos',$sec)) {
216 foreach ($sec['hijos'] as $hijo) { //Chequeo las subsecciones
217 array_push($tmp[$sec['nombre']],$hijo['link']);
218 $tmp2[$hijo['nombre']] = array ($hijo['link']);
219 if (array_key_exists('subhijos',$hijo)) {
220 foreach ($hijo['subhijos'] as $subhijo) { //Chequeo las subsubsecciones
221 array_push($tmp[$sec['nombre']],$subhijo);
222 array_push($tmp2[$hijo['nombre']],$subhijo);
228 $tmp = array_merge($tmp,$tmp2);
229 $s = serialize($tmp);
230 $fp = fopen(PRE_DIR.$this->_directorio.POST_DIR.ARRAYSECCIONES_SERIALIZADO,'w');
237 // +X2C Operation 134
239 * Funcion que se encarga de agregar componentes al array
241 * @param array $componente Datos del componente de menu a agregar
247 function agregarComponente($componente) // ~X2C
249 array_push($this->_componentes,$componente);
254 // +X2C Operation 143
256 * Funcion que se encarga de devolver lo que se debe mostrar en pantalla
262 function toHtml() // ~X2C
264 return $this->_tabla->toHtml();
269 // +X2C Operation 151
271 * Devuelve el html del menu que hay que mostrar en pantalla
277 function menuToHtml() // ~X2C
279 return $this->_menuHtml;
283 } // -X2C Class :Menu