]> git.llucax.com Git - mecon/meconlib.git/blobdiff - lib/MECON/Marco/Menu.php
Bug Fixes para que se vea bien en el netscape.
[mecon/meconlib.git] / lib / MECON / Marco / Menu.php
index d73124ff859637d70ac5f1f11bc14919ebafb0d0..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" 
-                                        cellspacing="0" 
-                                        cellpadding="0" 
-                                        border="0"
-                                        bgcolor="#FFFFFF"');
-        $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
-    {
-        $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
+    function _armarEncabezado($titulo) 
     {
     {
-        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,27 +169,93 @@ 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
-
+    
+    /**
+     * 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 _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
      */
      *
      * @return void
      * @access private
      */
-    function _serializarArraySecciones() // ~X2C
+    function _serializarArraySecciones() 
     {
         $secciones = $this->_configuracion['secciones'];
         $tmp  = array();
     {
         $secciones = $this->_configuracion['secciones'];
         $tmp  = array();
@@ -242,67 +290,5 @@ class MECON_Marco_Menu {
         fputs($fp, $s);
         fclose($fp);
     }
         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 Operation 222
-    /**
-     * Devuelve un string con el encabezado de la seccion
-     *
-     * @param  string $titulo Titulo de la seccion
-     *
-     * @return string
-     * @access private
-     */
-    function _armarEncabezado($titulo) // ~X2C
-    {
-        return '<font face="Arial, Helvetica, sans-serif" size="3" color="#336699"><b>'.$titulo.'</b></font>';
-    }
-    // -X2C
-
-} // -X2C Class :MECON_Marco_Menu
-
+}
 ?>
\ No newline at end of file
 ?>
\ No newline at end of file