1 <?php /* vim: set binary expandtab tabstop=4 shiftwidth=4 textwidth=80:
2 -------------------------------------------------------------------------------
5 -------------------------------------------------------------------------------
6 This file is part of meconlib.
8 meconlib is free software; you can redistribute it and/or modify it under
9 the terms of the GNU General Public License as published by the Free
10 Software Foundation; either version 2 of the License, or (at your option)
13 meconlib is distributed in the hope that it will be useful, but WITHOUT
14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
15 FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License; if not,
18 write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
19 Boston, MA 02111-1307 USA
20 -------------------------------------------------------------------------------
21 Creado: Mon Apr 14 16:23:22 2003
22 Autor: Martin Marrese <mmarre@mecon.gov.ar>
23 -------------------------------------------------------------------------------
25 -----------------------------------------------------------------------------*/
27 require_once 'MECON/Marco/Seccion.php';
28 require_once 'MECON/Marco/ImagenAnimada.php';
29 require_once 'HTML/Table.php';
31 define ('MENU_SERIALIZADO' , 'MenuSerializado');
32 define ('ARRAYSECCIONES_SERIALIZADO', 'ArraySeccionesSerializado');
34 // +X2C Class 14 :MECON_Marco_Menu
36 * Clase para el manejo de los menues y secciones de los sistemas.
38 * @package MECON_Marco
41 class MECON_Marco_Menu {
43 * Array con la configuracion de las secciones del sistema;.
45 * @var array $configuracion
48 var $_configuracion = array();
51 * Array de array con los componentes del menu
53 * @var array $componentes
56 var $_componentes = array();
59 * Variable que contiene la tabla general de menues que se va a mostrar en pantalla
67 * Variable que contiene el titulo de la seccion seleccionada
75 * Array con los objetos seccion.
77 * @var array $secciones
80 var $_secciones = array();
83 * Array de array con los componentes del menu en caso de ser este vertical
85 * @var string $componentesVertical
88 var $_componentesVertical = array();
94 * Recibe como parametro el directorio en donde se encuentra el sistema.
96 * @param array $configuracion Array con los datos de las secciones
101 function MECON_Marco_Menu($configuracion = null) // ~X2C
103 $this->_tabla = new HTML_Table('width=760
109 $this->_tabla->setLineEnd('');
110 $this->_tabla->setTab('');
112 $this->_configuracion = $configuracion;
118 * Funcion que se encarga de generar el archivo que despues sera utilizado con la funcion EVAL.
123 function _generarArchivo() // ~X2C
125 $s = serialize($this);
126 $fp = fopen($this->_configuracion['directorios']['root'].'/'.MENU_SERIALIZADO,'w');
134 * Funcion que se encarga de obtener el archivo con los datos del objeto para ser utilizado con la funcion EVAL.
136 * @param string $directorio Nombre del directorio en donde se encuentra el sistema instalado
141 function _obtenerArchivo($directorio) // ~X2C
143 $s = implode("", @file($this->_configuracion['directorios']['root'].'/'.MENU_SERIALIZADO));
144 return unserialize($s);
151 * Funcion que obtiene el array de configuracion de secciones.
156 function _obtenerConfSecciones() // ~X2C
158 return $this->_configuracion['secciones'];
164 * Funcion que arma a partir de la configuracion de las secciones el array con los objetos seccion.
166 * @param array $confSec Array con la informacion de las secciones
171 function _armarArraySecciones($confSec) // ~X2C
173 $linksel = $_SERVER['PHP_SELF'];
175 $cuenta = count ($confSec);
177 foreach ($confSec as $sec) {
178 //Veo si tiene permisos para ver la seccion
179 if (!@$this->_configuracion['obj_permiso'] || !@$sec['permisos']) {
182 elseif ($this->_configuracion['obj_permiso']->tiene(@$sec['permisos'])) {
189 $tmp = new MECON_Marco_Seccion ($sec, $this->_configuracion);
190 array_push($this->_componentes,$tmp->toHtml($linksel));
194 array_push($this->_componentesVertical, $tmp->toHtmlVertical($linksel,$ultimo));
195 array_push($this->_secciones,$tmp);
203 // +X2C Operation 126
205 * 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.
210 function _serializarArraySecciones() // ~X2C
212 $secciones = $this->_configuracion['secciones'];
216 $PATH = $this->_configuracion['directorios']['root'];
218 foreach ($secciones as $sec) { //Chequeo las secciones
219 $tmp[$sec['nombre']] = array ($PATH.'/'.$sec['link']);
220 if (array_key_exists('hijos',$sec)) {
221 foreach ($sec['hijos'] as $hijo) { //Chequeo las subsecciones
222 array_push($tmp[$sec['nombre']],$PATH.'/'.$hijo['link']);
223 $tmp2[$sec['nombre'].'-'.$hijo['nombre']] = array ($PATH.'/'.$hijo['link']);
224 if (array_key_exists('subhijos',$hijo)) {
225 foreach ($hijo['subhijos'] as $subhijo) { //Chequeo las subsubsecciones
226 array_push($tmp[$sec['nombre']],$PATH.'/'.$subhijo);
227 array_push($tmp2[$sec['nombre'].'-'.$hijo['nombre']],$PATH.'/'.$subhijo);
232 if (array_key_exists('subhijos',$sec)) {
233 foreach ($sec['subhijos'] as $subhijo2) { //Chequeo la lista de hijos no secciones
234 array_push($tmp[$sec['nombre']],$PATH.'/'.$subhijo2);
238 $tmp = array_merge($tmp,$tmp2);
239 $s = serialize($tmp);
240 $file_cache = strtr( $this->_configuracion['directorios']['root'], '/','_');
241 $fp = fopen($this->_configuracion['directorios_fs']['cache'].'/'.ARRAYSECCIONES_SERIALIZADO.'_'.$file_cache,'w');
248 // +X2C Operation 134
250 * Funcion que se encarga de agregar componentes al array
252 * @param array $componente Datos del componente de menu a agregar
257 function agregarComponente($componente) // ~X2C
259 array_push($this->_componentes,$componente);
264 // +X2C Operation 143
266 * Funcion que se encarga de devolver lo que se debe mostrar en pantalla
271 function toHtml() // ~X2C
273 return $this->_tabla->toHtml();
278 // +X2C Operation 151
280 * Devuelve el html del menu que hay que mostrar en pantalla
285 function menuToHtml() // ~X2C
287 return $this->_menuHtml;
291 // +X2C Operation 222
293 * Devuelve un string con el encabezado de la seccion
295 * @param string $titulo Titulo de la seccion
300 function _armarEncabezado($titulo) // ~X2C
302 return '<font face="Arial, Helvetica, sans-serif" size="3" color="#336699"><b>'.$titulo.'</b></font>';
306 } // -X2C Class :MECON_Marco_Menu