1 <?php /* vim: set binary expandtab tabstop=4 shiftwidth=4 textwidth=80:
2 -------------------------------------------------------------------------------
5 -------------------------------------------------------------------------------
6 This file is part of meconlib.
8 meconlib is free software; you can redistribute it and/or modify it under
9 the terms of the GNU General Public License as published by the Free
10 Software Foundation; either version 2 of the License, or (at your option)
13 meconlib is distributed in the hope that it will be useful, but WITHOUT
14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
15 FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License; if not,
18 write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
19 Boston, MA 02111-1307 USA
20 -------------------------------------------------------------------------------
21 Creado: fri mar 21 ART 2003
22 Autor: Martin Marrese <mmarre@mecon.gov.ar>
23 -------------------------------------------------------------------------------
25 -----------------------------------------------------------------------------*/
27 require_once 'HTML/Table.php';
32 * Libreria para le manejo de las tablas de los sistemas de intranet.
38 class Tabla extends HTML_Table {
41 * Valores de Configuracion particular
48 * Atributos de las tablas.
57 * Puede recibir como parametro un string con los atributos que se
58 * quieren dar a la tabla en cuestion. Estos atributos estan
59 * seteados por default segun el archivo de configuracion.
61 * @param mixed $atributos Atributos diferentes a los estandares para la
63 * @param string $estilo Tipo de tabla. (comun, servicio)
67 function Tabla($attrs = null, $estilo = 'comun')
69 $this->_conf = include 'MECON/HTML/Tabla/estilo_'.$estilo.'.php'; // Obtengo los valores particulares de configuracion
70 // Seteo los atributos para la tabla
71 $this->_attrs = $this->_conf['atributos']['tabla_comun'];
72 //Genero el objeto HTML_Table
73 if (is_string($attrs)) {
74 $attrs = $this->_parseAttributes($attrs);
76 if (is_array($attrs)) {
77 if (isset($attrs['width'])) {
78 $this->_attrs['width'] = $attrs['width'];
80 if (isset($attrs['bgcolor'])) {
81 $this->_attrs['bgcolor'] = $attrs['bgcolor'];
83 if (isset($attrs['cellspacing'])) {
84 $this->_attrs['cellspacing'] = $attrs['cellspacing'];
86 if (isset($attrs['cellpadding'])) {
87 $this->_attrs['cellpadding'] = $attrs['cellpadding'];
90 $this->HTML_Table($this->_attrs);
94 * Agrega una fila del tipo Cabecera
96 * Agrega una fila del tipo cabecera, tomando colores y demas del
97 * archivo de configuracion. Recibe como parametro un array con
98 * los datos a incluir en la linea. Agrega tantas columnas como
99 * elementos tenga el array. Si no recibe parametro alguno,
100 * inserta una fila en blanco. Devuelve el identificador de la
101 * fila en donde inserto los datos.
103 * @param $contenido Contenido de la fila
105 * @return int Identificador de Linea
110 function agregarFilaCabecera($contenido = '', $atributos = '')
112 return $this->addRow($contenido, 'cabecera');
116 * Agrega una fila del tipo Comun
118 * Agrega una fila del tipo comun, tomando colores y demas del
119 * archivo de configuracion. Recibe como parametro un array con
120 * los datos a incluir en la linea. Agrega tantas columnas como
121 * elementos tenga el array. Si no recibe parametro alguno,
122 * inserta una fila en blanco. Devuelve el identificador de la
123 * fila en donde inserto los datos.
125 * @param $contenido Contenido de la fila
127 * @return int Identificador de Linea
132 function agregarFila($contenido = '')
134 return $this->addRow($contenido, 'comun');
138 * Modifica el atributo rowSpan a la celda pasada por parametro
141 * @param int $columna
147 function rowSpan($fila, $columna, $valor)
149 return $this->updateCellAttributes($fila, $columna, 'rowspan="'.$valor.'"');
153 * Modifica el atributo colSpan a la celda pasada por parametro
156 * @param int $columna
162 function colSpan($fila, $columna, $valor)
164 return $this->updateCellAttributes($fila, $columna, 'colspan="'.$valor.'"');
168 * Modifica el atributo aling de la celda pasada por parametro
171 * @param int $columna
172 * @param string $valor (left, center, right...)
177 function align($fila, $columna, $valor)
179 return $this->updateCellAttributes($fila, $columna, 'align="'.$valor.'"');
183 * Setea una columna como del tipo cabecera
185 * @param int $columna
190 function setColCabecera($columna)
192 return $this->updateColAttributes($columna, 'cabecera');
196 * Setea una columna como del tipo titulo
198 * @param int $columna
203 function setColTitulo($columna)
205 return $this->updateColAttributes($columna, 'titulo');
209 * Alinea una columna entera
211 * @param int $columna
212 * @param string $valor
217 function setColAlign($columna, $valor)
219 return $this->updateColAttributes($columna,'align="'.$valor.'"');
223 * Cambia el tamanio de una columna entera
225 * @param int $columna
226 * @param string $valor
231 function setColWidth($columna, $valor)
233 return $this->updateColAttributes($columna,'width="'.$valor.'"');
237 * Cambia el color de fondo de una celda
240 * @param int $columna
241 * @param string $valor
246 function setCellBgcolor($fila, $columna, $valor)
248 return $this->updateCellAttributes($fila, $columna,'bgcolor="'.$valor.'"');
252 * Devuelve el html de la tabla
254 * Devuelve el html de la tabla para que sea mostrado.
255 * Como parametro recibe el indicador de tabla simple.
256 * Si $simple es falso, devuelve el html comun y corriente (con 2
257 * tablas), si es false devuelve una tabla sola.
259 * @param bool $simple
261 * @return string Html
265 function toHtml($simple = 0)
267 // Agregar la tabla de fondo.
269 $result = parent::toHtml();
271 $contenedora = $this->_conf['atributos']['tabla_contenedora'];
272 $contenedora['width'] = $this->getAttribute('width');
273 $this->updateAttributes(array('width' => '100%'));
274 $tabla_externa = new HTML_Table($contenedora);
275 $tabla_externa->addRow(array(parent::toHtml()),
276 $this->_conf['atributos']['celda_contenedora']);
277 $result = $tabla_externa->toHtml();
284 * Cambia las propiedades de una celda
286 * Cambia las propiedades de una celda. Si $attrs es un array
287 * asociativo, se setean los atributos representados por las claves
292 * @param mixed $attrs
296 function updateCellAttributes($row, $col, $attrs)
298 return parent::updateCellAttributes($row, $col, $this->_translateAttributes($attrs));
302 * Establece las propiedades de una celda
304 * Establece las propiedades de una celda. Si $attrs es un array
305 * asociativo, se setean los atributos representados por las claves
310 * @param mixed $attrs
314 function setCellAttributes($row, $col, $attrs)
316 return parent::setCellAttributes($row, $col, $this->_translateAttributes($attrs));
322 * Agrega una fila. El contenido es el que viene representado por
323 * el array $content. Recibe los atributos en la variable $attrs
325 * @param mixed $content
326 * @param mixed $attrs
332 function addRow($content, $attrs = 'comun')
334 return parent::addRow($content, $attrs);
338 * Convierte un atributo a string
340 * Convierte un atributo HTML al string para pasar a los metodos de HTML_Table
341 * Recibe en $attrs los atributos a modificar.
343 * @param string $attrs
348 function _translateAttributes($attrs)
353 if (is_string($attrs)) {
354 $attrs = $this->_parseAttributes($attrs);
357 $rta = $this->_conf['atributos']['celda_comun'];
359 foreach ($attrs as $attr => $val) {
360 $attr = strtolower($attr);
366 #$sin_estilo = false;
367 $rta = array_merge($rta, $this->_conf['atributos']["celda_$attr"]);
385 $rta["cell$attr"] = $val;
391 trigger_error("No se permite setear el atributo $attr", E_USER_ERROR);
394 // Si no tiene estilo, agrego estilo comun.
396 #$rta = $this->_conf['atributos']['celda_comun'];