X-Git-Url: https://git.llucax.com/mecon/meconlib.git/blobdiff_plain/cacc1525e7102dfef7964462a50e4ff13f02dcc6..997feeab434ec1ab5b6b94b8255068d732f8085f:/lib/MECON/Marco/Menu.php diff --git a/lib/MECON/Marco/Menu.php b/lib/MECON/Marco/Menu.php index a827721..edccce8 100644 --- a/lib/MECON/Marco/Menu.php +++ b/lib/MECON/Marco/Menu.php @@ -1,53 +1,49 @@ - -// +----------------------------------------------------------------------+ -// -// $Id$ -// $Author$ -// $URL$ -// $Date$ -// $Rev$ -// + +------------------------------------------------------------------------------- +$Id$ +-----------------------------------------------------------------------------*/ + +require_once 'MECON/Marco/Seccion.php'; +require_once 'MECON/Marco/ImagenAnimada.php'; require_once 'HTML/Table.php'; -define ('PRE_DIR' , '/var/www/intranet/www/sistemas/'); -define ('POST_DIR' , '/conf/'); -define ('SISTEMA_CONF_SECCIONES' , 'confSecciones.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 { /** - * Nombre del directorio en donde se encuentra el sistema;. + * Array con la configuracion de las secciones del sistema;. * - * @var string $directorio + * @var array $configuracion * @access private */ - var $_directorio; + var $_configuracion = array(); /** * Array de array con los componentes del menu @@ -55,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 @@ -71,7 +67,7 @@ class Menu { * @var string $titulo * @access private */ - var $_titulo; + var $_titulo = ''; /** * Array con los objetos seccion. @@ -79,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; + var $_componentesVertical = array(); - // ~X2C - - // +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 string $directorio Nombre del directorio en donde se encuentra el sistema. + * @param array $configuracion Array con los datos de las secciones * * @return void * @access public */ - function Menu($directorio = 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->_directorio = $directorio; + $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(PRE_DIR.$this->_directorio.POST_DIR.MENU_SERIALIZADO,'w'); + $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. * @@ -133,29 +129,23 @@ class Menu { * @return string * @access private */ - function _obtenerArchivo($directorio) // ~X2C + function _obtenerArchivo($directorio) { - $s = implode("", @file(PRE_DIR.$directorio.POST_DIR.MENU_SERIALIZADO)); + $s = implode("", @file($this->_configuracion['directorios']['root'].'/'.MENU_SERIALIZADO)); return unserialize($s); } - // -X2C - - - // +X2C Operation 76 + /** - * Funcion que obtiene el archivo de configuracion de secciones. + * Funcion que obtiene el array de configuracion de secciones. * * @return array * @access private */ - function _obtenerConfSecciones() // ~X2C + function _obtenerConfSecciones() { - $archivo = include SISTEMA_CONF_SECCIONES; - return $archivo; + 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. * @@ -164,66 +154,80 @@ 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->_directorio); - 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 = include SISTEMA_CONF_SECCIONES; + $secciones = $this->_configuracion['secciones']; $tmp = array(); $tmp2 = array(); - $PATH = '/www/sistemas/'.$this->_directorio.'/www/'; + $PATH = $this->_configuracion['directorios']['root']; foreach ($secciones as $sec) { //Chequeo las secciones - $tmp[$sec['nombre']] = array ($PATH.$sec['link']); + $tmp[$sec['nombre']] = array ($PATH.'/'.$sec['link']); 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']); + array_push($tmp[$sec['nombre']],$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($tmp[$sec['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); - $fp = fopen(PRE_DIR.$this->_directorio.POST_DIR.ARRAYSECCIONES_SERIALIZADO,'w'); + $file_cache = strtr( $this->_configuracion['directorios']['root'], '/','_'); + $fp = fopen($this->_configuracion['directorios_fs']['cache'].'/'.ARRAYSECCIONES_SERIALIZADO.'_'.$file_cache,'w'); fputs($fp, $s); fclose($fp); } - // -X2C - - - // +X2C Operation 134 + /** * Funcion que se encarga de agregar componentes al array * @@ -232,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