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 '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
53 * Array de array con los componentes del menu
55 * @var array $componentes
61 * Variable que contiene la tabla general de menues que se va a mostrar en pantalla
69 * Variable que contiene el titulo de la seccion seleccionada
77 * Array con los objetos seccion.
79 * @var array $secciones
85 * @var string $componentesVertical
88 var $_componentesVertical;
94 * Constructor. Recibe como parametro el directorio en donde se encuentra el sistema.
96 * @param string $directorio Nombre del directorio en donde se encuentra el sistema.
101 function Menu($directorio = null) // ~X2C
103 $this->_componentes = array (); //Inicializo vacio el array de componentes del menu
104 $this->_componentesVertical = array (); //Inicializo vacio el array de componentes del menu
105 $this->_secciones = array (); //Inicializo vacio el array de los objetos secciones
106 $this->_tabla = new HTML_Table('width=760 align="center" bgcolor="#FFFFFF" cellspacing="0" cellpadding="0" border="0"');
107 $this->_directorio = $directorio;
113 * Funcion que se encarga de generar el archivo que despues sera utilizado con la funcion EVAL.
118 function _generarArchivo() // ~X2C
120 $s = serialize($this);
121 $fp = fopen(PRE_DIR.$this->_directorio.POST_DIR.MENU_SERIALIZADO,'w');
129 * Funcion que se encarga de obtener el archivo con los datos del objeto para ser utilizado con la funcion EVAL.
131 * @param string $directorio Nombre del directorio en donde se encuentra el sistema instalado
136 function _obtenerArchivo($directorio) // ~X2C
138 $s = implode("", @file(PRE_DIR.$directorio.POST_DIR.MENU_SERIALIZADO));
139 return unserialize($s);
146 * Funcion que obtiene el archivo de configuracion de secciones.
151 function _obtenerConfSecciones() // ~X2C
153 $archivo = include SISTEMA_CONF_SECCIONES;
160 * Funcion que arma a partir de la configuracion de las secciones el array con los objetos seccion.
162 * @param array $confSec Array con la informacion de las secciones
167 function _armarArraySecciones($confSec) // ~X2C
169 $linksel = $_SERVER['PHP_SELF'];
171 $cuenta = count ($confSec);
173 foreach ($confSec as $sec) {
174 $tmp = new Seccion ($sec, $this->_directorio);
175 array_push($this->_componentes,$tmp->toHtml($linksel));
179 array_push($this->_componentesVertical, $tmp->toHtmlVertical($linksel,$ultimo));
181 array_push($this->_secciones,$tmp);
187 // +X2C Operation 126
189 * 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.
194 function _serializarArraySecciones() // ~X2C
196 $secciones = include SISTEMA_CONF_SECCIONES;
200 $PATH = '/www/sistemas/'.$this->_directorio.'/www/';
202 foreach ($secciones as $sec) { //Chequeo las secciones
203 $tmp[$sec['nombre']] = array ($PATH.$sec['link']);
204 if (array_key_exists('hijos',$sec)) {
205 foreach ($sec['hijos'] as $hijo) { //Chequeo las subsecciones
206 array_push($tmp[$sec['nombre']],$PATH.$hijo['link']);
207 $tmp2[$hijo['nombre']] = array ($PATH.$hijo['link']);
208 if (array_key_exists('subhijos',$hijo)) {
209 foreach ($hijo['subhijos'] as $subhijo) { //Chequeo las subsubsecciones
210 array_push($tmp[$sec['nombre']],$PATH.$subhijo);
211 array_push($tmp2[$hijo['nombre']],$PATH.$subhijo);
217 $tmp = array_merge($tmp,$tmp2);
218 $s = serialize($tmp);
219 $fp = fopen(PRE_DIR.$this->_directorio.POST_DIR.ARRAYSECCIONES_SERIALIZADO,'w');
226 // +X2C Operation 134
228 * Funcion que se encarga de agregar componentes al array
230 * @param array $componente Datos del componente de menu a agregar
235 function agregarComponente($componente) // ~X2C
237 array_push($this->_componentes,$componente);
242 // +X2C Operation 143
244 * Funcion que se encarga de devolver lo que se debe mostrar en pantalla
249 function toHtml() // ~X2C
251 return $this->_tabla->toHtml();
256 // +X2C Operation 151
258 * Devuelve el html del menu que hay que mostrar en pantalla
263 function menuToHtml() // ~X2C
265 return $this->_menuHtml;
269 } // -X2C Class :Menu