X-Git-Url: https://git.llucax.com/mecon/meconlib.git/blobdiff_plain/71acf4950362871b3ad6bc168d08db422edf0509..997feeab434ec1ab5b6b94b8255068d732f8085f:/lib/MECON/Marco/Menu.php diff --git a/lib/MECON/Marco/Menu.php b/lib/MECON/Marco/Menu.php index 21e3e6f..edccce8 100644 --- a/lib/MECON/Marco/Menu.php +++ b/lib/MECON/Marco/Menu.php @@ -31,21 +31,19 @@ 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. * - * @package MECON_Marco * @access public */ -class Menu { +class MECON_Marco_Menu { /** * Array con la configuracion de las secciones del sistema;. * * @var array $configuracion * @access private */ - var $_configuracion; + var $_configuracion = array(); /** * Array de array con los componentes del menu @@ -53,7 +51,7 @@ class 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 @@ -69,7 +67,7 @@ class Menu { * @var string $titulo * @access private */ - var $_titulo; + var $_titulo = ''; /** * Array con los objetos seccion. @@ -77,52 +75,52 @@ 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 + var $_componentesVertical = array(); - // +X2C Operation 56 /** - * Constructor. Recibe como parametro el directorio en donde se encuentra el sistema. + * Recibe como parametro el directorio en donde se encuentra el 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->_tabla = new HTML_Table('width=760 + align="center" + cellspacing="0" + cellpadding="0" + border="0" + bgcolor="#FFFFFF"'); + $this->_tabla->setLineEnd(''); + $this->_tabla->setTab(''); + $this->_configuracion = $configuracion; } - // -X2C - // +X2C Operation 57 /** * Funcion que se encarga de generar el archivo que despues sera utilizado con la funcion EVAL. * * @return void * @access private */ - function _generarArchivo() // ~X2C + function _generarArchivo() { $s = serialize($this); $fp = fopen($this->_configuracion['directorios']['root'].'/'.MENU_SERIALIZADO,'w'); fputs($fp, $s); fclose($fp); } - // -X2C - - // +X2C Operation 58 + /** * Funcion que se encarga de obtener el archivo con los datos del objeto para ser utilizado con la funcion EVAL. * @@ -131,28 +129,23 @@ class Menu { * @return string * @access private */ - function _obtenerArchivo($directorio) // ~X2C + function _obtenerArchivo($directorio) { $s = implode("", @file($this->_configuracion['directorios']['root'].'/'.MENU_SERIALIZADO)); return unserialize($s); } - // -X2C - - - // +X2C Operation 76 + /** - * Funcion que obtiene el arrayde configuracion de secciones. + * Funcion que obtiene el array de configuracion de secciones. * * @return array * @access private */ - function _obtenerConfSecciones() // ~X2C + function _obtenerConfSecciones() { 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. * @@ -161,34 +154,45 @@ class Menu { * @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 - - - // +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 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() // ~X2C + function _serializarArraySecciones() { $secciones = $this->_configuracion['secciones']; $tmp = array(); @@ -201,15 +205,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); @@ -218,10 +227,7 @@ class Menu { fputs($fp, $s); fclose($fp); } - // -X2C - - - // +X2C Operation 134 + /** * Funcion que se encarga de agregar componentes al array * @@ -230,40 +236,44 @@ class Menu { * @return void * @access public */ - function agregarComponente($componente) // ~X2C + function agregarComponente($componente) { 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 + function toHtml() { 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 + function menuToHtml() { return $this->_menuHtml; } - // -X2C - -} // -X2C Class :Menu + /** + * Devuelve un string con el encabezado de la seccion + * + * @param string $titulo Titulo de la seccion + * + * @return string + * @access private + */ + function _armarEncabezado($titulo) + { + return ''.$titulo.''; + } +} ?> \ No newline at end of file