-<?php
-// vim: set expandtab tabstop=4 softtabstop=4 shiftwidth=4:
-// +----------------------------------------------------------------------+
-// | PHP Version 4 |
-// +----------------------------------------------------------------------+
-// | Copyright (c) 1997-2003 The PHP Group |
-// +----------------------------------------------------------------------+
-// | This source file is subject to version 2.02 of the PHP license, |
-// | that is bundled with this package in the file LICENSE, and is |
-// | available at through the world-wide-web at |
-// | http://www.php.net/license/2_02.txt. |
-// | If you did not receive a copy of the PHP license and are unable to |
-// | obtain it through the world-wide-web, please send a note to |
-// | license@php.net so we can mail you a copy immediately. |
-// +----------------------------------------------------------------------+
-// | Created: Mon Apr 14 16:23:22 2003
-// | Author: Martin Marrese <mmarre@mecon.gov.ar>
-// +----------------------------------------------------------------------+
-//
-// $Id$
-// $Author$
-// $URL$
-// $Date$
-// $Rev$
-//
+<?php /* vim: set binary expandtab tabstop=4 shiftwidth=4 textwidth=80:
+-------------------------------------------------------------------------------
+ Ministerio de EconomÃa
+ meconlib
+-------------------------------------------------------------------------------
+This file is part of meconlib.
+
+meconlib is free software; you can redistribute it and/or modify it under
+the terms of the GNU General Public License as published by the Free
+Software Foundation; either version 2 of the License, or (at your option)
+any later version.
+
+meconlib is distributed in the hope that it will be useful, but WITHOUT
+ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
+FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
+
+You should have received a copy of the GNU General Public License; if not,
+write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
+Boston, MA 02111-1307 USA
+-------------------------------------------------------------------------------
+Creado: Mon Apr 14 16:23:22 2003
+Autor: Martin Marrese <mmarre@mecon.gov.ar>
+-------------------------------------------------------------------------------
+$Id$
+-----------------------------------------------------------------------------*/
require_once 'MECON/Marco/Seccion.php';
require_once 'MECON/Marco/ImagenAnimada.php';
define ('MENU_SERIALIZADO' , 'MenuSerializado');
define ('ARRAYSECCIONES_SERIALIZADO', 'ArraySeccionesSerializado');
-// +X2C Class 14 :Menu
/**
* Clase para el manejo de los menues y secciones de los sistemas.
*
* @access public
*/
-class Menu {
+class MECON_Marco_Menu {
/**
* Array con la configuracion de las secciones del sistema;.
*
* @var array $configuracion
* @access private
*/
- var $_configuracion;
+ var $_configuracion = array();
/**
* Array de array con los componentes del menu
* @var array $componentes
* @access private
*/
- var $_componentes;
+ var $_componentes = array();
/**
* Variable que contiene la tabla general de menues que se va a mostrar en pantalla
* @var string $titulo
* @access private
*/
- var $_titulo;
+ var $_titulo = '';
/**
* Array con los objetos seccion.
* @var array $secciones
* @access private
*/
- var $_secciones;
+ var $_secciones = array();
/**
+ * Array de array con los componentes del menu en caso de ser este vertical
+ *
* @var string $componentesVertical
* @access private
*/
- var $_componentesVertical;
-
- // ~X2C
+ var $_componentesVertical = array();
- // +X2C Operation 56
/**
- * Constructor. Recibe como parametro el directorio en donde se encuentra el sistema.
+ * Recibe como parametro el directorio en donde se encuentra el sistema.
*
* @param array $configuracion Array con los datos de las secciones
*
* @return void
* @access public
*/
- function Menu($configuracion = null)// ~X2C
+ function MECON_Marco_Menu($configuracion = null)
{
- $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->_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;
}
- // -X2C
- // +X2C Operation 57
/**
* Funcion que se encarga de generar el archivo que despues sera utilizado con la funcion EVAL.
*
* @return void
* @access private
*/
- function _generarArchivo()// ~X2C
+ function _generarArchivo()
{
$s = serialize($this);
$fp = fopen($this->_configuracion['directorios']['root'].'/'.MENU_SERIALIZADO,'w');
fputs($fp, $s);
fclose($fp);
}
- // -X2C
-
- // +X2C Operation 58
+
/**
* Funcion que se encarga de obtener el archivo con los datos del objeto para ser utilizado con la funcion EVAL.
*
* @return string
* @access private
*/
- function _obtenerArchivo($directorio)// ~X2C
+ function _obtenerArchivo($directorio)
{
$s = implode("", @file($this->_configuracion['directorios']['root'].'/'.MENU_SERIALIZADO));
return unserialize($s);
}
- // -X2C
-
-
- // +X2C Operation 76
+
/**
- * Funcion que obtiene el arrayde configuracion de secciones.
+ * Funcion que obtiene el array de configuracion de secciones.
*
* @return array
* @access private
*/
- function _obtenerConfSecciones()// ~X2C
+ function _obtenerConfSecciones()
{
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.
*
* @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 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
-
-
- // +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 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
+ function _serializarArraySecciones()
{
$secciones = $this->_configuracion['secciones'];
$tmp = array();
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);
fputs($fp, $s);
fclose($fp);
}
- // -X2C
-
-
- // +X2C Operation 134
+
/**
* Funcion que se encarga de agregar componentes al array
*
* @return void
* @access public
*/
- function agregarComponente($componente)// ~X2C
+ function agregarComponente($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
*/
- function toHtml()// ~X2C
+ function toHtml()
{
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
+ function menuToHtml()
{
return $this->_menuHtml;
}
- // -X2C
-
-} // -X2C Class :Menu
+ /**
+ * Devuelve un string con el encabezado de la seccion
+ *
+ * @param string $titulo Titulo de la seccion
+ *
+ * @return string
+ * @access private
+ */
+ function _armarEncabezado($titulo)
+ {
+ return '<font face="Arial, Helvetica, sans-serif" size="3" color="#336699"><b>'.$titulo.'</b></font>';
+ }
+}
?>
\ No newline at end of file