-------------------------------------------------------------------------------
$Id$
-----------------------------------------------------------------------------*/
require_once 'MECON/Marco/Seccion.php';
require_once 'MECON/Marco/ImagenAnimada.php';
require_once 'HTML/Table.php';
define ('MENU_SERIALIZADO' , 'MenuSerializado');
define ('ARRAYSECCIONES_SERIALIZADO', 'ArraySeccionesSerializado');
/**
* Clase para el manejo de los menues y secciones de los sistemas.
*
* @access public
*/
class MECON_Marco_Menu {
/**
* 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.
*
* @var array $componentes
* @access private
*/
var $_componentes = array();
/**
* 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 $_tabla;
/**
* Variable que contiene el titulo de la seccion seleccionada.
*
* @var string $titulo
* @access private
*/
var $_titulo = '';
/**
* Array con los objetos seccion.
*
* @var array $secciones
* @access private
*/
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();
/**
* 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)
{
$this->_configuracion = $configuracion;
$this->_tabla =& new HTML_Table (
array (
'width' => '760',
'cellspacing' => '0',
'cellpadding' => '0',
'border' => '0',
)
);
}
/**
* Funcion que obtiene el array de configuracion de secciones.
*
* @return array
* @access private
*/
function _obtenerConfSecciones()
{
return $this->_configuracion['secciones'];
}
/**
* Devuelve un string con el encabezado de la seccion
*
* @param string $titulo Titulo de la seccion
*
* @return string
* @access private
*/
function _armarEncabezado($titulo)
{
return '
'.$titulo.'
';
}
/**
* 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)
{
$linksel = $_SERVER['PHP_SELF'];
$ultimo = 0;
$cuenta = count ($confSec);
$i = 1;
foreach ($confSec as $sec) {
//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);
}
$i++;
}
}
/**
* 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;
}
/**
* 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
*/
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);
}
}
?>