]> git.llucax.com Git - mecon/meconlib.git/blobdiff - lib/MECON/Marco/Menu.php
- Correccion de bugs
[mecon/meconlib.git] / lib / MECON / Marco / Menu.php
index 3b3224a448c4b6058ef39fdf18ac9c4a466a69d8..92bf5e7800bf8d2c41474ed247f3f88d9aa00dcb 100644 (file)
@@ -31,24 +31,32 @@ require_once 'HTML/Table.php';
 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.
  *
- * @package MECON_Marco
  * @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();
-
+    
     /**
-     * Array de array con los componentes del menu
+     * Array de array con los componentes del menu.
      *
      * @var    array $componentes
      * @access private
@@ -56,7 +64,8 @@ class MECON_Marco_Menu {
     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
@@ -64,7 +73,7 @@ class MECON_Marco_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
@@ -80,117 +89,173 @@ class MECON_Marco_Menu {
     var $_secciones = array();
 
     /**
+     * Array de array con los componentes del menu en caso de ser este vertical.
+     *
      * @var    string $componentesVertical
      * @access private
      */
     var $_componentesVertical = array();
-
-    // ~X2C
-
-    // +X2C Operation 56
+    
     /**
-     * Constructor. 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
      */
-    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->_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($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
      */
-    function _obtenerArchivo($directorio) // ~X2C
+    function _armarEncabezado($titulo) 
     {
-        $s = implode("", @file($this->_configuracion['directorios']['root'].'/'.MENU_SERIALIZADO));
-        return unserialize($s);
+        return '<div class="mecon_marco_subtitle">'.$titulo.'</div>';
     }
-    // -X2C
-
 
-    // +X2C Operation 76
     /**
-     * Funcion que obtiene el arrayde configuracion de secciones.
-     *
-     * @return array
-     * @access private
-     */
-    function _obtenerConfSecciones() // ~X2C
-    {
-        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.
+     * 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 MECON_Marco_Seccion ($sec, $this->_configuracion);         
-            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
-
+    
+    /**
+     * Funcion que se encarga de agregar componentes al array
+     *
+     * @param  array $componente Datos del componente de menu a agregar
+     *
+     * @return void
+     * @access public
+     */
+    function agregarComponente($componente) 
+    {
+        array_push($this->_componentes,$componente);
+    }
+    
+    /**
+     * Funcion que se encarga de devolver lo que se debe mostrar en pantalla
+     *
+     * @return string
+     * @access public
+     */
+    function toHtml() 
+    {
+        return $this->_tabla->toHtml();
+    }
+    
+    /**
+     * Devuelve el html del menu que hay que mostrar en pantalla
+     *
+     * @return string
+     * @access public
+     */
+    function menuToHtml() 
+    {
+        return $this->_menuHtml;
+    }
 
-    // +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 generar el archivo que despues sera utilizado 
+     * con la funcion EVAL.
      *
      * @return void
      * @access private
      */
-    function _serializarArraySecciones() // ~X2C
+    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();
@@ -203,15 +268,20 @@ class MECON_Marco_Menu {
             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']);
+                    $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($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);
@@ -220,52 +290,5 @@ class MECON_Marco_Menu {
         fputs($fp, $s);
         fclose($fp);
     }
-    // -X2C
-
-
-    // +X2C Operation 134
-    /**
-     * Funcion que se encarga de agregar componentes al array
-     *
-     * @param  array $componente Datos del componente de menu a agregar
-     *
-     * @return void
-     * @access public
-     */
-    function agregarComponente($componente) // ~X2C
-    {
-        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
-    {
-        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
-    {
-        return $this->_menuHtml;
-    }
-    // -X2C
-
-} // -X2C Class :MECON_Marco_Menu
-
+}
 ?>
\ No newline at end of file