]> git.llucax.com Git - mecon/meconlib.git/blobdiff - lib/MECON/Marco/Menu.php
Se corrige un bug.
[mecon/meconlib.git] / lib / MECON / Marco / Menu.php
index a8277219a3d2601dc8abf99ed3e3ec63b09a7723..5b71ffc9b8ea06a4f07e07362af77366816a0fca 100644 (file)
 // $Rev$
 //
 
 // $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';
 
 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');
 
 define ('MENU_SERIALIZADO'          , 'MenuSerializado');
 define ('ARRAYSECCIONES_SERIALIZADO', 'ArraySeccionesSerializado');
 
@@ -42,12 +39,12 @@ define ('ARRAYSECCIONES_SERIALIZADO', 'ArraySeccionesSerializado');
  */
 class Menu {
     /**
  */
 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
      */
      * @access private
      */
-    var $_directorio;
+    var $_configuracion;
 
     /**
      * Array de array con los componentes del menu
 
     /**
      * 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.
      *
     /**
      * 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
      */
      *
      * @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->_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
 
     }
     // -X2C
 
@@ -118,7 +115,7 @@ class Menu {
     function _generarArchivo() // ~X2C
     {
         $s = serialize($this);
     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);
     }
         fputs($fp, $s);
         fclose($fp);
     }
@@ -135,7 +132,7 @@ class Menu {
      */
     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
         return unserialize($s);
     }
     // -X2C
@@ -143,15 +140,14 @@ class Menu {
 
     // +X2C Operation 76
     /**
 
     // +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
     {
      *
      * @return array
      * @access private
      */
     function _obtenerConfSecciones() // ~X2C
     {
-        $archivo = include SISTEMA_CONF_SECCIONES;
-        return $archivo;
+        return $this->_configuracion['secciones'];
     }
     // -X2C
 
     }
     // -X2C
 
@@ -171,7 +167,7 @@ class Menu {
         $cuenta = count ($confSec);
         $i = 1;
         foreach ($confSec as $sec) {
         $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;
             array_push($this->_componentes,$tmp->toHtml($linksel));
             if ($cuenta == $i) {
                 $ultimo = 1;
@@ -193,22 +189,22 @@ class Menu {
      */
     function _serializarArraySecciones() // ~X2C
     {
      */
     function _serializarArraySecciones() // ~X2C
     {
-        $secciones = include SISTEMA_CONF_SECCIONES;
+        $secciones = $this->_configuracion['secciones'];
         $tmp  = array();
         $tmp2 = array();
         
         $tmp  = array();
         $tmp2 = array();
         
-        $PATH = '/www/sistemas/'.$this->_directorio.'/www/';
+        $PATH = $this->_configuracion['directorios']['root'];
        
         foreach ($secciones as $sec) { //Chequeo las secciones
        
         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            
             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
                     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);
         }
         $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);
     }
         fputs($fp, $s);
         fclose($fp);
     }
@@ -247,7 +244,7 @@ class Menu {
      * @access public
      */
     function toHtml() // ~X2C
      * @access public
      */
     function toHtml() // ~X2C
-    {   
+    {
         return $this->_tabla->toHtml();
     }
     // -X2C
         return $this->_tabla->toHtml();
     }
     // -X2C
@@ -268,4 +265,4 @@ class Menu {
 
 } // -X2C Class :Menu
 
 
 } // -X2C Class :Menu
 
-?>
\ No newline at end of file
+?>