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'];
79 $this->HTML_Table($this->_atribTabla);
80 //Modifico los atributos de todas las tablas
81 //Hay que encontrar o hacer una funcion que setee los atributos para las futuras
86 * Agrega una fila del tipo Cabecera
88 * Agrega una fila del tipo cabecera, tomando colores y demas del
89 * archivo de configuracion. Recibe como parametro un array con
90 * los datos a incluir en la linea. Agrega tantas columnas como
91 * elementos tenga el array. Si no recibe parametro alguno,
92 * inserta una fila en blanco. Devuelve el identificador de la
93 * fila en donde inserto los datos.
95 * @param $contenido Contenido de la fila
97 * @return int Identificador de Linea
101 function agregarFilaCabecera ($contenido = '', $atributos = '')
103 return $this->addRow($contenido, $this->_conf['atributos']['celda_cabecera'],'TH');
107 * Agrega una fila del tipo Comun
109 * Agrega una fila del tipo comun, tomando colores y demas del
110 * archivo de configuracion. Recibe como parametro un array con
111 * los datos a incluir en la linea. Agrega tantas columnas como
112 * elementos tenga el array. Si no recibe parametro alguno,
113 * inserta una fila en blanco. Devuelve el identificador de la
114 * fila en donde inserto los datos.
116 * @param $contenido Contenido de la fila
118 * @return int Identificador de Linea
122 function agregarFila ($contenido = '')
124 return $this->addRow($contenido,$this->_conf['atributos']['celda_comun']);
129 * Modifica el atributo rowSpan a la celda pasada por parametro
132 * @param int $columna
137 function rowSpan ($fila, $columna, $valor)
139 return $this->updateCellAttributes($fila, $columna, 'rowspan='.$valor);
143 * Modifica el atributo colSpan a la celda pasada por parametro
146 * @param int $columna
151 function colSpan ($fila, $columna, $valor)
153 return $this->updateCellAttributes($fila, $columna, 'colspan='.$valor);
157 * Modifica el atributo aling de la celda pasada por parametro
160 * @param int $columna
161 * @param string $valor (left, center, right...)
165 function align ($fila, $columna, $valor)
167 return $this->updateCellAttributes($fila, $columna, 'align="'.$valor.'"');
171 * Setea una columna como del tipo cabecera
173 * @param int $columna
177 function setColCabecera ($columna)
179 return $this->updateColAttributes($columna,$this->_conf['atributos']['celda_cabecera']);
183 * Alinea una columna entera
185 * @param int $columna
186 * @param strin $valor
190 function setColAlign ($columna, $valor)
192 return $this->updateColAttributes($columna,'align="'.$valor.'"');
196 * Cambia el color de fondo de una celda
199 * @param int $columna
200 * @param strin $valor
204 function setCellBgcolor ($fila, $columna, $valor)
206 return $this->updateCellAttributes($fila, $columna,'bgcolor="'.$valor.'"');
210 * Devuelve el html de la tabla
212 * Devuelve el html de la tabla para que sea mostrado.
213 * Como parametro recibe el indicador de tabla simple.
214 * Si doble es 0, devuelve el html comun y corriente, si es
215 * distinto de 0 devuelve una tabla sola
219 * @return string Html
223 function toHtml ($doble = 0)
225 // Agregar la tabla de fondo.
227 $tmp = $this->_parseAttributes($this->_conf['atributos']['tabla_contenedora']);
228 $tmp['width'] = $this->_atribTabla['width'];
229 $tabla_externa = new HTML_Table($tmp);
230 $tabla_externa->setCellContents(0,0,parent::toHtml(),$this->_conf['atributos']['celda_comun']);
231 $result = $tabla_externa->toHtml();
234 $result = parent::toHtml();