------------------------------------------------------------------------------- $Id$ -----------------------------------------------------------------------------*/ //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 :MECON_Marco_Seccion /** * Clase para el manejo de las secciones * * @package MECON_Marco * @access public */ class MECON_Marco_Seccion { /** * Nombre de la seccion. * * @var string $nombre * @access private */ var $_nombre = ''; /** * Este es el nombre de la imagen * * @var Imagen $imagen * @access private */ var $_imagen; /** * Hijos (menu) de la seccion. * * @var Menu $hijos * @access private */ var $_hijos; /** * Valor string del tipo de menu de la seccion * * @var string $tipoMenu * @access private */ var $_tipoMenu = ''; /** * Array con la configuracion del sistema * * @var array $configuracion * @access private */ var $_configuracion = array(); /** * Contiene el html del menu de la seccion * * @var string $menuHtml * @access private */ var $_menuHtml = ''; /** * Nombre del archivo pagina. * * @var string $link * @access private */ var $_link = ''; // ~X2C // +X2C Operation 63 /** * 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 */ function MECON_Marco_Seccion($seccion, $configuracion) // ~X2C { $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']); $this->_imagen = new MECON_Marco_ImagenAnimada( $imgComun, $imgMouseOn, $imgSelect, $configuracion['directorios']['imagenes'], $this->_nombre, $configuracion['directorios']['root'].'/'. $this->_link); if (!is_null($configuracion)) { $this->_configuracion = $configuracion; } 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. * * @param string $link_sel Indica la pagina a la cual se quiere acceder. * * @return string * @access public */ function toHtml($link_sel) // ~X2C { if (!$this->_configuracion['links']) { $this->_imagen->setHabilitada(false); } if ($this->verifSeccionSeleccionada($link_sel)) { $this->_imagen->setSeleccionada(true); } return $this->_imagen->toHtml(); } // -X2C // +X2C Operation 84 /** * Carga el array con los objetos hijos de la seccion * * @param array $hijos Array con los datos de los hijos de la seccion * * @return void * @access private */ function _cargarHijos($hijos) // ~X2C { if ($this->_tipoMenu == 'vertical'){ $tmp = new MECON_Marco_MenuVertical($this->_configuracion); } elseif ($this->_tipoMenu == 'horizontal') { $tmp = new MECON_Marco_MenuHorizontal($this->_configuracion); } else { $tmp = new MECON_Marco_MenuOculto($this->_configuracion); } foreach ($hijos as $hijo) { $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 { $file_cache = strtr($this->_configuracion['directorios']['root'],'/','_'); $tmp = $this->_configuracion['directorios_fs']['cache'].'/'.ARRAYSECCIONES_SERIALIZADO.'_'.$file_cache; if (file_exists($tmp)) { $s = implode("", @file($tmp)); return unserialize($s); } else { 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. * * @param string $link_sel Nombre de la pagina a la cual se quiere acceder. * * @return int * @access public */ function verifSeccionSeleccionada($link_sel) // ~X2C { $tmp = $this->_desSerializarArraySecciones(); $retorno = 0; if (isset($tmp) && array_key_exists($this->_nombre,$tmp)) { foreach ($tmp[$this->_nombre] as $t) { if ($link_sel == $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 { $style = "text-decoration:none"; if (!$this->_configuracion['links']) { $link_start = ''; $link_end = ''; } else { $link_start = ''; $link_end = ''; } $sec = array (); if ($this->verifSeccionSeleccionada($link_sel)) { if ($ultimo) { $sec[] = $link_start.''.$link_end; } else { $sec[] = $link_start.''.$link_end; } } else { if ($ultimo) { $sec[] = $link_start.''.$link_end; } else { $sec[] = $link_start.''.$link_end; } } $sec[] = ''.$link_start.'  '.$this->_nombre.$link_end.''; return $sec; } // -X2C } // -X2C Class :MECON_Marco_Seccion ?>