X-Git-Url: https://git.llucax.com/mecon/meconlib.git/blobdiff_plain/5df0c5621bbee83b19a5ed01975135203dd33c34..cf1f71752ba7c60a275cd3671e17523624448720:/lib/MECON/Marco/Seccion.php
diff --git a/lib/MECON/Marco/Seccion.php b/lib/MECON/Marco/Seccion.php
index fc38697..426d0c1 100644
--- a/lib/MECON/Marco/Seccion.php
+++ b/lib/MECON/Marco/Seccion.php
@@ -1,58 +1,48 @@
-
-// +----------------------------------------------------------------------+
-//
-// $Id$
-// $Author$
-// $URL$
-// $Date$
-// $Rev$
-//
+
+-------------------------------------------------------------------------------
+$Id$
+-----------------------------------------------------------------------------*/
-// +X2C includes
-require_once 'MECON/Marco/Pagina.php';
-// ~X2C
-
-//Require Agregados por MMARRE, no pasan por el xmi2code
require_once 'MECON/Marco/ImagenAnimada.php';
require_once 'MECON/Marco/Menu.php';
require_once 'MECON/Marco/MenuHorizontal.php';
require_once 'MECON/Marco/MenuVertical.php';
require_once 'MECON/Marco/MenuOculto.php';
-
-// +X2C Class 16 :Seccion
/**
- * Clase seccion para el manejo de las secciones
+ * Clase para el manejo de las secciones
*
* @access public
*/
-class Seccion extends Pagina {
+class MECON_Marco_Seccion {
/**
* Nombre de la seccion.
*
* @var string $nombre
* @access private
*/
- var $_nombre;
+ var $_nombre = '';
/**
* Este es el nombre de la imagen
@@ -76,7 +66,7 @@ class Seccion extends Pagina {
* @var string $tipoMenu
* @access private
*/
- var $_tipoMenu;
+ var $_tipoMenu = '';
/**
* Array con la configuracion del sistema
@@ -84,62 +74,58 @@ class Seccion extends Pagina {
* @var array $configuracion
* @access private
*/
- var $_configuracion;
+ var $_configuracion = array();
/**
+ * Contiene el html del menu de la seccion
+ *
* @var string $menuHtml
* @access private
*/
- var $_menuHtml;
+ var $_menuHtml = '';
- // ~X2C
+ /**
+ * Nombre del archivo pagina.
+ *
+ * @var string $link
+ * @access private
+ */
+ var $_link = '';
- // +X2C Operation 63
/**
- * Constructor. Recibe como parametro el nombre de la seccion
+ * Recibe como parametro el nombre de la seccion
*
* @param array $seccion Array con la informacion de la seccion
* @param array $configuracion Array con la configuracion del sistema
*
* @return void
* @access public
- * @static
*/
- function Seccion($seccion, $configuracion)// ~X2C
+ function MECON_Marco_Seccion($seccion, $configuracion)
{
- if (array_key_exists('nombre',$seccion)) {
- $this->_nombre = $seccion['nombre'];
- }
- if (array_key_exists('imagenComun', $seccion))
- $imgComun = $seccion['imagenComun'];
- else
- unset($imgComun);
- if (array_key_exists('imagenMouseOn', $seccion))
- $imgMouseOn = $seccion['imagenMouseOn'];
- else
- unset($imgMouseOn);
- if (array_key_exists('imagenSelect', $seccion))
- $imgSelect = $seccion['imagenSelect'];
- else
- unset($imgSelect);
- $this->_imagen = new ImagenAnimada($imgComun, $imgMouseOn, $imgSelect, $configuracion['directorios']['imagenes']);
+ $this->_nombre = @strval($seccion['nombre']);
+ $imgComun = @strval($seccion['imagenComun']);
+ $imgMouseOn = @strval($seccion['imagenMouseOn']);
+ $imgSelect = @strval($seccion['imagenSelect']);
+ $this->_tipoMenu = @strval($seccion['tipoMenu']);
+ $this->_link = @strval($seccion['link']);
- if (array_key_exists('tipoMenu', $seccion)) {
- $this->_tipoMenu = $seccion['tipoMenu'];
- }
+ $this->_imagen = new MECON_Marco_ImagenAnimada( $imgComun,
+ $imgMouseOn,
+ $imgSelect,
+ $configuracion['directorios']['imagenes'],
+ $this->_nombre,
+ $configuracion['directorios']['root'].'/'.
+ $this->_link,
+ @strval($seccion['alt']));
if (!is_null($configuracion)) {
$this->_configuracion = $configuracion;
}
- if (array_key_exists('link', $seccion)) {
- parent::Pagina($seccion['link']);
- }
if (array_key_exists('hijos', $seccion)) {
$this->_cargarHijos($seccion['hijos']);
}
}
- // -X2C
- // +X2C Operation 64
/**
* Funcion que devuelve un string con el html a imprimir por pantalla.
*
@@ -148,31 +134,17 @@ class Seccion extends Pagina {
* @return string
* @access public
*/
- function toHtml($link_sel)// ~X2C
+ function toHtml($link_sel)
{
- if (isset($_SESSION['deshabilitar_links']) && $_SESSION['deshabilitar_links']) {
- $link_start = '';
- $link_end = '';
- $link_start2 = '';
- }
- else {
- $link_start = '';
- $link_start2 = '_nombre.'\',\'\',\''.$this->_imagen->_imgMouseOn.'\',1)>';
- $link_end = '';
+ if (!$this->_configuracion['links']) {
+ $this->_imagen->setHabilitada(false);
}
-
if ($this->verifSeccionSeleccionada($link_sel)) {
- $sec = $link_start."_nombre."\" src=\"".$this->_imagen->_imgSelect."\" border=\"0\" alt=\"".$this->_nombre."\">".$link_end;
- }
- else {
- $sec = $link_start2."_nombre."\" src=\"".$this->_imagen->_imgComun."\" border=\"0\" alt=\"".$this->_nombre."\">".$link_end;
+ $this->_imagen->setSeleccionada(true);
}
-
- return $sec;
+ return $this->_imagen->toHtml();
}
- // -X2C
- // +X2C Operation 84
/**
* Carga el array con los objetos hijos de la seccion
*
@@ -181,32 +153,32 @@ class Seccion extends Pagina {
* @return void
* @access private
*/
- function _cargarHijos($hijos)// ~X2C
+ function _cargarHijos($hijos)
{
if ($this->_tipoMenu == 'vertical'){
- $tmp = new MenuVertical($this->_configuracion);
+ $tmp = new MECON_Marco_MenuVertical($this->_configuracion);
}
elseif ($this->_tipoMenu == 'horizontal') {
- $tmp = new MenuHorizontal($this->_configuracion);
+ $tmp = new MECON_Marco_MenuHorizontal($this->_configuracion);
}
else {
- $tmp = new MenuOculto($this->_configuracion);
+ $tmp = new MECON_Marco_MenuOculto($this->_configuracion);
}
foreach ($hijos as $hijo) {
+ $hijo['alt'] = @$hijo['alt'] ? $hijo['alt'] : $hijo['nombre'];
+ $hijo['nombre'] = $this->_nombre.'-'.$hijo['nombre'];
$tmp->agregarComponente($hijo);
}
$this->_hijos = $tmp;
}
- // -X2C
- // +X2C Operation 127
/**
* Funcion que se encarga de desserializar el array asociativo paginas-secciones.
*
* @return void
* @access private
*/
- function _desSerializarArraySecciones()// ~X2C
+ function _desSerializarArraySecciones()
{
$file_cache = strtr($this->_configuracion['directorios']['root'],'/','_');
$tmp = $this->_configuracion['directorios_fs']['cache'].'/'.ARRAYSECCIONES_SERIALIZADO.'_'.$file_cache;
@@ -219,48 +191,46 @@ class Seccion extends Pagina {
return null;
}
}
- // -X2C
- // +X2C Operation 129
/**
- * Funcion que se encarga de verificar si la pagina a la cual se quiere acceder pertenece a la seccion que estoy dibujando. Se utiliza como agregado en toHtml.
-Devuelve 1 si pertenece a la seccion, en caso contrario 0.
+ * Funcion que se encarga de verificar si la pagina a la cual se quiere
+ * acceder pertenece a la seccion que estoy dibujando. Se utiliza como
+ * agregado en toHtml.
+ * Devuelve 1 si pertenece a la seccion, en caso contrario 0.
*
* @param string $link_sel Nombre de la pagina a la cual se quiere acceder.
*
* @return int
* @access public
*/
- function verifSeccionSeleccionada($link_sel)// ~X2C
+ function verifSeccionSeleccionada($link_sel)
{
$tmp = $this->_desSerializarArraySecciones();
$retorno = 0;
if (isset($tmp) && array_key_exists($this->_nombre,$tmp)) {
foreach ($tmp[$this->_nombre] as $t) {
- if ($link_sel == $t) {
+ if (rtrim($link_sel, '/') == rtrim($t, '/')) {
$retorno = 1;
}
}
}
return $retorno;
}
- // -X2C
-
-
-
- // +X2C Operation 202
+
/**
+ * Devuelve el html a mostrar en pantalla
+ *
* @param string $link_sel Nombre de la seccion seleccionada
* @param bool $ultimo Indica si es el ultimo componente del menu.....en caso de serlo, debe mostrar la imagen con codito
*
* @return string
* @access public
*/
- function toHtmlVertical($link_sel, $ultimo = false)// ~X2C
+ function toHtmlVertical($link_sel, $ultimo = false)
{
$style = "text-decoration:none";
- if (isset($_SESSION['deshabilitar_links']) && $_SESSION['deshabilitar_links']) {
+ if (!$this->_configuracion['links']) {
$link_start = '';
$link_end = '';
}
@@ -271,27 +241,16 @@ Devuelve 1 si pertenece a la seccion, en caso contrario 0.
$sec = array ();
if ($this->verifSeccionSeleccionada($link_sel)) {
- if ($ultimo) {
- $sec[] = $link_start.''.$link_end;
- }
- else {
- $sec[] = $link_start.''.$link_end;
- }
+ $sec[] = $link_start.''.$link_end;
}
else {
- if ($ultimo) {
- $sec[] = $link_start.''.$link_end;
- }
- else {
- $sec[] = $link_start.''.$link_end;
- }
+ $sec[] = $link_start.''.$link_end;
}
- $sec[] = ''.$link_start.' '.$this->_nombre.$link_end.'';
+ $nombre = strstr($this->_nombre, '-');
+ $nombre = substr($nombre, 1);
+ $sec[] = ''.$nombre.'
';
return $sec;
}
- // -X2C
-
-} // -X2C Class :Seccion
-
+}
?>
\ No newline at end of file