<?PHP
    session_start();   
	header("Pragma: public");
	header("Cache-Control: must-revalidate, post-check=0, pre-check=0");//CVA - PEDRO CAMEJO.
	header("Cache-Control: private",false);
	if(!array_key_exists("la_logusr",$_SESSION))
	{
		print "<script language=JavaScript>";
		print "opener.document.form1.submit();"	;	
		print "close();";
		print "</script>";		
	}	
	$x_pos=0;//mientras mas grande el numero, mas a la derecha.
	$y_pos=-1;//Mientras mas pequeño el numero, mas alto.
	$ls_directorio="cheque_configurable";
	$ls_archivo="cheque_configurable/medidas.txt";
	$li_medidas=16;
	//-------------------------------------------------------------------------------------------------
	function uf_inicializar_variables()
	{
		global $valores;
		global $ls_directorio;
		global $ls_archivo;	
		global $li_medidas;	
		if(!file_exists ($ls_directorio))
		{
			$lb_exito=mkdir($ls_directorio,0777);
			if(!$lb_exito)
			{
				print "<script>";
				print "alert('Error al crear directorio cheque_configurable');";
				print "close();";
				print "</script>";
			}
		}
		
		if((!file_exists ($ls_archivo)) || (filesize($ls_archivo)==0))
		{	
			if(file_exists ($ls_directorio))
			{
				$archivo = fopen($ls_archivo, "w");			
				$ls_contenido="138.00-6.00-32.00-24.00-32.00-28.00-32.00-34.00-32.00-43.00-77.00-43.00-137.00-65.00-131.00-70.00";
				fwrite($archivo,$ls_contenido);
				fclose($archivo);
			}
		}
			
		if((file_exists($ls_archivo)) && (filesize($ls_archivo)>0))
		{
			$archivo = fopen($ls_archivo, "r");
			$contenido = fread($archivo, filesize($ls_archivo));			
			fclose($archivo);			
			$valores = explode("-",$contenido);	
			if(count($valores)<>$li_medidas)
			{
				$archivo = fopen($ls_archivo, "w");
				fclose($archivo);			
				print "<script>";
				print "alert('Ocurrio un error, por favor cargue de nuevo el cheque (Las medidas seran inicializadas por fallo de lectura y escritura)');";
				print "close();";
				print "</script>";
			}
		}
		else
		{
			print "<script>";
			print "alert('Ocurrio un error, por favor cargue de nuevo el cheque (Las medidas seran inicializadas por fallo de lectura y escritura)');";
			print "close();";
			print "</script>";
		}
	}
	
	//--------------------------------------------------------------------------------------------------------------------------------
	function uf_print_encabezado_pagina($ldec_monto,$ls_nomproben,$ls_monto,$ls_fecha,&$io_pdf,$x)
	{
		//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
		//       Function: uf_print_encabezado_pagina
		//		    Acess: private 
		//	    Arguments: ldec_monto : Monto del cheque
		//	    		   ls_nomproben:  Nombre del proveedor o beneficiario
		//	    		   ls_monto : Monto en letras
		//	    		   ls_fecha : Fecha del cheque
		//				   io_pdf   : Instancia de objeto pdf
		//    Description: función que imprime los encabezados por página
		//	   Creado Por: Ing. Nelson Barraez
		// Fecha Creación: 25/04/2006 
		//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
		global $valores;
		//Imprimo el monto
		$io_pdf->add_texto($valores[0],$valores[1],14,"<b>***".$ldec_monto."***</b>");
		$io_pdf->add_texto(10,$valores[7],16,"<b>***".$ldec_monto."***</b>");
		//Beneficiario del Cheque
		$io_pdf->add_texto($valores[2],$valores[3],11,"<b>***$ls_nomproben***</b>");
		$ls_anio=substr($ls_fecha,-4);
		$ls_fecha_corta=substr($ls_fecha,0,(strlen($ls_fecha)-5));	
		//Fecha del Cheque
		$io_pdf->add_texto($valores[8],$valores[9],9,"<b>$ls_fecha_corta</b>");
		$io_pdf->add_texto($valores[10],$valores[11],9,"<b>$ls_anio</b>");
		//Informacion de Caducidad	
        $io_pdf->add_texto($valores[14],$valores[15],9,"<b>CADUCA A LOS 90 DIAS</b>");
		//No Endosable
		$io_pdf->add_texto($valores[12],$valores[13],12,"<b>NO ENDOSABLE</b>");
	}// end function uf_print_encabezadopagina
	//--------------------------------------------------------------------------------------------------------------------------------
	
	//--------------------------------------------------------------------------------------------------------------------------------
	function uf_print_cabecera($ls_numdoc,$ls_nomban,$ls_ctaban,$ls_nomproben,$ls_fecmov,$ls_conmov,$as_chevau,&$io_pdf)
	{
		//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
		//       Function: uf_print_cabecera
		//		   Access: private 
		//	    Arguments: ls_numdoc : Numero de documento
		//	    		   ls_nomban : Nombre del banco
		//				   ls_cbtan  : Cuenta del banco
		//				   ls_chevau : Voucher del cheque
		//				   ls_nomproben: Nombre del proveedor o beneficiario
		//				   ls_solicitudes: Solicitudes canceladas con el cheque					  
		//	    		   io_pdf // total de registros que va a tener el reporte
		//    Description: función que imprime los datos basicos del cheque
		//	   Creado Por: Ing. Néstor Falcón.
		// Fecha Creación: 24/04/2006 
		//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

		$ls_conmov = wordwrap($ls_conmov,80);
		$io_pdf->add_texto(12,107,10,$ls_conmov);//108
		
		$li_pos=155;//155
		$io_pdf->convertir_valor_mm_px($li_pos);		
		$io_pdf->ezSetY($li_pos);
		$la_data=array(array('cheque'=>'','banco'=>''),
					   array('cheque'=>$ls_numdoc,'banco'=>"    ".$ls_nomban));
		$la_columna=array('cheque'=>'','banco'=>'');
		$la_config=array('showHeadings'=>0, // Mostrar encabezados
						 'showLines'=>0, // Mostrar Líneas
						 'fontSize' =>9, // Tamaño de Letras
						 'shaded'=>0, // Sombra entre líneas
						 'shadeCol2'=>array(0.9,0.9,0.9), // Color de la sombra
						 'xPos'=>340, // Orientación de la tabla
						 'width'=>580, // Ancho de la tabla
						 'maxWidth'=>580,
						 'cols'=>array('cheque'=>array('justification'=>'left','width'=>150),
						 'banco'=>array('justification'=>'left','width'=>250))); // Ancho Máximo de la tabla
		$io_pdf->ezTable($la_data,$la_columna,'',$la_config);
		$io_pdf->add_texto(8,260,9,substr($as_chevau,-8));//108
	}// end function uf_print_cabecera
	//--------------------------------------------------------------------------------------------------------------------------------

	//--------------------------------------------------------------------------------------------------------------------------------
	function uf_print_detalle($la_data,&$io_pdf,$x_pos)
	{
		//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
		//       Function: uf_print_detalle
		//		    Acess: private 
		//	    Arguments: la_data // arreglo de información
		//	   			   io_pdf // Objeto PDF
		//    Description: función que imprime el detalle
		//	   Creado Por: Ing. Nelson Barraez
		// Fecha Creación: 24/04/2006 
		//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
		
		$io_pdf->ezSety(375);
		$la_config=array('showHeadings'=>0, // Mostrar encabezados
						 'fontSize'=>8, // Tamaño de Letras
						 'titleFontSize'=>8,  // Tamaño de Letras de los títulos
						 'showLines'=>0, // Mostrar Líneas
						 'shaded'=>0, // Sombra entre líneas
						 'width'=>580, // Ancho de la tabla
						 'maxWidth'=>580, // Ancho Máximo de la tabla
						 'colGap'=>1, //Separacion de los caracteres entre las barras de las tablas.
						 'xPos'=>258, // Orientación de la tabla
						 'cols'=>array('scg_cuenta'=>array('justification'=>'center','width'=>90),
			 						   'denctascg'=>array('justification'=>'left','width'=>200),
			 						   'debe'=>array('justification'=>'right','width'=>85),									   
									   'haber'=>array('justification'=>'right','width'=>90))); // Justificación y ancho de la columna
		$la_columnas=array('scg_cuenta'=>'','denctascg'=>'','debe'=>'','haber'=>'');
		$io_pdf->ezTable($la_data,$la_columnas,'',$la_config);
	}// end function uf_print_detalle
	//--------------------------------------------------------------------------------------------------------------------------------

	function uf_print_totales($ad_montotdeb,$ad_montothab,$io_pdf)
	{
		//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
		//       Function: uf_print_totales
		//		    Acess: private 
		//	    Arguments: $ad_montotdeb : Monto total de los detalles de los Débitos.
		//                 $ad_montothab : Monto total de los detalles de los Créditos.
		//	   			   io_pdf // Objeto PDF
		//    Description: Imprime la totalizacion de los montos de debitos y los creditos al final del voucher.
		//	   Creado Por: Ing. Néstor Falcón.
		// Fecha Creación: 29/01/2008
		//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
	     
		 $io_pdf->add_texto(127,98,9,'<b>'.number_format($ad_montotdeb,2,',','.').'</b>');
		 $io_pdf->add_texto(158,99,9,'<b>'.number_format($ad_montothab,2,',','.').'</b>');
	}
	
	function uf_convertir($ls_numero)
	{
		$ls_numero=str_replace(".","",$ls_numero);
		$ls_numero=str_replace(",",".",$ls_numero);
		return $ls_numero;
	}
	//--------------------------------------------------------------------------------------------------------------------------------
	//require_once("../../shared/ezpdf/class.ezpdf.php");
	 uf_inicializar_variables();
	require_once('../../shared/class_folder/class_pdf.php');
	require_once("../../shared/class_folder/class_funciones.php");
	require_once("../../shared/class_folder/sigesp_include.php");
	require_once("../../shared/class_folder/class_datastore.php");
	require_once("../../shared/class_folder/class_sql.php");
	$in=new sigesp_include();
	$con=$in->uf_conectar();
	$io_sql=new class_sql($con);	
	require_once("sigesp_scb_report.php");
	$class_report=new sigesp_scb_report($con);
	$io_funciones=new class_funciones();				
	$ds_voucher=new class_datastore();	
	$ds_dt_scg=new class_datastore();				
	$ds_dt_spg=new class_datastore();
	//Instancio a la clase de conversión de numeros a letras.
	require_once("../../shared/class_folder/cnumero_letra.php");
	$numalet= new cnumero_letra();
	
	
	
	$ls_tipimp = "";
	if (array_key_exists("tipimp",$_GET))
	{
		$ls_tipimp = $_GET["tipimp"];
	}	

	if ($ls_tipimp=='lote')
	{
		$ls_codemp		=$_SESSION["la_empresa"]["codemp"];
		$ls_codban      = $_GET["codban"];
		$ls_ctaban      = $_GET["ctaban"];
		$ls_documentos  = $_GET["documentos"];
		$ls_fechas      = $_GET["fechas"];
		$ld_fecdes      = $_GET["fecdesde"];
		$ld_fechas      = $_GET["fechasta"];
		$ls_operaciones = $_GET["operaciones"];
			
		//Descompongo la cadena de documentos en un arreglo tomando como separación el ','
		$arr_documentos = split(",",$ls_documentos);
		$li_totdoc		= count($arr_documentos);
		//Descompongo la cadena de fechas en un arreglo tomando como separación el '-'
		$arr_fecmov = split("-",$ls_fechas);
		$li_totfec  = count($arr_fecmov);
	   //Descompongo la cadena de operaciones en un arreglo tomando como separación el '-'
		$arr_operaciones = split("-",$ls_operaciones);
		$li_totdoc	= count($arr_operaciones);		
		$class_report->uf_buscar_cheques_vouchers($arr_documentos,$arr_fecmov,$arr_operaciones,$ls_codban,$ls_ctaban);
		
		$li_total   = $class_report->ds_voucher1->getRowCount("numdoc");

		if ($li_total>0)
		{	
			//error_reporting(E_ALL);
			//set_time_limit(1800);
			$io_pdf=new class_pdf('LETTER','portrait'); // Instancia de la clase PDF
			$io_pdf->selectFont('../../shared/ezpdf/fonts/Helvetica.afm'); // Seleccionamos el tipo de letra	
			$io_pdf->set_margenes(0,0,$x_pos,0);
			$li_totrow=$ds_voucher->getRowCount("numdoc");
			$io_pdf->transaction('start'); // Iniciamos la transacción
			$thisPageNum=$io_pdf->ezPageCount;
		
			for ($i=1;$i<=$li_total;$i++)
			{
				$ls_numdoc=$class_report->ds_voucher1->getValue("numdoc",$i);
				
				$ls_chevau=$class_report->ds_voucher1->getValue("chevau",$i);
				$ls_codope='CH';
				
				$data=$class_report->uf_cargar_chq_voucher($ls_numdoc,$ls_chevau,$ls_codban,$ls_ctaban,$ls_codope);
			$class_report->SQL->begin_transaction();
			$lb_valido=$class_report->uf_actualizar_status_impreso($ls_numdoc,$ls_chevau,$ls_codban,$ls_ctaban,$ls_codope);
			if(!$lb_valido)
			{
				print "Error al actualizar";
				$class_report->is_msg_error;	
				$class_report->SQL->rollback();
			}
			else
			{
				$class_report->SQL->commit();
			}
			$ds_voucher->data=$data;			
			$li_totrow=$ds_voucher->getRowCount("numdoc");
			$io_pdf->transaction('start'); // Iniciamos la transacción
			$thisPageNum=$io_pdf->ezPageCount;
			for($li_i=1;$li_i<=$li_totrow;$li_i++)
			{
				unset($la_data);
				$li_totprenom=0;
				$ldec_mondeb=0;
				$ldec_monhab=0;
				$li_totant=0;
				$ls_numdoc=$ds_voucher->data["numdoc"][$li_i];
				$ls_codban=$ds_voucher->data["codban"][$li_i];
				$ls_nomban=$class_report->uf_select_data($io_sql,"SELECT * FROM scb_banco WHERE codban ='".$ls_codban."' AND codemp='".$ls_codemp."'","nomban");
				$ls_ctaban=$ds_voucher->data["ctaban"][$li_i];
				$ls_chevau=$ds_voucher->data["chevau"][$li_i];
				$ld_fecmov=$io_funciones->uf_convertirfecmostrar($ds_voucher->data["fecmov"][$li_i]);
				$ls_nomproben=$ds_voucher->data["nomproben"][$li_i];
				$ls_solicitudes=$class_report->uf_select_solicitudes($ls_numdoc,$ls_codban,$ls_ctaban);
				$ls_conmov=$ds_voucher->getValue("conmov",$li_i);
				$ldec_monret=$ds_voucher->getValue("monret",$li_i);
				$ldec_monto=$ds_voucher->getValue("monto",$li_i);
				$ldec_total=$ldec_monto-$ldec_monret;
				$ls_monto=$numalet->uf_convertir_letra($ldec_total,'','');
				$io_encabezado=$io_pdf->openObject();
				uf_print_encabezado_pagina(number_format($ldec_total,2,",","."),$ls_nomproben,$ls_monto,$_SESSION["la_empresa"]["ciuemp"].", ".$ld_fecmov,$io_pdf,$y_pos); // Imprimimos el encabezado de la página
				uf_print_cabecera($ls_numdoc,$ls_nomban,$ls_ctaban,$ls_nomproben,$ld_fecmov,$ls_conmov,$ls_chevau,$io_pdf); // Imprimimos la cabecera del registro
				$io_pdf->closeObject();
				$io_pdf->addObject($io_encabezado,'all');
				$ds_dt_scg->data=$class_report->uf_cargar_dt_scg($ls_numdoc,$ls_codban,$ls_ctaban,$ls_codope); // Obtenemos el detalle del reporte
				$ds_dt_spg->data=$class_report->uf_cargar_dt_spg($ls_numdoc,$ls_codban,$ls_ctaban,$ls_codope);
				$la_campos=array("scg_cuenta");
				$la_monto=array("monto");
				$ds_dt_scg->group_by($la_campos,$la_monto,"scg_cuenta");
				$la_campos=array("spg_cuenta","estpro");
				$ds_dt_spg->group_by($la_campos,$la_monto,"spg_cuenta");
				$li_totrow_det=$ds_dt_scg->getRowCount("scg_cuenta");
				$li_totrow_spg=$ds_dt_spg->getRowCount("spg_cuenta");
				$la_contable = array();
				$ld_montotdeb = $ld_montothab = 0;
				///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
				// Hago un ciclo para unir en una sola matriz los detalles de presupuesto y los contables para proceder luego a pintarlos
				if($li_totrow_det>=$li_totrow_spg)
				{
					for($li_s=1;$li_s<=$li_totrow_det;$li_s++)
					{
						$ls_scg_cuenta = trim($ds_dt_scg->data["scg_cuenta"][$li_s]);
						$ls_scg_cuenta = substr($ls_scg_cuenta,0,1).'-'.substr($ls_scg_cuenta,1,2).'-'.substr($ls_scg_cuenta,3,2).'-'.substr($ls_scg_cuenta,5,2).'-'.substr($ls_scg_cuenta,7,2).'-'.substr($ls_scg_cuenta,9,3);
						$ls_denctascg  = $ds_dt_scg->data["denominacion"][$li_s];
						$ls_debhab     = $ds_dt_scg->data["debhab"][$li_s];
						$ldec_monto    = $ds_dt_scg->data["monto"][$li_s];
						if($ls_debhab=='D')
						{
							$ld_montotdeb += $ldec_monto;
							$ldec_mondeb=number_format($ldec_monto,2,",",".");
							$ldec_monhab=" ";
						}
						else
						{
							$ld_montothab += $ldec_monto;
							$ldec_monhab=number_format($ldec_monto,2,",",".");
							$ldec_mondeb=" ";
						}
						if(array_key_exists("spg_cuenta",$ds_dt_spg->data))
						{
							if(array_key_exists($li_s,$ds_dt_spg->data["spg_cuenta"]))
							{
								$ls_cuentaspg   = trim($ds_dt_spg->getValue("spg_cuenta",$li_s));
								$ls_denctaspg   = $ds_dt_spg->getValue("denominacion",$li_s);	
								$ls_estpro      = $ds_dt_spg->getValue("estpro",$li_s);	  
								$ls_codestpro1  = substr($ls_estpro,14,6);
								$ls_codestpro2  = substr($ls_estpro,21,6);
								$ls_estpro      = $ls_codestpro1.'-'.$ls_codestpro2;
								$ldec_monto_spg = number_format($ds_dt_spg->getValue("monto",$li_s),2,",",".");
							}
							else
							{
								$ls_cuentaspg=" ";	
								$ls_estpro=" ";	  
								$ldec_monto_spg=" ";
								$ls_denctaspg = "";
							}
						}
						else
						{
							$ls_cuentaspg=" ";	
							$ls_estpro=" ";	  
							$ldec_monto_spg=" ";
							$ls_denctaspg = "";
						}
						$la_data[$li_s]=array('estpro'=>$ls_estpro,'spg_cuenta'=>$ls_cuentaspg,'denctaspg'=>$ls_denctaspg,'monto_spg'=>$ldec_monto_spg,'scg_cuenta'=>$ls_scg_cuenta,'denctascg'=>$ls_denctascg,'debe'=>$ldec_mondeb,'haber'=>$ldec_monhab);
					}
				}
				
				if($li_totrow_spg>$li_totrow_det)
				{
					for($li_s=1;$li_s<=$li_totrow_spg;$li_s++)
					{
						if(array_key_exists("scg_cuenta",$ds_dt_scg->data))
						{
							if(array_key_exists($li_s,$ds_dt_scg->data["scg_cuenta"]))
							{
								$ls_scg_cuenta = trim($ds_dt_scg->data["scg_cuenta"][$li_s]);
								$ls_scg_cuenta = substr($ls_scg_cuenta,0,1).'-'.substr($ls_scg_cuenta,1,2).'-'.substr($ls_scg_cuenta,3,2).'-'.substr($ls_scg_cuenta,5,2).'-'.substr($ls_scg_cuenta,7,2).'-'.substr($ls_scg_cuenta,9,3);
								$ls_denctascg  = $ds_dt_scg->data["denominacion"][$li_s];
								$ls_debhab     = $ds_dt_scg->data["debhab"][$li_s];
								$ldec_monto    = $ds_dt_scg->data["monto"][$li_s];
								if($ls_debhab=='D')
								{
									$ld_montotdeb += $ldec_monto;
									$ldec_mondeb=number_format($ldec_monto,2,",",".");
									$ldec_monhab=" ";
								}
								else
								{
									$ld_montothab += $ldec_monto;
									$ldec_monhab=number_format($ldec_monto,2,",",".");
									$ldec_mondeb=" ";
								}
							}
							else
							{
								$ls_scg_cuenta="";
								$ls_denctascg="";
								$ls_debhab = "";
								$ldec_monto= "";
								$ldec_mondeb="";
								$ldec_monhab="";					
							}
						}
						else
						{
							$ls_scg_cuenta="";
							$ls_denctascg ="";
							$ls_debhab = "";
							$ldec_monto= "";
							$ldec_mondeb="";
							$ldec_monhab="";					
						}
						if(array_key_exists("spg_cuenta",$ds_dt_spg->data))
						{
							if(array_key_exists($li_s,$ds_dt_spg->data["spg_cuenta"]))
							{
								$ls_cuentaspg   = trim($ds_dt_spg->getValue("spg_cuenta",$li_s));
								$ls_denctaspg   = $ds_dt_spg->getValue("denominacion",$li_s);	
								$ls_estpro      = $ds_dt_spg->getValue("estpro",$li_s);	  
								$ldec_monto_spg = number_format($ds_dt_spg->getValue("monto",$li_s),2,",",".");
							}
							else
							{
								$ls_cuentaspg=" ";	
								$ls_estpro=" ";	  
								$ldec_monto_spg=" ";
							}
						}
						else
						{
							$ls_cuentaspg=" ";	
							$ls_estpro=" ";	  
							$ldec_monto_spg=" ";
						}
						$la_data[$li_s]=array('estpro'=>$ls_estpro,'spg_cuenta'=>$ls_cuentaspg,'denctaspg'=>$ls_denctaspg,'monto_spg'=>$ldec_monto_spg,'scg_cuenta'=>$ls_scg_cuenta,'denctascg'=>$ls_denctascg,'debe'=>$ldec_mondeb,'haber'=>$ldec_monhab);
					}
				}
				////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
				if(empty($la_data))
				{
					$ls_cuentaspg='';
					$ls_estpro='';
					$ldec_monto_spg='';
					$ls_scg_cuenta='';
					$ls_denctascg="";
					$ldec_mondeb='';
					$ldec_monhab='';
					$la_data[1]=array('estpro'=>$ls_estpro,'spg_cuenta'=>$ls_cuentaspg,'denctaspg'=>$ls_denctaspg,'monto_spg'=>$ldec_monto_spg,'scg_cuenta'=>$ls_scg_cuenta,'denctascg'=>$ls_denctascg,'debe'=>$ldec_mondeb,'haber'=>$ldec_monhab);
					$la_data[2]=array('estpro'=>$ls_estpro,'spg_cuenta'=>$ls_cuentaspg,'denctaspg'=>$ls_denctaspg,'monto_spg'=>$ldec_monto_spg,'scg_cuenta'=>$ls_scg_cuenta,'denctascg'=>$ls_denctascg,'debe'=>$ldec_mondeb,'haber'=>$ldec_monhab);
					$la_data[3]=array('estpro'=>$ls_estpro,'spg_cuenta'=>$ls_cuentaspg,'denctaspg'=>$ls_denctaspg,'monto_spg'=>$ldec_monto_spg,'scg_cuenta'=>$ls_scg_cuenta,'denctascg'=>$ls_denctascg,'debe'=>$ldec_mondeb,'haber'=>$ldec_monhab);
				}
				//codigo para unir las cuentas iguales
				$la_dataaux=array();
				for($li_k=1;$li_k<=count($la_data);$li_k++)
				{
					$lb_existe=false;
					$li_pos=0;
					for($li_l=1;$li_l<=count($la_dataaux);$li_l++)
					{
						if(($la_data[$li_k]["spg_cuenta"]==$la_dataaux[$li_l]["spg_cuenta"])
							&& ($la_data[$li_k]["estpro"]==$la_dataaux[$li_l]["estpro"])
							&& ($la_data[$li_k]["scg_cuenta"]==$la_dataaux[$li_l]["scg_cuenta"]))
						{
							$li_pos=$li_i;
							$lb_existe=true;
						}
					}
					if(!$lb_existe)
					{
						$li_index=count($la_dataaux)+1;
						$la_dataaux[$li_index]=$la_data[$li_k];
					}
					else
					{
						
						$ls_monto_spg1   = uf_convertir($la_dataaux[$li_pos]["monto_spg"]);
						$ls_monto_spg2   = uf_convertir($la_data[$li_k]["monto_spg"]);
						$ls_monto_debe1  = uf_convertir($la_dataaux[$li_pos]["debe"]);
						$ls_monto_debe2  = uf_convertir($la_data[$li_k]["debe"]);
						$ls_monto_haber1 = uf_convertir($la_dataaux[$li_pos]["haber"]);
						$ls_monto_haber2 = uf_convertir($la_data[$li_k]["haber"]);
						$la_dataaux[$li_pos]["monto_spg"] = number_format(($ls_monto_spg1 + $ls_monto_spg2),2,",",".");
						if (($ls_monto_debe1 + $ls_monto_debe2) != 0)
							$la_dataaux[$li_pos]["debe"] = number_format(($ls_monto_debe1 + $ls_monto_debe2),2,",",".");
						else
							$la_dataaux[$li_pos]["debe"]="";
						if(($ls_monto_haber1 + $ls_monto_haber2) != 0)
							$la_dataaux[$li_pos]["haber"] = number_format(($ls_monto_haber1 + $ls_monto_haber2),2,",",".");
						else
							$la_dataaux[$li_pos]["haber"]="";
					}
					
				}
				
				$io_pdf->y=190;
				$io_pdf->y=440;	
				$io_pdf->set_margenes(138,70,$x_pos,0);//print_r ($la_dataaux);
				uf_print_detalle($la_dataaux,$io_pdf,$x_pos); // Imprimimos el detalle 	
				uf_print_totales($ld_montotdeb,$ld_montothab,$io_pdf);
			}
	

				if ($i<$li_total)
				{			
					$io_pdf->ezNewPage(); // Insertar una nueva página
					$io_pdf->set_margenes(0,0,$x_pos,0);
				}
		
			}// Fin del for 1
			$io_pdf->ezStopPageNumbers(1,1);
			$io_pdf->ezStream();
			unset($io_pdf,$class_report,$io_funciones,$ds_dt_spg,$ds_dt_scg,$ds_voucher,$la_data);
		}//Fin del if ($li_total>0)
		else
		{
			 print("<script language=JavaScript>");
			 print(" alert('No hay nada que Reportar');"); 
			 print(" close();");
			 print("</script>");	  
		} 
		
	} // Fin de si es lote
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// SI NO ES POR LOTE ENTONCES
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
	else 
	{	
			$ls_codemp=$_SESSION["la_empresa"]["codemp"];
			$ls_codban=$_GET["codban"];
			$ls_ctaban=$_GET["ctaban"];
			$ls_numdoc=$_GET["numdoc"];
			$ls_chevau=$_GET["chevau"];
			$ls_codope=$_GET["codope"];				
		
			$data=$class_report->uf_cargar_chq_voucher($ls_numdoc,$ls_chevau,$ls_codban,$ls_ctaban,$ls_codope);
			$class_report->SQL->begin_transaction();
			$lb_valido=$class_report->uf_actualizar_status_impreso($ls_numdoc,$ls_chevau,$ls_codban,$ls_ctaban,$ls_codope);
			if(!$lb_valido)
			{
				print "Error al actualizar";
				$class_report->is_msg_error;	
				$class_report->SQL->rollback();
			}
			else
			{
				$class_report->SQL->commit();
			}
			$ds_voucher->data=$data;
			//error_reporting(E_ALL);
			//set_time_limit(1800);
			$io_pdf=new class_pdf('LETTER','portrait'); // Instancia de la clase PDF
			$io_pdf->selectFont('../../shared/ezpdf/fonts/Helvetica.afm'); // Seleccionamos el tipo de letra	
			$io_pdf->set_margenes(0,0,$x_pos,0);	
			$li_totrow=$ds_voucher->getRowCount("numdoc");
			$io_pdf->transaction('start'); // Iniciamos la transacción
			$thisPageNum=$io_pdf->ezPageCount;
			for($li_i=1;$li_i<=$li_totrow;$li_i++)
			{
				unset($la_data);
				$li_totprenom=0;
				$ldec_mondeb=0;
				$ldec_monhab=0;
				$li_totant=0;
				$ls_numdoc=$ds_voucher->data["numdoc"][$li_i];
				$ls_codban=$ds_voucher->data["codban"][$li_i];
				$ls_nomban=$class_report->uf_select_data($io_sql,"SELECT * FROM scb_banco WHERE codban ='".$ls_codban."' AND codemp='".$ls_codemp."'","nomban");
				$ls_ctaban=$ds_voucher->data["ctaban"][$li_i];
				$ls_chevau=$ds_voucher->data["chevau"][$li_i];
				$ld_fecmov=$io_funciones->uf_convertirfecmostrar($ds_voucher->data["fecmov"][$li_i]);
				$ls_nomproben=$ds_voucher->data["nomproben"][$li_i];
				$ls_solicitudes=$class_report->uf_select_solicitudes($ls_numdoc,$ls_codban,$ls_ctaban);
				$ls_conmov=$ds_voucher->getValue("conmov",$li_i);
				$ldec_monret=$ds_voucher->getValue("monret",$li_i);
				$ldec_monto=$ds_voucher->getValue("monto",$li_i);
				$ldec_total=$ldec_monto-$ldec_monret;
				$ls_monto=$numalet->uf_convertir_letra($ldec_total,'','');
				$io_encabezado=$io_pdf->openObject();
				uf_print_encabezado_pagina(number_format($ldec_total,2,",","."),$ls_nomproben,$ls_monto,$_SESSION["la_empresa"]["ciuemp"].", ".$ld_fecmov,$io_pdf,$y_pos); // Imprimimos el encabezado de la página
				uf_print_cabecera($ls_numdoc,$ls_nomban,$ls_ctaban,$ls_nomproben,$ld_fecmov,$ls_conmov,$ls_chevau,$io_pdf); // Imprimimos la cabecera del registro
				$io_pdf->closeObject();
				$io_pdf->addObject($io_encabezado,'all');
				$ds_dt_scg->data=$class_report->uf_cargar_dt_scg($ls_numdoc,$ls_codban,$ls_ctaban,$ls_codope); // Obtenemos el detalle del reporte
				$ds_dt_spg->data=$class_report->uf_cargar_dt_spg($ls_numdoc,$ls_codban,$ls_ctaban,$ls_codope);
				$la_campos=array("scg_cuenta");
				$la_monto=array("monto");
				$ds_dt_scg->group_by($la_campos,$la_monto,"scg_cuenta");
				$la_campos=array("spg_cuenta","estpro");
				$ds_dt_spg->group_by($la_campos,$la_monto,"spg_cuenta");
				$li_totrow_det=$ds_dt_scg->getRowCount("scg_cuenta");
				$li_totrow_spg=$ds_dt_spg->getRowCount("spg_cuenta");
				$la_contable = array();
				$ld_montotdeb = $ld_montothab = 0;
				///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
				// Hago un ciclo para unir en una sola matriz los detalles de presupuesto y los contables para proceder luego a pintarlos
				if($li_totrow_det>=$li_totrow_spg)
				{
					for($li_s=1;$li_s<=$li_totrow_det;$li_s++)
					{
						$ls_scg_cuenta = trim($ds_dt_scg->data["scg_cuenta"][$li_s]);
						$ls_scg_cuenta = substr($ls_scg_cuenta,0,1).'-'.substr($ls_scg_cuenta,1,2).'-'.substr($ls_scg_cuenta,3,2).'-'.substr($ls_scg_cuenta,5,2).'-'.substr($ls_scg_cuenta,7,2).'-'.substr($ls_scg_cuenta,9,3);
						$ls_denctascg  = $ds_dt_scg->data["denominacion"][$li_s];
						$ls_debhab     = $ds_dt_scg->data["debhab"][$li_s];
						$ldec_monto    = $ds_dt_scg->data["monto"][$li_s];
						if($ls_debhab=='D')
						{
							$ld_montotdeb += $ldec_monto;
							$ldec_mondeb=number_format($ldec_monto,2,",",".");
							$ldec_monhab=" ";
						}
						else
						{
							$ld_montothab += $ldec_monto;
							$ldec_monhab=number_format($ldec_monto,2,",",".");
							$ldec_mondeb=" ";
						}
						if(array_key_exists("spg_cuenta",$ds_dt_spg->data))
						{
							if(array_key_exists($li_s,$ds_dt_spg->data["spg_cuenta"]))
							{
								$ls_cuentaspg   = trim($ds_dt_spg->getValue("spg_cuenta",$li_s));
								$ls_denctaspg   = $ds_dt_spg->getValue("denominacion",$li_s);	
								$ls_estpro      = $ds_dt_spg->getValue("estpro",$li_s);	  
								$ls_codestpro1  = substr($ls_estpro,14,6);
								$ls_codestpro2  = substr($ls_estpro,21,6);
								$ls_estpro      = $ls_codestpro1.'-'.$ls_codestpro2;
								$ldec_monto_spg = number_format($ds_dt_spg->getValue("monto",$li_s),2,",",".");
							}
							else
							{
								$ls_cuentaspg=" ";	
								$ls_estpro=" ";	  
								$ldec_monto_spg=" ";
								$ls_denctaspg = "";
							}
						}
						else
						{
							$ls_cuentaspg=" ";	
							$ls_estpro=" ";	  
							$ldec_monto_spg=" ";
							$ls_denctaspg = "";
						}
						$la_data[$li_s]=array('estpro'=>$ls_estpro,'spg_cuenta'=>$ls_cuentaspg,'denctaspg'=>$ls_denctaspg,'monto_spg'=>$ldec_monto_spg,'scg_cuenta'=>$ls_scg_cuenta,'denctascg'=>$ls_denctascg,'debe'=>$ldec_mondeb,'haber'=>$ldec_monhab);
					}
				}
				
				if($li_totrow_spg>$li_totrow_det)
				{
					for($li_s=1;$li_s<=$li_totrow_spg;$li_s++)
					{
						if(array_key_exists("scg_cuenta",$ds_dt_scg->data))
						{
							if(array_key_exists($li_s,$ds_dt_scg->data["scg_cuenta"]))
							{
								$ls_scg_cuenta = trim($ds_dt_scg->data["scg_cuenta"][$li_s]);
								$ls_scg_cuenta = substr($ls_scg_cuenta,0,1).'-'.substr($ls_scg_cuenta,1,2).'-'.substr($ls_scg_cuenta,3,2).'-'.substr($ls_scg_cuenta,5,2).'-'.substr($ls_scg_cuenta,7,2).'-'.substr($ls_scg_cuenta,9,3);
								$ls_denctascg  = $ds_dt_scg->data["denominacion"][$li_s];
								$ls_debhab     = $ds_dt_scg->data["debhab"][$li_s];
								$ldec_monto    = $ds_dt_scg->data["monto"][$li_s];
								if($ls_debhab=='D')
								{
									$ld_montotdeb += $ldec_monto;
									$ldec_mondeb=number_format($ldec_monto,2,",",".");
									$ldec_monhab=" ";
								}
								else
								{
									$ld_montothab += $ldec_monto;
									$ldec_monhab=number_format($ldec_monto,2,",",".");
									$ldec_mondeb=" ";
								}
							}
							else
							{
								$ls_scg_cuenta="";
								$ls_denctascg="";
								$ls_debhab = "";
								$ldec_monto= "";
								$ldec_mondeb="";
								$ldec_monhab="";					
							}
						}
						else
						{
							$ls_scg_cuenta="";
							$ls_denctascg ="";
							$ls_debhab = "";
							$ldec_monto= "";
							$ldec_mondeb="";
							$ldec_monhab="";					
						}
						if(array_key_exists("spg_cuenta",$ds_dt_spg->data))
						{
							if(array_key_exists($li_s,$ds_dt_spg->data["spg_cuenta"]))
							{
								$ls_cuentaspg   = trim($ds_dt_spg->getValue("spg_cuenta",$li_s));
								$ls_denctaspg   = $ds_dt_spg->getValue("denominacion",$li_s);	
								$ls_estpro      = $ds_dt_spg->getValue("estpro",$li_s);	  
								$ldec_monto_spg = number_format($ds_dt_spg->getValue("monto",$li_s),2,",",".");
							}
							else
							{
								$ls_cuentaspg=" ";	
								$ls_estpro=" ";	  
								$ldec_monto_spg=" ";
							}
						}
						else
						{
							$ls_cuentaspg=" ";	
							$ls_estpro=" ";	  
							$ldec_monto_spg=" ";
						}
						$la_data[$li_s]=array('estpro'=>$ls_estpro,'spg_cuenta'=>$ls_cuentaspg,'denctaspg'=>$ls_denctaspg,'monto_spg'=>$ldec_monto_spg,'scg_cuenta'=>$ls_scg_cuenta,'denctascg'=>$ls_denctascg,'debe'=>$ldec_mondeb,'haber'=>$ldec_monhab);
					}
				}
				////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
				if(empty($la_data))
				{
					$ls_cuentaspg='';
					$ls_estpro='';
					$ldec_monto_spg='';
					$ls_scg_cuenta='';
					$ls_denctascg="";
					$ldec_mondeb='';
					$ldec_monhab='';
					$la_data[1]=array('estpro'=>$ls_estpro,'spg_cuenta'=>$ls_cuentaspg,'denctaspg'=>$ls_denctaspg,'monto_spg'=>$ldec_monto_spg,'scg_cuenta'=>$ls_scg_cuenta,'denctascg'=>$ls_denctascg,'debe'=>$ldec_mondeb,'haber'=>$ldec_monhab);
					$la_data[2]=array('estpro'=>$ls_estpro,'spg_cuenta'=>$ls_cuentaspg,'denctaspg'=>$ls_denctaspg,'monto_spg'=>$ldec_monto_spg,'scg_cuenta'=>$ls_scg_cuenta,'denctascg'=>$ls_denctascg,'debe'=>$ldec_mondeb,'haber'=>$ldec_monhab);
					$la_data[3]=array('estpro'=>$ls_estpro,'spg_cuenta'=>$ls_cuentaspg,'denctaspg'=>$ls_denctaspg,'monto_spg'=>$ldec_monto_spg,'scg_cuenta'=>$ls_scg_cuenta,'denctascg'=>$ls_denctascg,'debe'=>$ldec_mondeb,'haber'=>$ldec_monhab);
				}
				//codigo para unir las cuentas iguales
				$la_dataaux=array();
				for($li_k=1;$li_k<=count($la_data);$li_k++)
				{
					$lb_existe=false;
					$li_pos=0;
					for($li_l=1;$li_l<=count($la_dataaux);$li_l++)
					{
						if(($la_data[$li_k]["spg_cuenta"]==$la_dataaux[$li_l]["spg_cuenta"])
							&& ($la_data[$li_k]["estpro"]==$la_dataaux[$li_l]["estpro"])
							&& ($la_data[$li_k]["scg_cuenta"]==$la_dataaux[$li_l]["scg_cuenta"]))
						{
							$li_pos=$li_i;
							$lb_existe=true;
						}
					}
					if(!$lb_existe)
					{
						$li_index=count($la_dataaux)+1;
						$la_dataaux[$li_index]=$la_data[$li_k];
					}
					else
					{
						
						$ls_monto_spg1   = uf_convertir($la_dataaux[$li_pos]["monto_spg"]);
						$ls_monto_spg2   = uf_convertir($la_data[$li_k]["monto_spg"]);
						$ls_monto_debe1  = uf_convertir($la_dataaux[$li_pos]["debe"]);
						$ls_monto_debe2  = uf_convertir($la_data[$li_k]["debe"]);
						$ls_monto_haber1 = uf_convertir($la_dataaux[$li_pos]["haber"]);
						$ls_monto_haber2 = uf_convertir($la_data[$li_k]["haber"]);
						$la_dataaux[$li_pos]["monto_spg"] = number_format(($ls_monto_spg1 + $ls_monto_spg2),2,",",".");
						if (($ls_monto_debe1 + $ls_monto_debe2) != 0)
							$la_dataaux[$li_pos]["debe"] = number_format(($ls_monto_debe1 + $ls_monto_debe2),2,",",".");
						else
							$la_dataaux[$li_pos]["debe"]="";
						if(($ls_monto_haber1 + $ls_monto_haber2) != 0)
							$la_dataaux[$li_pos]["haber"] = number_format(($ls_monto_haber1 + $ls_monto_haber2),2,",",".");
						else
							$la_dataaux[$li_pos]["haber"]="";
					}
					
				}
				
				$io_pdf->y=190;
				$io_pdf->y=440;	
				$io_pdf->set_margenes(138,70,$x_pos,0);//print_r ($la_dataaux);
				uf_print_detalle($la_dataaux,$io_pdf,$x_pos); // Imprimimos el detalle 	
				uf_print_totales($ld_montotdeb,$ld_montothab,$io_pdf);
			}
			$io_pdf->ezStopPageNumbers(1,1);
			$io_pdf->ezStream();
			unset($io_pdf);
			unset($class_report);
			unset($io_funciones);
	}
?> 