]> git.llucax.com Git - mecon/meconlib.git/blobdiff - lib/MECON/PDF/Tabla.php
BugFix.
[mecon/meconlib.git] / lib / MECON / PDF / Tabla.php
index 37ecb7ddbebfa730a882efe256d3573b668ccfc0..499c406bc3e0f8af596248045ca31889a83d124c 100644 (file)
@@ -24,32 +24,77 @@ Autor:  Martin Marrese <mmarre@mecon.gov.ar>
 $Id$
 -----------------------------------------------------------------------------*/
 
 $Id$
 -----------------------------------------------------------------------------*/
 
-require_once 'MECON/PDF/Marco.php';
+require_once 'MECON/PDF/Contenido.php';
 
 /**
  * Libreria que permite agregar una tabla a un pdf.
  */
 
 /**
  * Libreria que permite agregar una tabla a un pdf.
  */
-class MECON_PDF_Tabla extends MECON_PDF_Marco {
+class MECON_PDF_Tabla extends MECON_PDF_Contenido {
+    
+    /**
+     * Configuracion
+     * @var array $config
+     * @access protected
+     */
+    var $_config;
+    
+    /**
+     * Objeto MECON_HTML_Tabla.
+     * @var &Object $tabla MECON_HTML_Tabla
+     * @access protected
+     */
+    var $_tabla;
+    
+    /**
+     * Objeto MECON_PDF_Marco
+     * @var &Object $marco
+     * @access protected
+     */
+    var $_marco;
 
     /**
 
     /**
-     * Funcion que envia el archivo a pantalla (para que el usuario haga un
-     * download)
+     * Orientacion de las nuevas paginas
+     * @var string $orientacion
+     * @access protected
+     */
+    var $_orientacion;
+    
+    /**
+     * Indica si el encabezado debe ir en la nuevas paginas.
+     * @var bool $encabezado
+     * @access protected;
+     */
+    var $_encabezado;
+    
+    /**
+     * Class Constructor
      *
      *
-     * @return string
+     * @param &Object $TABLA MECON_HTML_Tabla
+     * @param string $orientacion Orientacion que deben tener las nuevas paginas
+     * que genere la tabla.
+     *
+     * @return void
      * @access public
      */
      * @access public
      */
-    function display() {
+    function MECON_PDF_Tabla($TABLA, $orientacion = null, $encabezado = true) {
+        $this->_tabla = $TABLA;
+        $this->_orientacion = $orientacion;
+        $this->_config = include 'MECON/PDF/Tabla/medidas.php';
+        $this->_encabezado = $encabezado;
+    }
+    
+    /**
+     * Funcion que agrega el contenido de la tabla que se este utilizando al
+     * PDF.
+     *
+     * @param &Object $MARCO MECON_PDF_Marco
+     *
+     * @return void
+     * @access public
+     */
+    function toPDF(&$MARCO) {
+        $this->_marco =& $MARCO;
         $this->_agregarContenido();
         $this->_agregarContenido();
-        
-        //Agrego los encabezados
-        $t = true;
-        foreach ($this->_pdf->getPages() as $page) {
-            $this->_pdf->_pagina_actual = $page;
-            $this->buildPage($t, $t);
-            $t = false;
-        }
-        
-        $this->_pdf->display();
     }
 
     /**
     }
 
     /**
@@ -67,14 +112,22 @@ class MECON_PDF_Tabla extends MECON_PDF_Marco {
      */
     function _obtenerAlineacionTexto($row, $col, $texto, $attr, $estilo) {
         
      */
     function _obtenerAlineacionTexto($row, $col, $texto, $attr, $estilo) {
         
-        $at = $this->getCellAttributes($row, $col);
+        $at = $this->_tabla->getCellAttributes($row, $col);
+
+        if (@$at['colspan']) {
+            $offset = $at['colspan'];
+        }
+        else {
+            $offset = 1;
+        }
+        
         if (@$at['align'] == 'center') {
         if (@$at['align'] == 'center') {
-            $tam = $this->_pdf->strlen($texto, $estilo);
-            $init = $attr[$col] + ($attr[$col+1] - $attr[$col] - $tam) / 2;
+            $tam = $this->_marco->strlen($texto, $estilo);
+            $init = $attr[$col] + ($attr[$col+$offset] - $attr[$col] - $tam) / 2;
         }
         elseif (@$at['align'] == 'right') {
         }
         elseif (@$at['align'] == 'right') {
-            $tam = $this->_pdf->strlen($texto, $estilo);
-            $init = $attr[$col+1] - $tam + 1;
+            $tam = $this->_marco->strlen($texto, $estilo);
+            $init = $attr[$col+$offset] - $tam + 1;
         }
         else {
             $init = $attr[$col];
         }
         else {
             $init = $attr[$col];
@@ -92,16 +145,31 @@ class MECON_PDF_Tabla extends MECON_PDF_Marco {
      * @access protected
      */
     function _obtenerEstiloCelda($row, $col) {
      * @access protected
      */
     function _obtenerEstiloCelda($row, $col) {
-        $clase = $this->getCellAttributes($row, $col);
-        if (@$clase['cabecera'] || @$clase['oscura']) {
+        $clase = $this->_tabla->getCellAttributes($row, $col);
+        if (@$clase['cabecera']) {
             $estilo = $this->_config['celda_cabecera'];
         }
             $estilo = $this->_config['celda_cabecera'];
         }
-        elseif (@$clase['titulo'] || @$clase['clara']) {
+        elseif (@$clase['titulo']) {
             $estilo = $this->_config['celda_titulo'];
         }
             $estilo = $this->_config['celda_titulo'];
         }
+        elseif (@$clase['oscura']) {
+            $tmp = $this->_config['celda_comun'];
+            $tmp['fillcolor'] = $this->_config['celda_cabecera']['fillcolor'];
+            $tmp['fill'] = $this->_config['celda_cabecera']['fill'];
+            $estilo = $tmp;
+        }
+        elseif (@$clase['clara']) {
+            $tmp = $this->_config['celda_comun'];
+            $tmp['fillcolor'] = $this->_config['celda_titulo']['fillcolor'];
+            $tmp['fill'] = $this->_config['celda_titulo']['fill'];
+            $estilo = $tmp;
+        }
         else {
             $estilo = $this->_config['celda_comun'];
         }
         else {
             $estilo = $this->_config['celda_comun'];
         }
+        if (@$clase['colspan']) {
+            $estilo['colspan'] = $clase['colspan'];
+        }
         return $estilo;
     }
 
         return $estilo;
     }
 
@@ -112,15 +180,23 @@ class MECON_PDF_Tabla extends MECON_PDF_Marco {
      * @access protected
      */
     function _obtenerAnchoColumnas() {
      * @access protected
      */
     function _obtenerAnchoColumnas() {
-        $ancho_pagina = $this->_pdf->getWidth($this->_orientacion);
-        for ($i=0; $i<$this->getColCount(); $i++ ) {
-            $tmp = $this->getCellAttributes(0,$i);
-            if (is_null(@$tmp['width'])) {
-                die ('Todas las columnas deben tener asignado un ancho.');                
+        $ancho_pagina = $this->_marco->getWidth($this->_marco->refPage(),
+                $this->_marco->getOrientation());
+        for ($row = 0; $row<$this->_tabla->getRowCount(); $row++) {
+            for ($i=0; $i<$this->_tabla->getColCount(); $i++ ) {
+                $tmp = $this->_tabla->getCellAttributes($row,$i);
+                if(@intval($tmp['width']) != 0)
+                    $attr[$i] = intval($tmp['width']);
+                if(@count($attr) == $this->_tabla->getColCount())
+                  break 2;
             }
             }
-            $attr[$i] = intval($tmp['width']);
         }
         }
+        
+        if (!isset($attr))
+            trigger_error ('Todas las columnas tienen que tener un ancho asignado', E_USER_ERROR);
+        
         $tmp = array_sum($attr);
         $tmp = array_sum($attr);
+        
         $attr2[0] = 0;
         for ($i=1; $i<count($attr); $i++) {
             $attr2[$i] = intval(($ancho_pagina * $attr[$i-1] / $tmp) +
         $attr2[0] = 0;
         for ($i=1; $i<count($attr); $i++) {
             $attr2[$i] = intval(($ancho_pagina * $attr[$i-1] / $tmp) +
@@ -129,6 +205,17 @@ class MECON_PDF_Tabla extends MECON_PDF_Marco {
         $attr2[$i] = $ancho_pagina;
         return $attr2;
     }
         $attr2[$i] = $ancho_pagina;
         return $attr2;
     }
+    /**
+     * Funcion que se encarga de crear las nuevas paginas.
+     *
+     * @return void
+     * @access protected
+     */
+    function _newPage() {
+        $tmp = ($this->_orientacion) ? $this->_orientacion :
+            $this->_marco->getOrientation();
+        $this->_marco->newPage($this->_marco->tamanio, $tmp, $this->_encabezado);               
+    }
 
     /**
      * Funcion que agrega las filas y columnas a la pagina.                  
 
     /**
      * Funcion que agrega las filas y columnas a la pagina.                  
@@ -137,38 +224,80 @@ class MECON_PDF_Tabla extends MECON_PDF_Marco {
      * @access protected
      */
     function _agregarContenido() {
      * @access protected
      */
     function _agregarContenido() {
-        $this->_pdf->newPage($this->_tamanio);               
-        $alto = $this->_getAvailableSpace($this->_pdf->numPage());
+        $alto = $this->_marco->espacioDisponible;
+        $orientacion = $this->_marco->getOrientation();
+        if ($alto <= 0 || ($this->_orientacion && $this->_orientacion !=
+                    $orientacion) ) {
+            $this->_newPage();               
+            $orientacion = $this->_marco->getOrientation();
+            $alto = $this->_marco->espacioDisponible;
+        }
         $attr2 = $this->_obtenerAnchoColumnas();
         $attr2 = $this->_obtenerAnchoColumnas();
-        for ($i = 0; $i < $this->getRowCount(); $i++) {
+        for ($i = 0; $i < $this->_tabla->getRowCount(); $i++) {
             $max = 0;
             $max = 0;
-            for ($j = 0; $j < $this->getColCount(); $j++) {
+            for ($j = 0; $j < $this->_tabla->getColCount(); $j++) {
                 $estilo = $this->_obtenerEstiloCelda($i, $j);
                 $estilo = $this->_obtenerEstiloCelda($i, $j);
-                $txt = $this->_pdf->wordWrap($this->getCellContents($i,$j),
-                        $attr2[$j+1] - $attr2[$j], $estilo);
+
+                //Actuo por el colspan
+                if (@$estilo['colspan']) {
+                    if ($estilo['colspan'] > $this->_tabla->getColCount()) {
+                        $estilo['colspan'] = 
+                            $this->_tabla->getColCount() - $j;
+                    }
+                    $ancho_columna = $attr2[$j+$estilo['colspan']] - 
+                        $attr2[$j];
+                }
+                else {
+                   $ancho_columna = $attr2[$j+1] - $attr2[$j];
+                }
+                if (@$this->_tabla->getCellContents($i,$j)) {
+                    $txt = $this->_marco->wordWrap(
+                            @$this->_tabla->getCellContents($i,$j), $ancho_columna, 
+                            $estilo
+                            );
+                }
+                else {
+                    $txt = array (' ');
+                }
+                
                 $txtt[$j] = $txt; //Esto es para no hacer el wordWrap siempre
                 $max = max($estilo['alto_linea'] * count($txt), $max);
                 
                 $rep = array ();
                 $txtt[$j] = $txt; //Esto es para no hacer el wordWrap siempre
                 $max = max($estilo['alto_linea'] * count($txt), $max);
                 
                 $rep = array ();
-                $rep = $this->getCellAttributes($i, $j);
+                $rep = $this->_tabla->getCellAttributes($i, $j);
                 if (@$rep['cabecera'] || @$rep['titulo']) {
                     $repetir[$i][$j] = $txt;
                     $repetir[$i]['max'] = $max;
                 }
             }
                 if (@$rep['cabecera'] || @$rep['titulo']) {
                     $repetir[$i][$j] = $txt;
                     $repetir[$i]['max'] = $max;
                 }
             }
-            
-            if ($alto < 0) {
-                $this->_pdf->newPage($this->_tamanio);
-                $alto = $this->_getAvailableSpace($this->_pdf->numPage());
+            if ($alto <= 0) 
+            {
+                $this->_newPage();               
+                $alto = $this->_marco->espacioDisponible;
                 
                 foreach ($repetir as $ii => $value) {
                     $alto -= $repetir[$ii]['max'];
                 
                 foreach ($repetir as $ii => $value) {
                     $alto -= $repetir[$ii]['max'];
-                    for ($jj = 0; $jj < $this->getColCount(); $jj++) {
+                    for ($jj = 0; $jj < $this->_tabla->getColCount(); $jj++) {
                         $estilo = $this->_obtenerEstiloCelda($ii, $jj);
                         $estilo = $this->_obtenerEstiloCelda($ii, $jj);
-                        $this->_pdf->addRectangle($attr2[$jj], $alto,
-                                $attr2[$jj+1],  $alto+$repetir[$ii]['max'],
-                                @$estilo['fill'], null, $this->_orientacion);
+
+                        //Actuo por el colspan
+                        if (@$estilo['colspan']) {
+                            if ($estilo['colspan'] > $this->_tabla->getColCount()) {
+                                $estilo['colspan'] =
+                                    $this->_tabla->getColCount() - $jj;
+                            }
+                            $der = $attr2[$jj+$estilo['colspan']];
+                            $izq = $attr2[$jj];
+                        }
+                        else {
+                           $der = $attr2[$jj+1];
+                           $izq = $attr2[$jj];
+                        }
+
                         
                         
+                        $this->_marco->addRectangle($izq, $alto, $der, 
+                                $alto+$repetir[$ii]['max'], @$estilo['fill'], 
+                                null, $orientacion);
                         $alto1 = $alto + $repetir[$ii]['max'];
                         foreach ($repetir[$ii][$jj] as $t) {
                             $alto1 -= $estilo['alto_linea'];
                         $alto1 = $alto + $repetir[$ii]['max'];
                         foreach ($repetir[$ii][$jj] as $t) {
                             $alto1 -= $estilo['alto_linea'];
@@ -177,36 +306,61 @@ class MECON_PDF_Tabla extends MECON_PDF_Marco {
                             $init = $this->_obtenerAlineacionTexto($ii, $jj, $t, $attr2,
                                     $estilo);
                             
                             $init = $this->_obtenerAlineacionTexto($ii, $jj, $t, $attr2,
                                     $estilo);
                             
-                            $this->_pdf->addText($init, $alto1 + 2,
-                                    $t, $estilo, null, $this->_orientacion);
+                            $this->_marco->addText($init, $alto1 + 2,
+                                    $t, $estilo, null, $orientacion);
+                        }
+
+                        if (@$estilo['colspan']) {
+                            $jj += $estilo['colspan'] -1;
                         }
                         }
+                        
                     }
                 }
                 
             }
             
             $alto -= $max;
                     }
                 }
                 
             }
             
             $alto -= $max;
-            for ($j = 0; $j < $this->getColCount(); $j++) {
-
+            for ($j = 0; $j < $this->_tabla->getColCount(); $j++) {
+                
                 $estilo = $this->_obtenerEstiloCelda($i, $j);
                 $estilo = $this->_obtenerEstiloCelda($i, $j);
+                 
+                //Actuo por el colspan
+                if (@$estilo['colspan']) {
+                    if ($estilo['colspan'] > $this->_tabla->getColCount()) {
+                        $estilo['colspan'] = $this->_tabla->getColCount()  - 1;
+                    }
+                    $der = $attr2[$j+$estilo['colspan']];
+                    $izq = $attr2[$j];
+                }
+                else {
+                   $der = $attr2[$j+1];
+                   $izq = $attr2[$j];
+                }
+
                 
                 
-                $this->_pdf->addRectangle($attr2[$j], $alto,
-                        $attr2[$j+1], $alto+$max, @$estilo['fill'], null,
-                        $this->_orientacion);
+                $this->_marco->addRectangle($izq, $alto, $der, $alto+$max, 
+                        @$estilo['fill'], null, $orientacion);
                 
                 $alto1 = $alto + $max;
                 
                 $alto1 = $alto + $max;
-                foreach ($txtt[$j] as $t) {
-                    $alto1 -= $estilo['alto_linea'];
-
-                    //Ubico el texto segun su alineacion
-                    $init = $this->_obtenerAlineacionTexto($i, $j, $t, $attr2,
-                            $estilo);
-                    
-                    $this->_pdf->addText($init, $alto1 + 2,
-                            $t, $estilo, null, $this->_orientacion);
+                if (@$txtt[$j]) {
+                    foreach ($txtt[$j] as $t) {
+                        $alto1 -= $estilo['alto_linea'];
+
+                        //Ubico el texto segun su alineacion
+                        $init = $this->_obtenerAlineacionTexto($i, $j, $t, $attr2,
+                                $estilo);
+                        
+                        $this->_marco->addText($init, $alto1 + 2,
+                                $t, $estilo, null, $orientacion);
+                    }
                 }
                 }
+                if (@$estilo['colspan']) {
+                    $j += $estilo['colspan']-1;
+                }
+
             }
         }
             }
         }
+        $this->_marco->espacioDisponible = $alto;
     }
 }
 ?>
\ No newline at end of file
     }
 }
 ?>
\ No newline at end of file