From: Manuel Nazar Anchorena Date: Thu, 30 Oct 2003 20:37:55 +0000 (+0000) Subject: Se hace que colspanee la primera columna si no hay una central. X-Git-Tag: svn_import~207 X-Git-Url: https://git.llucax.com/mecon/meconlib.git/commitdiff_plain/8c7295e6b1d27e3f563b27fde72ada98c6cf7ac8?ds=inline Se hace que colspanee la primera columna si no hay una central. --- diff --git a/lib/MECON/HTML/Tabla.php b/lib/MECON/HTML/Tabla.php index b4a7551..af155b9 100644 --- a/lib/MECON/HTML/Tabla.php +++ b/lib/MECON/HTML/Tabla.php @@ -140,15 +140,7 @@ class MECON_HTML_Tabla extends HTML_Table { $tabla_externa = new HTML_Table(array('width'=>'100%','border'=>0)); } // Si tiene cabecera, la agrega. - if ($this->_cabecera) { - $tabla_externa->addRow($this->_cabecera, array( - 'valign' => 'middle', - 'width' => '33%', - )); - $tabla_externa->updateCellAttributes(0, 0, array('align' => 'left')); - $tabla_externa->updateCellAttributes(0, 1, array('align' => 'center')); - $tabla_externa->updateCellAttributes(0, 2, array('align' => 'right')); - } + $this->_addSpecialRow($this->_cabecera, $tabla_externa); // Si tiene cabecera o pie, agrega la tabla original. if ($this->_cabecera or $this->_pie) { //$id = $tabla_externa->addRow($result); @@ -160,16 +152,35 @@ class MECON_HTML_Tabla extends HTML_Table { )); } // Si tiene pie, lo agrega. - if ($this->_pie) { - $id = $tabla_externa->addRow($this->_pie, array( + $this->_addSpecialRow($this->_pie, $tabla_externa); + return ($this->_cabecera or $this->_pie) ? $tabla_externa->toHtml() : $result; + } + + function _addSpecialRow($array, &$tabla) { + if ($array) { + $row = array(); + foreach ($array as $key => $val) { + $row[$key] = $val ? $val : ' '; + } + $id = $tabla->addRow($row, array( 'valign' => 'middle', - 'width' => '33%', + 'width' => '33%', )); - $tabla_externa->updateCellAttributes($id, 0, array('align' => 'left')); - $tabla_externa->updateCellAttributes($id, 1, array('align' => 'center')); - $tabla_externa->updateCellAttributes($id, 2, array('align' => 'right')); + // Si no hay celda central, hace colspan. + if ($array[0] and !$array[1]) { + $tabla->updateCellAttributes($id, 0, array( + 'colspan' => 2, + 'width' => '67%')); + /* } XXX se complica hacer el colspan para atras: + elseif ($array[2] and !$array[1]) { + $tabla->updateCellAttributes($id, 1, array( + 'colspan' => 2, + 'width' => '67%')); */ + } + $tabla->updateCellAttributes($id, 0, array('align' => 'left')); + $tabla->updateCellAttributes($id, 1, array('align' => 'center')); + $tabla->updateCellAttributes($id, 2, array('align' => 'right')); } - return ($this->_cabecera or $this->_pie) ? $tabla_externa->toHtml() : $result; } /** @@ -297,7 +308,7 @@ class MECON_HTML_Tabla extends HTML_Table { * Setea la cabecera. * Ejemplo: * @code - * $tabla->setCabecera(array('Hola', ' ', 'mundo!')); + * $tabla->setCabecera(array('Hola', '', 'mundo!')); * @endcode * * @param array $cabecera Array de 3 elementos, que son la celda izquierda, @@ -325,7 +336,7 @@ class MECON_HTML_Tabla extends HTML_Table { */ function updateCabecera($cabecera, $lugar) { if (!$this->_cabecera) { - $this->_cabecera = array(' ', ' ', ' '); + $this->_cabecera = array('', '', ''); } if ($lugar == 'izquierda') { $this->_cabecera[0] = $cabecera; @@ -365,7 +376,7 @@ class MECON_HTML_Tabla extends HTML_Table { */ function updatePie($pie, $lugar) { if (!$this->_pie) { - $this->_pie = array(' ', ' ', ' '); + $this->_pie = array('', '', ''); } if ($lugar == 'izquierda') { $this->_pie[0] = $pie;