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 * Objeto tabla que voy a utilizar
44 * @var Object HTML_Table
49 * Atributos de las tablas.
58 * Puede recibir como parametro un string con los atributos que se
59 * quieren dar a la tabla en cuestion. Estos atributos estan
60 * seteados por default segun el archivo de configuracion.
62 * @param $atributos Atributos diferentes a los estandares para la
67 function Tabla ($atributos = '')
69 $this->_conf = include 'Tabla/conf_Tabla.php'; // Obtengo los valores particulares de configuracion
70 // Seteo los atributos para la tabla
71 $this->_atribTabla = $this->_parseAttributes($this->_conf['atributos']['tabla_comun']);
72 //Genero el objeto HTML_Table
73 if ($atributos != '') {
74 $tmp = $this->_parseAttributes($atributos);
75 if (isset($tmp['width'])) {
76 $this->_atribTabla['width'] = $tmp['width'];
78 if (isset($tmp['bgcolor'])) {
79 $this->_atribTabla['bgcolor'] = $tmp['bgcolor'];
81 if (isset($tmp['cellspacing'])) {
82 $this->_atribTabla['cellspacing'] = $tmp['cellspacing'];
84 if (isset($tmp['cellpadding'])) {
85 $this->_atribTabla['cellpadding'] = $tmp['cellpadding'];
88 $this->HTML_Table($this->_atribTabla);
89 //Modifico los atributos de todas las tablas
90 //Hay que encontrar o hacer una funcion que setee los atributos para las futuras
95 * Agrega una fila del tipo Cabecera
97 * Agrega una fila del tipo cabecera, tomando colores y demas del
98 * archivo de configuracion. Recibe como parametro un array con
99 * los datos a incluir en la linea. Agrega tantas columnas como
100 * elementos tenga el array. Si no recibe parametro alguno,
101 * inserta una fila en blanco. Devuelve el identificador de la
102 * fila en donde inserto los datos.
104 * @param $contenido Contenido de la fila
106 * @return int Identificador de Linea
110 function agregarFilaCabecera ($contenido = '', $atributos = '')
112 return $this->addRow($contenido, $this->_conf['atributos']['celda_cabecera'],'TH');
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
131 function agregarFila ($contenido = '')
133 return $this->addRow($contenido,$this->_conf['atributos']['celda_comun']);
138 * Modifica el atributo rowSpan a la celda pasada por parametro
141 * @param int $columna
146 function rowSpan ($fila, $columna, $valor)
148 return $this->updateCellAttributes($fila, $columna, 'rowspan='.$valor);
152 * Modifica el atributo colSpan a la celda pasada por parametro
155 * @param int $columna
160 function colSpan ($fila, $columna, $valor)
162 return $this->updateCellAttributes($fila, $columna, 'colspan='.$valor);
166 * Modifica el atributo aling de la celda pasada por parametro
169 * @param int $columna
170 * @param string $valor (left, center, right...)
174 function align ($fila, $columna, $valor)
176 return $this->updateCellAttributes($fila, $columna, 'align="'.$valor.'"');
180 * Setea una columna como del tipo cabecera
182 * @param int $columna
186 function setColCabecera ($columna)
188 return $this->updateColAttributes($columna,$this->_conf['atributos']['celda_cabecera']);
192 * Setea una columna como del tipo titulo
194 * @param int $columna
198 function setColTitulo ($columna)
200 return $this->updateColAttributes($columna,$this->_conf['atributos']['celda_titulo']);
204 * Alinea una columna entera
206 * @param int $columna
207 * @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
224 function setColWidth ($columna, $valor)
226 return $this->updateColAttributes($columna,'width="'.$valor.'"');
230 * Cambia el color de fondo de una celda
233 * @param int $columna
234 * @param string $valor
238 function setCellBgcolor ($fila, $columna, $valor)
240 return $this->updateCellAttributes($fila, $columna,'bgcolor="'.$valor.'"');
244 * Devuelve el html de la tabla
246 * Devuelve el html de la tabla para que sea mostrado.
247 * Como parametro recibe el indicador de tabla simple.
248 * Si doble es 0, devuelve el html comun y corriente, si es
249 * distinto de 0 devuelve una tabla sola
253 * @return string Html
257 function toHtml ($doble = 0)
259 // Agregar la tabla de fondo.
261 $tmp = $this->_parseAttributes($this->_conf['atributos']['tabla_contenedora']);
262 $tmp['width'] = $this->_atribTabla['width'];
263 $tabla_externa = new HTML_Table($tmp);
264 $tabla_externa->setCellContents(0,0,parent::toHtml(),$this->_conf['atributos']['celda_comun']);
265 $result = $tabla_externa->toHtml();
268 $result = parent::toHtml();