X-Git-Url: https://git.llucax.com/mecon/meconlib.git/blobdiff_plain/cacc1525e7102dfef7964462a50e4ff13f02dcc6..06cd54ffd3f4a2641a10db316fb08d42c3b8b5ea:/lib/MECON/Marco/Menu.php?ds=inline
diff --git a/lib/MECON/Marco/Menu.php b/lib/MECON/Marco/Menu.php
index a827721..92bf5e7 100644
--- a/lib/MECON/Marco/Menu.php
+++ b/lib/MECON/Marco/Menu.php
@@ -1,64 +1,71 @@
-
-// +----------------------------------------------------------------------+
-//
-// $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 los resultados para agregar a la pagina.
+ * Sobre este array MECON_Marco realiza un foreach para agregar lo que
+ * corresponda.
*
- * @var string $directorio
+ * @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 $_directorio;
-
+ 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
@@ -66,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.
@@ -79,151 +86,101 @@ 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 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->_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(PRE_DIR.$this->_directorio.POST_DIR.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(PRE_DIR.$directorio.POST_DIR.MENU_SERIALIZADO));
- return unserialize($s);
+ return '
'.$titulo.'
';
}
- // -X2C
-
- // +X2C Operation 76
/**
- * Funcion que obtiene el archivo de configuracion de secciones.
- *
- * @return array
- * @access private
- */
- function _obtenerConfSecciones() // ~X2C
- {
- $archivo = include SISTEMA_CONF_SECCIONES;
- return $archivo;
- }
- // -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->_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;
}
- 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.
- *
- * @return void
- * @access private
- */
- function _serializarArraySecciones() // ~X2C
- {
- $secciones = include SISTEMA_CONF_SECCIONES;
- $tmp = array();
- $tmp2 = array();
-
- $PATH = '/www/sistemas/'.$this->_directorio.'/www/';
-
- foreach ($secciones as $sec) { //Chequeo las secciones
- $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']);
- 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);
- }
- }
+ 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);
}
+ $i++;
}
- $tmp = array_merge($tmp,$tmp2);
- $s = serialize($tmp);
- $fp = fopen(PRE_DIR.$this->_directorio.POST_DIR.ARRAYSECCIONES_SERIALIZADO,'w');
- fputs($fp, $s);
- fclose($fp);
}
- // -X2C
-
-
- // +X2C Operation 134
+
/**
* Funcion que se encarga de agregar componentes al array
*
@@ -232,40 +189,106 @@ 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
+ /**
+ * Funcion que se encarga de generar el archivo que despues sera utilizado
+ * con la funcion EVAL.
+ *
+ * @return void
+ * @access private
+ */
+ 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();
+ $tmp2 = array();
+
+ $PATH = $this->_configuracion['directorios']['root'];
+
+ foreach ($secciones as $sec) { //Chequeo las secciones
+ $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[$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[$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);
+ $file_cache = strtr( $this->_configuracion['directorios']['root'], '/','_');
+ $fp = fopen($this->_configuracion['directorios_fs']['cache'].'/'.ARRAYSECCIONES_SERIALIZADO.'_'.$file_cache,'w');
+ fputs($fp, $s);
+ fclose($fp);
+ }
+}
?>
\ No newline at end of file