2 // vim: set expandtab tabstop=4 softtabstop=4 shiftwidth=4:
3 // +--------------------------------------------------------------------+
5 // +--------------------------------------------------------------------+
6 // | Libreria para la estandarizacion de los elementos html de los |
8 // | Ministerio de EconomÃa |
9 // +--------------------------------------------------------------------+
10 // | Creado: fri mar 21 ART 2003 |
11 // | Autor: Martin Marrese <mmarre@mecon.gov.ar> |
12 // +--------------------------------------------------------------------+
21 require_once 'HTML/Table.php';
26 * Libreria para le manejo de las tablas de los sistemas de intranet.
32 class Tabla extends HTML_Table {
35 * Valores de Configuracion particular
42 * Atributos de las tablas.
51 * Puede recibir como parametro un string con los atributos que se
52 * quieren dar a la tabla en cuestion. Estos atributos estan
53 * seteados por default segun el archivo de configuracion.
55 * @param $atributos Atributos diferentes a los estandares para la
60 function Tabla($attrs = '')
62 $this->_conf = include 'Tabla/conf_Tabla.php'; // Obtengo los valores particulares de configuracion
63 // Seteo los atributos para la tabla
64 $this->_attrs = $this->_parseAttributes($this->_conf['atributos']['tabla_comun']);
65 //Genero el objeto HTML_Table
67 $tmp = $this->_parseAttributes($attrs);
68 if (isset($tmp['width'])) {
69 $this->_attrs['width'] = $tmp['width'];
71 if (isset($tmp['bgcolor'])) {
72 $this->_attrs['bgcolor'] = $tmp['bgcolor'];
74 if (isset($tmp['cellspacing'])) {
75 $this->_attrs['cellspacing'] = $tmp['cellspacing'];
77 if (isset($tmp['cellpadding'])) {
78 $this->_attrs['cellpadding'] = $tmp['cellpadding'];
81 $this->HTML_Table($this->_attrs);
82 //Modifico los atributos de todas las tablas
83 //Hay que encontrar o hacer una funcion que setee los atributos para las futuras
88 * Agrega una fila del tipo Cabecera
90 * Agrega una fila del tipo cabecera, tomando colores y demas del
91 * archivo de configuracion. Recibe como parametro un array con
92 * los datos a incluir en la linea. Agrega tantas columnas como
93 * elementos tenga el array. Si no recibe parametro alguno,
94 * inserta una fila en blanco. Devuelve el identificador de la
95 * fila en donde inserto los datos.
97 * @param $contenido Contenido de la fila
99 * @return int Identificador de Linea
104 function agregarFilaCabecera($contenido = '', $atributos = '')
106 return $this->addRow($contenido, 'cabecera');
110 * Agrega una fila del tipo Comun
112 * Agrega una fila del tipo comun, tomando colores y demas del
113 * archivo de configuracion. Recibe como parametro un array con
114 * los datos a incluir en la linea. Agrega tantas columnas como
115 * elementos tenga el array. Si no recibe parametro alguno,
116 * inserta una fila en blanco. Devuelve el identificador de la
117 * fila en donde inserto los datos.
119 * @param $contenido Contenido de la fila
121 * @return int Identificador de Linea
126 function agregarFila($contenido = '')
128 return $this->addRow($contenido, 'comun');
132 * Modifica el atributo rowSpan a la celda pasada por parametro
135 * @param int $columna
141 function rowSpan($fila, $columna, $valor)
143 return $this->updateCellAttributes($fila, $columna, 'rowspan="'.$valor.'"');
147 * Modifica el atributo colSpan a la celda pasada por parametro
150 * @param int $columna
156 function colSpan($fila, $columna, $valor)
158 return $this->updateCellAttributes($fila, $columna, 'colspan="'.$valor.'"');
162 * Modifica el atributo aling de la celda pasada por parametro
165 * @param int $columna
166 * @param string $valor (left, center, right...)
171 function align($fila, $columna, $valor)
173 return $this->updateCellAttributes($fila, $columna, 'align="'.$valor.'"');
177 * Setea una columna como del tipo cabecera
179 * @param int $columna
184 function setColCabecera($columna)
186 return $this->updateColAttributes($columna, 'cabecera');
190 * Setea una columna como del tipo titulo
192 * @param int $columna
197 function setColTitulo($columna)
199 return $this->updateColAttributes($columna, 'titulo');
203 * Alinea una columna entera
205 * @param int $columna
206 * @param string $valor
211 function setColAlign($columna, $valor)
213 return $this->updateColAttributes($columna,'align="'.$valor.'"');
217 * Cambia el tamanio de una columna entera
219 * @param int $columna
220 * @param string $valor
225 function setColWidth($columna, $valor)
227 return $this->updateColAttributes($columna,'width="'.$valor.'"');
231 * Cambia el color de fondo de una celda
234 * @param int $columna
235 * @param string $valor
240 function setCellBgcolor($fila, $columna, $valor)
242 return $this->updateCellAttributes($fila, $columna,'bgcolor="'.$valor.'"');
246 * Devuelve el html de la tabla
248 * Devuelve el html de la tabla para que sea mostrado.
249 * Como parametro recibe el indicador de tabla simple.
250 * Si $simple es falso, devuelve el html comun y corriente (con 2
251 * tablas), si es false devuelve una tabla sola.
253 * @param bool $simple
255 * @return string Html
259 function toHtml($simple = 0)
261 // Agregar la tabla de fondo.
263 $tmp = $this->_parseAttributes($this->_conf['atributos']['tabla_contenedora']);
264 $tmp['width'] = $this->_attrs['width'];
265 $tabla_externa = new HTML_Table($tmp);
266 $tabla_externa->setCellContents(0, 0, parent::toHtml());
267 $tabla_externa->setCellAttributes(0, 0, $this->_conf['atributos']['celda_comun']);
268 $result = $tabla_externa->toHtml();
271 $result = parent::toHtml();
278 * Cambia las propiedades de una celda
280 * Cambia las propiedades de una celda. Si $attrs es un array
281 * asociativo, se setean los atributos representados por las claves
286 * @param mixed $attrs
290 function updateCellAttributes($row, $col, $attrs)
292 return parent::updateCellAttributes($row, $col, $this->_translateAttributes($attrs));
296 * Establece las propiedades de una celda
298 * Establece las propiedades de una celda. Si $attrs es un array
299 * asociativo, se setean los atributos representados por las claves
304 * @param mixed $attrs
308 function setCellAttributes($row, $col, $attrs)
310 return parent::setCellAttributes($row, $col, $this->_translateAttributes($attrs));
316 * Agrega una fila. El contenido es el que viene representado por
317 * el array $content. Recibe los atributos en la variable $attrs
319 * @param mixed $content
320 * @param mixed $attrs
326 function addRow($content, $attrs = 'comun')
328 return parent::addRow($content, $attrs);
332 * Convierte un atributo a string
334 * Convierte un atributo HTML al string para pasar a los metodos de HTML_Table
335 * Recibe en $attrs los atributos a modificar.
337 * @param string $attrs
342 function _translateAttributes($attrs)
347 if (is_string($attrs)) {
348 $attrs = $this->_parseAttributes($attrs);
351 $rta = $this->_conf['atributos']['celda_comun'];
353 foreach ($attrs as $attr => $val) {
354 $attr = strtolower($attr);
360 #$sin_estilo = false;
361 $rta = array_merge($rta, $this->_conf['atributos']["celda_$attr"]);
378 $rta["cell$attr"] = $val;
385 trigger_error("No se permite setear el atributo $attr", E_USER_ERROR);
388 // Si no tiene estilo, agrego estilo comun.
390 #$rta = $this->_conf['atributos']['celda_comun'];