X-Git-Url: https://git.llucax.com/mecon/meconlib.git/blobdiff_plain/cacc1525e7102dfef7964462a50e4ff13f02dcc6..cf3ecc87d6a327afdb468c29f890d317b3d99f07:/lib/MECON/Marco/Menu.php diff --git a/lib/MECON/Marco/Menu.php b/lib/MECON/Marco/Menu.php index a827721..32d81bd 100644 --- a/lib/MECON/Marco/Menu.php +++ b/lib/MECON/Marco/Menu.php @@ -24,13 +24,10 @@ // $Rev$ // -require_once 'Seccion.php'; -require_once 'ImagenAnimada.php'; +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'); @@ -42,12 +39,12 @@ define ('ARRAYSECCIONES_SERIALIZADO', 'ArraySeccionesSerializado'); */ class 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 de array con los componentes del menu @@ -93,18 +90,18 @@ class Menu { /** * Constructor. 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 Menu($configuracion = null)// ~X2C { $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; } // -X2C @@ -115,10 +112,10 @@ class Menu { * @return void * @access private */ - function _generarArchivo() // ~X2C + function _generarArchivo()// ~X2C { $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); } @@ -133,9 +130,9 @@ class Menu { * @return string * @access private */ - function _obtenerArchivo($directorio) // ~X2C + function _obtenerArchivo($directorio)// ~X2C { - $s = implode("", @file(PRE_DIR.$directorio.POST_DIR.MENU_SERIALIZADO)); + $s = implode("", @file($this->_configuracion['directorios']['root'].'/'.MENU_SERIALIZADO)); return unserialize($s); } // -X2C @@ -143,15 +140,14 @@ class Menu { // +X2C Operation 76 /** - * Funcion que obtiene el archivo de configuracion de secciones. + * Funcion que obtiene el arrayde configuracion de secciones. * * @return array * @access private */ - function _obtenerConfSecciones() // ~X2C + function _obtenerConfSecciones()// ~X2C { - $archivo = include SISTEMA_CONF_SECCIONES; - return $archivo; + return $this->_configuracion['secciones']; } // -X2C @@ -164,14 +160,14 @@ class Menu { * @return void * @access private */ - function _armarArraySecciones($confSec) // ~X2C + function _armarArraySecciones($confSec)// ~X2C { $linksel = $_SERVER['PHP_SELF']; $ultimo = 0; $cuenta = count ($confSec); $i = 1; foreach ($confSec as $sec) { - $tmp = new Seccion ($sec, $this->_directorio); + $tmp = new Seccion ($sec, $this->_configuracion); array_push($this->_componentes,$tmp->toHtml($linksel)); if ($cuenta == $i) { $ultimo = 1; @@ -191,24 +187,24 @@ class Menu { * @return void * @access private */ - function _serializarArraySecciones() // ~X2C + function _serializarArraySecciones()// ~X2C { - $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[$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[$hijo['nombre']],$PATH.'/'.$subhijo); } } } @@ -216,7 +212,8 @@ class Menu { } $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); } @@ -232,7 +229,7 @@ class Menu { * @return void * @access public */ - function agregarComponente($componente) // ~X2C + function agregarComponente($componente)// ~X2C { array_push($this->_componentes,$componente); } @@ -246,8 +243,8 @@ class Menu { * @return string * @access public */ - function toHtml() // ~X2C - { + function toHtml()// ~X2C + { return $this->_tabla->toHtml(); } // -X2C @@ -260,7 +257,7 @@ class Menu { * @return string * @access public */ - function menuToHtml() // ~X2C + function menuToHtml()// ~X2C { return $this->_menuHtml; }