X-Git-Url: https://git.llucax.com/mecon/meconlib.git/blobdiff_plain/a420f0a24fe60b19c139999a970efa9c85596752..c0cc0ddabd54d39b68079ef97f414b799211aa67:/lib/MECON/Marco/Menu.php diff --git a/lib/MECON/Marco/Menu.php b/lib/MECON/Marco/Menu.php index 5b71ffc..92bf5e7 100644 --- a/lib/MECON/Marco/Menu.php +++ b/lib/MECON/Marco/Menu.php @@ -1,28 +1,28 @@ - -// +----------------------------------------------------------------------+ -// -// $Id$ -// $Author$ -// $URL$ -// $Date$ -// $Rev$ -// + +------------------------------------------------------------------------------- +$Id$ +-----------------------------------------------------------------------------*/ require_once 'MECON/Marco/Seccion.php'; require_once 'MECON/Marco/ImagenAnimada.php'; @@ -31,31 +31,41 @@ require_once 'HTML/Table.php'; define ('MENU_SERIALIZADO' , 'MenuSerializado'); define ('ARRAYSECCIONES_SERIALIZADO', 'ArraySeccionesSerializado'); -// +X2C Class 14 :Menu /** * Clase para el manejo de los menues y secciones de los sistemas. * * @access public */ -class Menu { +class MECON_Marco_Menu { /** - * Array con la configuracion de las secciones del sistema;. + * Array con los resultados para agregar a la pagina. + * Sobre este array MECON_Marco realiza un foreach para agregar lo que + * corresponda. + * + * @var array $resultado + * @access public + */ + var $resultado = array(); /** + + * Array con la configuracion de las secciones del sistema o subsecciones de + * la sección principal. * * @var array $configuracion * @access private */ - var $_configuracion; - + var $_configuracion = array(); + /** - * Array de array con los componentes del menu + * Array de array con los componentes del menu. * * @var array $componentes * @access private */ - var $_componentes; + var $_componentes = array(); /** - * Variable que contiene la tabla general de menues que se va a mostrar en pantalla + * Objeto que contiene el menu a mostrar. Opcionalmente puede contener el + * body de la pagina si es el caso de un menu vertical. * * @var table $tabla * @access private @@ -63,12 +73,12 @@ class Menu { var $_tabla; /** - * Variable que contiene el titulo de la seccion seleccionada + * Variable que contiene el titulo de la seccion seleccionada. * * @var string $titulo * @access private */ - var $_titulo; + var $_titulo = ''; /** * Array con los objetos seccion. @@ -76,118 +86,176 @@ class Menu { * @var array $secciones * @access private */ - var $_secciones; + var $_secciones = array(); /** + * Array de array con los componentes del menu en caso de ser este vertical. + * * @var string $componentesVertical * @access private */ - var $_componentesVertical; - - // ~X2C - - // +X2C Operation 56 + var $_componentesVertical = array(); + /** - * Constructor. Recibe como parametro el directorio en donde se encuentra el sistema. + * Recibe como parametro la configuracion del sistema. * * @param array $configuracion Array con los datos de las secciones * * @return void * @access public */ - function Menu($configuracion = null) // ~X2C + function MECON_Marco_Menu($configuracion = null) { - $this->_componentes = array (); //Inicializo vacio el array de componentes del menu - $this->_componentesVertical = array (); //Inicializo vacio el array de componentes del menu - $this->_secciones = array (); //Inicializo vacio el array de los objetos secciones - $this->_tabla = new HTML_Table('width=760 align="center" bgcolor="#FFFFFF" cellspacing="0" cellpadding="0" border="0"'); $this->_configuracion = $configuracion; + $this->_tabla =& new HTML_Table ( + array ( + 'width' => '760', + 'cellspacing' => '0', + 'cellpadding' => '0', + 'border' => '0', + ) + ); } - // -X2C - - // +X2C Operation 57 + /** - * Funcion que se encarga de generar el archivo que despues sera utilizado con la funcion EVAL. + * Funcion que obtiene el array de configuracion de secciones. * - * @return void + * @return array * @access private */ - function _generarArchivo() // ~X2C + function _obtenerConfSecciones() { - $s = serialize($this); - $fp = fopen($this->_configuracion['directorios']['root'].'/'.MENU_SERIALIZADO,'w'); - fputs($fp, $s); - fclose($fp); + return $this->_configuracion['secciones']; } - // -X2C - // +X2C Operation 58 /** - * Funcion que se encarga de obtener el archivo con los datos del objeto para ser utilizado con la funcion EVAL. + * Devuelve un string con el encabezado de la seccion * - * @param string $directorio Nombre del directorio en donde se encuentra el sistema instalado + * @param string $titulo Titulo de la seccion * * @return string * @access private */ - function _obtenerArchivo($directorio) // ~X2C + function _armarEncabezado($titulo) { - $s = implode("", @file($this->_configuracion['directorios']['root'].'/'.MENU_SERIALIZADO)); - return unserialize($s); + return '
'.$titulo.'
'; } - // -X2C - - // +X2C Operation 76 /** - * Funcion que obtiene el arrayde configuracion de secciones. - * - * @return array - * @access private - */ - function _obtenerConfSecciones() // ~X2C - { - return $this->_configuracion['secciones']; - } - // -X2C - - // +X2C Operation 82 - /** - * Funcion que arma a partir de la configuracion de las secciones el array con los objetos seccion. + * Funcion que arma a partir de la configuracion de las secciones el array + * con los objetos seccion. * * @param array $confSec Array con la informacion de las secciones * * @return void * @access private */ - function _armarArraySecciones($confSec) // ~X2C + function _armarArraySecciones($confSec) { $linksel = $_SERVER['PHP_SELF']; $ultimo = 0; $cuenta = count ($confSec); $i = 1; foreach ($confSec as $sec) { - $tmp = new Seccion ($sec, $this->_configuracion); - array_push($this->_componentes,$tmp->toHtml($linksel)); - if ($cuenta == $i) { - $ultimo = 1; + //Veo si tiene permisos para ver la seccion + if (!@$this->_configuracion['obj_permiso'] || !@$sec['permisos']) { + $ver = true; + } + elseif ($this->_configuracion['obj_permiso']->tiene(@$sec['permisos'])) { + $ver = true; + } + else { + $ver = false; + } + if ($ver) { + $tmp = new MECON_Marco_Seccion ($sec, $this->_configuracion); + array_push($this->_componentes, $tmp->toHtml($linksel)); + if ($cuenta == $i) { + $ultimo = 1; + } + array_push($this->_componentesVertical, + $tmp->toHtmlVertical($linksel,$ultimo)); + array_push($this->_secciones,$tmp); } - array_push($this->_componentesVertical, $tmp->toHtmlVertical($linksel,$ultimo)); $i++; - array_push($this->_secciones,$tmp); } } - // -X2C - + + /** + * Funcion que se encarga de agregar componentes al array + * + * @param array $componente Datos del componente de menu a agregar + * + * @return void + * @access public + */ + function agregarComponente($componente) + { + array_push($this->_componentes,$componente); + } + + /** + * Funcion que se encarga de devolver lo que se debe mostrar en pantalla + * + * @return string + * @access public + */ + function toHtml() + { + return $this->_tabla->toHtml(); + } + + /** + * Devuelve el html del menu que hay que mostrar en pantalla + * + * @return string + * @access public + */ + function menuToHtml() + { + return $this->_menuHtml; + } - // +X2C Operation 126 /** - * 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. + * Funcion que se encarga de generar el archivo que despues sera utilizado + * con la funcion EVAL. * * @return void * @access private */ - function _serializarArraySecciones() // ~X2C + function _generarArchivo() + { + $s = serialize($this); + $fp = fopen($this->_configuracion['directorios']['root'].'/'.MENU_SERIALIZADO,'w'); + fputs($fp, $s); + fclose($fp); + } + + /** + * Funcion que se encarga de obtener el archivo con los datos del objeto + * para ser utilizado con la funcion EVAL. + * + * @param string $directorio Nombre del directorio en donde se encuentra el + * sistema instalado + * + * @return string + * @access private + */ + function _obtenerArchivo($directorio) + { + $s = implode("", @file($this->_configuracion['directorios']['root'].'/'.MENU_SERIALIZADO)); + return unserialize($s); + } + + /** + * 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. + * + * @return void + * @access private + */ + function _serializarArraySecciones() { $secciones = $this->_configuracion['secciones']; $tmp = array(); @@ -200,15 +268,20 @@ class Menu { if (array_key_exists('hijos',$sec)) { foreach ($sec['hijos'] as $hijo) { //Chequeo las subsecciones array_push($tmp[$sec['nombre']],$PATH.'/'.$hijo['link']); - $tmp2[$hijo['nombre']] = array ($PATH.'/'.$hijo['link']); + $tmp2[$sec['nombre'].'-'.$hijo['nombre']] = array ($PATH.'/'.$hijo['link']); if (array_key_exists('subhijos',$hijo)) { foreach ($hijo['subhijos'] as $subhijo) { //Chequeo las subsubsecciones array_push($tmp[$sec['nombre']],$PATH.'/'.$subhijo); - array_push($tmp2[$hijo['nombre']],$PATH.'/'.$subhijo); + array_push($tmp2[$sec['nombre'].'-'.$hijo['nombre']],$PATH.'/'.$subhijo); } } } } + if (array_key_exists('subhijos',$sec)) { + foreach ($sec['subhijos'] as $subhijo2) { //Chequeo la lista de hijos no secciones + array_push($tmp[$sec['nombre']],$PATH.'/'.$subhijo2); + } + } } $tmp = array_merge($tmp,$tmp2); $s = serialize($tmp); @@ -217,52 +290,5 @@ class Menu { fputs($fp, $s); fclose($fp); } - // -X2C - - - // +X2C Operation 134 - /** - * Funcion que se encarga de agregar componentes al array - * - * @param array $componente Datos del componente de menu a agregar - * - * @return void - * @access public - */ - function agregarComponente($componente) // ~X2C - { - array_push($this->_componentes,$componente); - } - // -X2C - - - // +X2C Operation 143 - /** - * Funcion que se encarga de devolver lo que se debe mostrar en pantalla - * - * @return string - * @access public - */ - function toHtml() // ~X2C - { - return $this->_tabla->toHtml(); - } - // -X2C - - - // +X2C Operation 151 - /** - * Devuelve el html del menu que hay que mostrar en pantalla - * - * @return string - * @access public - */ - function menuToHtml() // ~X2C - { - return $this->_menuHtml; - } - // -X2C - -} // -X2C Class :Menu - -?> +} +?> \ No newline at end of file