]> git.llucax.com Git - mecon/meconlib.git/blobdiff - lib/MECON/Marco/Menu.php
BugFix.
[mecon/meconlib.git] / lib / MECON / Marco / Menu.php
index 4ffe45882b2da8f989f7f79eaa376bd0697d83df..92bf5e7800bf8d2c41474ed247f3f88d9aa00dcb 100644 (file)
@@ -31,24 +31,32 @@ require_once 'HTML/Table.php';
 define ('MENU_SERIALIZADO'          , 'MenuSerializado');
 define ('ARRAYSECCIONES_SERIALIZADO', 'ArraySeccionesSerializado');
 
 define ('MENU_SERIALIZADO'          , 'MenuSerializado');
 define ('ARRAYSECCIONES_SERIALIZADO', 'ArraySeccionesSerializado');
 
-// +X2C Class 14 :MECON_Marco_Menu
 /**
  * Clase para el manejo de los menues y secciones de los sistemas.
  *
 /**
  * Clase para el manejo de los menues y secciones de los sistemas.
  *
- * @package MECON_Marco
  * @access public
  */
 class MECON_Marco_Menu {
     /**
  * @access public
  */
 class MECON_Marco_Menu {
     /**
-     * Array con la configuracion de las secciones del sistema;.
+     * Array con los resultados para agregar a la pagina.
+     * Sobre este array MECON_Marco realiza un foreach para agregar lo que
+     * corresponda.
+     *
+     * @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 $_configuracion = array();
      *
      * @var    array $configuracion
      * @access private
      */
     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    array $componentes
      * @access private
@@ -56,7 +64,8 @@ class MECON_Marco_Menu {
     var $_componentes = array();
 
     /**
     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
      *
      * @var    table $tabla
      * @access private
@@ -64,7 +73,7 @@ class MECON_Marco_Menu {
     var $_tabla;
 
     /**
     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    string $titulo
      * @access private
@@ -80,95 +89,68 @@ class MECON_Marco_Menu {
     var $_secciones = array();
 
     /**
     var $_secciones = array();
 
     /**
-     * Array de array con los componentes del menu en caso de ser este vertical
+     * Array de array con los componentes del menu en caso de ser este vertical.
      *
      * @var    string $componentesVertical
      * @access private
      */
     var $_componentesVertical = array();
      *
      * @var    string $componentesVertical
      * @access private
      */
     var $_componentesVertical = array();
-
-    // ~X2C
-
-    // +X2C Operation 56
+    
     /**
     /**
-     * Recibe como parametro el directorio en donde se encuentra el sistema.
+     * Recibe como parametro la configuracion del sistema.
      *
      * @param  array $configuracion Array con los datos de las secciones
      *
      * @return void
      * @access public
      */
      *
      * @param  array $configuracion Array con los datos de las secciones
      *
      * @return void
      * @access public
      */
-    function MECON_Marco_Menu($configuracion = null) // ~X2C
+    function MECON_Marco_Menu($configuracion = null) 
     {
     {
-        $this->_tabla = new HTML_Table('width=760 
-                                        align="center" 
-                                        bgcolor="#FFFFFF" 
-                                        cellspacing="0" 
-                                        cellpadding="0" 
-                                        border="0"');
-        $this->_tabla->setLineEnd('');
-        $this->_tabla->setTab('');
-        
         $this->_configuracion = $configuracion;
         $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
      */
      * @access private
      */
-    function _generarArchivo() // ~X2C
+    function _obtenerConfSecciones() 
     {
     {
-        $s = serialize($this);
-        $fp = fopen($this->_configuracion['directorios']['root'].'/'.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
      */
      *
      * @return string
      * @access private
      */
-    function _obtenerArchivo($directorio) // ~X2C
+    function _armarEncabezado($titulo) 
     {
     {
-        $s = implode("", @file($this->_configuracion['directorios']['root'].'/'.MENU_SERIALIZADO));
-        return unserialize($s);
-    }
-    // -X2C
-
-
-    // +X2C Operation 76
-    /**
-     * Funcion que obtiene el array de configuracion de secciones.
-     *
-     * @return array
-     * @access private
-     */
-    function _obtenerConfSecciones() // ~X2C
-    {
-        return $this->_configuracion['secciones'];
+        return '<div class="mecon_marco_subtitle">'.$titulo.'</div>';
     }
     }
-    // -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
      */
      *
      * @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;
     {
         $linksel = $_SERVER['PHP_SELF'];
         $ultimo = 0;
@@ -187,60 +169,18 @@ class MECON_Marco_Menu {
             }
             if ($ver) {
                 $tmp = new MECON_Marco_Seccion ($sec, $this->_configuracion);         
             }
             if ($ver) {
                 $tmp = new MECON_Marco_Seccion ($sec, $this->_configuracion);         
-                array_push($this->_componentes,$tmp->toHtml($linksel));
+                array_push($this->_componentes, $tmp->toHtml($linksel));
                 if ($cuenta == $i) {
                     $ultimo = 1;
                 }
                 if ($cuenta == $i) {
                     $ultimo = 1;
                 }
-                array_push($this->_componentesVertical, $tmp->toHtmlVertical($linksel,$ultimo));
+                array_push($this->_componentesVertical, 
+                        $tmp->toHtmlVertical($linksel,$ultimo));
                 array_push($this->_secciones,$tmp);
             }
             $i++;
         }
     }
                 array_push($this->_secciones,$tmp);
             }
             $i++;
         }
     }
-    // -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 = $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[$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);
-                        }
-                    }
-                }
-            }
-        }
-        $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);
-    }
-    // -X2C
-
-
-    // +X2C Operation 134
+    
     /**
      * Funcion que se encarga de agregar componentes al array
      *
     /**
      * Funcion que se encarga de agregar componentes al array
      *
@@ -249,55 +189,106 @@ class MECON_Marco_Menu {
      * @return void
      * @access public
      */
      * @return void
      * @access public
      */
-    function agregarComponente($componente) // ~X2C
+    function agregarComponente($componente) 
     {
         array_push($this->_componentes,$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
      */
     /**
      * 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();
     }
     {
         return $this->_tabla->toHtml();
     }
-    // -X2C
-
-
-    // +X2C Operation 151
+    
     /**
      * Devuelve el html del menu que hay que mostrar en pantalla
      *
      * @return string
      * @access public
      */
     /**
      * Devuelve el html del menu que hay que mostrar en pantalla
      *
      * @return string
      * @access public
      */
-    function menuToHtml() // ~X2C
+    function menuToHtml() 
     {
         return $this->_menuHtml;
     }
     {
         return $this->_menuHtml;
     }
-    // -X2C
 
 
-    // +X2C Operation 222
     /**
     /**
-     * Devuelve un string con el encabezado de la seccion
+     * Funcion que se encarga de generar el archivo que despues sera utilizado 
+     * con la funcion EVAL.
      *
      *
-     * @param  string $titulo Titulo de la seccion
+     * @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
      */
      *
      * @return string
      * @access private
      */
-    function _armarEncabezado($titulo) // ~X2C
+    function _obtenerArchivo($directorio) 
     {
     {
-        return '<font face="Arial, Helvetica, sans-serif" size="3" color="#336699"><b>'.$titulo.'</b></font>';
+        $s = implode("", @file($this->_configuracion['directorios']['root'].'/'.MENU_SERIALIZADO));
+        return unserialize($s);
     }
     }
-    // -X2C
-
-} // -X2C Class :MECON_Marco_Menu
-
+    
+    /**
+     * 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
 ?>
\ No newline at end of file