Comming ucUs SH3LL V.2

Path : /home/gujo45me/public_html/margarita/pdf/
Disable Functions : exec,passthru,shell_exec,system
System : Linux server-604606.appsiete.com 3.10.0-1160.119.1.el7.tuxcare.els25.x86_64 #1 SMP Wed Oct 1 17:37:27 UTC 2025 x86_64

[ Home ][ Zone-h ][ Jumping ][ Symlink ][ Mass Depes ][ Command ]

File Upload :
Current File : /home/gujo45me/public_html/margarita/pdf/reporteUsuarios.php

<?php 

	include("config.php");
	require_once("phpexcel/PHPExcel.php");

	if (PHP_SAPI == 'cli')
    	die('Este archivo solo se puede ver desde un navegador web');
	
	// Se crea el objeto PHPExcel
	$objPHPExcel = new PHPExcel();

	$id_usuario = $_GET['id_usuario'];
	$pago = $_GET['tipo_pago'];
	$fecha1 = $_GET['fecha1'];
	$fecha2 = $_GET['fecha2'];

	$conexion = new mysqli($db_host,$db_user,$db_pass,$db_name);
	if (mysqli_connect_errno()) {
	   printf("La conexión con el servidor de base de datos falló: %s\n", mysqli_connect_error());
	   exit();
	}

	$consulta2 =  null;
	$consulta3 =  null;

	if ($id_usuario == 0) {
		$consulta = 'SELECT v.id_venta as id, l.nombre as local, u.nombres AS "nombres", u.apellidos AS "apellidos", c.nombre AS "Titular", c.numero_documento AS "NUM", DATE_FORMAT(v.created_at, "%d-%m-%Y %h:%i:%s") AS "Fecha de Venta", nombre_comprobante, total_venta AS "Monto S/", tipo_pago , observacion FROM ventas v INNER JOIN usuarios u ON v.id_usuario = u.id_usuario INNER JOIN clientes c ON v.id_cliente = c.id_cliente INNER JOIN local l ON l.id_local = v.id_local WHERE (v.created_at >= "'.$fecha1.'" AND v.created_at <= "'.$fecha2.'") AND v.id_nota is null AND v.tipo_pago = "'.$pago.'" AND v.estado="1" ORDER BY v.created_at ASC';

		if ($pago == "EFECTIVO") {
			$consulta2 = 'SELECT p.id_proforma as id, l.nombre as local, u.nombres AS "nombres", u.apellidos AS "apellidos", p.nombre AS "Titular", p.numero_documento AS "NUM", DATE_FORMAT(p.created_at, "%d-%m-%Y %h:%i:%s") AS "Fecha de Venta", "PEDIDO" as nombre_comprobante, adelanto AS "Monto S/", "ADELANTO" as tipo_pago , observacion FROM proformas p INNER JOIN usuarios u ON p.id_usuario = u.id_usuario INNER JOIN local l ON l.id_local = p.id_local WHERE (p.created_at >= "'.$fecha1.'" AND p.created_at <= "'.$fecha2.'") AND p.estado=1 AND p.adelanto is not null ORDER BY p.created_at ASC';

			$consulta3 = 'SELECT dc.id_detalle_credito as id , lv.nombre AS local_venta,lp.nombre AS local_proforma,  u.nombres AS "nombres", u.apellidos AS "apellidos", c.nombre AS cliente_venta, p.nombre AS cliente_proforma, c.numero_documento AS documento_venta, p.numero_documento AS documento_proforma, DATE_FORMAT(dc.created_at, "%d-%m-%Y %h:%i:%s") AS "Fecha de Venta", "RECIBO" AS comprobante_venta, "RECIBO" AS comprobante_proforma, dc.monto AS "Monto S/", "PAGO DE LETRA" as tipo_pago , dc.observacion as observacion  FROM detalle_credito dc LEFT JOIN usuarios u ON dc.id_usuario = u.id_usuario LEFT JOIN ventas v ON dc.id_venta = v.id_venta LEFT JOIN local lv ON lv.id_local = v.id_local LEFT JOIN clientes c ON c.id_cliente = v.id_cliente LEFT JOIN proformas p ON dc.id_proforma = p.id_proforma LEFT JOIN local lp ON lp.id_local = p.id_local WHERE (dc.created_at >= "'.$fecha1.'" AND dc.created_at <= "'.$fecha2.'") AND dc.estado = 1 ORDER BY p.created_at ASC';

			$resultado2 = $conexion->query($consulta2);
			$resultado3 = $conexion->query($consulta3);
		}
	}
	else{
		$consulta = 'SELECT v.id_venta as id, l.nombre as local, u.nombres AS "nombres", u.apellidos AS "apellidos", c.nombre AS "Titular", c.numero_documento AS "NUM", DATE_FORMAT(v.created_at, "%d-%m-%Y %h:%i:%s") AS "Fecha de Venta", nombre_comprobante, total_venta AS "Monto S/" , tipo_pago , observacion FROM ventas v INNER JOIN usuarios u ON v.id_usuario = u.id_usuario INNER JOIN clientes c ON v.id_cliente = c.id_cliente INNER JOIN local l ON l.id_local = v.id_local WHERE (v.created_at >= "'.$fecha1.'" AND v.created_at <= "'.$fecha2.'") AND v.id_nota is null AND v.id_usuario= "'.$id_usuario.'" AND v.tipo_pago = "'.$pago.'" AND v.estado="1" ORDER BY v.created_at ASC';

		if ($pago == "EFECTIVO") {

			$consulta2 = 'SELECT p.id_proforma as id, l.nombre as local, u.nombres AS "nombres", u.apellidos AS "apellidos", p.nombre AS "Titular", p.numero_documento AS "NUM", DATE_FORMAT(p.created_at, "%d-%m-%Y %h:%i:%s") AS "Fecha de Venta", "PEDIDO" as nombre_comprobante, adelanto AS "Monto S/", "ADELANTO" as tipo_pago, observacion FROM proformas p INNER JOIN usuarios u ON p.id_usuario = u.id_usuario INNER JOIN local l ON l.id_local = p.id_local WHERE (p.created_at >= "'.$fecha1.'" AND p.created_at <= "'.$fecha2.'") AND p.estado=1 AND p.adelanto is not null AND p.id_usuario= "'.$id_usuario.'" ORDER BY p.created_at ASC';

			$consulta3 = 'SELECT  dc.id_detalle_credito as id , lv.nombre AS local_venta,lp.nombre AS local_proforma,  u.nombres AS "nombres", u.apellidos AS "apellidos", c.nombre AS cliente_venta, p.nombre AS cliente_proforma, c.numero_documento AS documento_venta, p.numero_documento AS documento_proforma, DATE_FORMAT(dc.created_at, "%d-%m-%Y %h:%i:%s") AS "Fecha de Venta", "RECIBO" AS comprobante_venta, "RECIBO" AS comprobante_proforma, dc.monto AS "Monto S/", "PAGO DE LETRA" as tipo_pago, dc.observacion as observacion FROM detalle_credito dc LEFT JOIN usuarios u ON dc.id_usuario = u.id_usuario LEFT JOIN ventas v ON dc.id_venta = v.id_venta LEFT JOIN local lv ON lv.id_local = v.id_local LEFT JOIN clientes c ON c.id_cliente = v.id_cliente LEFT JOIN proformas p ON dc.id_proforma = p.id_proforma LEFT JOIN local lp ON lp.id_local = p.id_local WHERE (dc.created_at >= "'.$fecha1.'" AND dc.created_at <= "'.$fecha2.'") AND dc.estado = 1 AND dc.id_usuario= "'.$id_usuario.'" ORDER BY p.created_at ASC';

			$resultado2 = $conexion->query($consulta2);
			$resultado3 = $conexion->query($consulta3);

		}
	}
	
	$resultado = $conexion->query($consulta);
	
	if($resultado->num_rows > 0 || $resultado2->num_rows > 0 || $resultado3->num_rows > 0 ){

		// Propiedades del documento
		$objPHPExcel->getProperties()->setCreator("Seven")
									 ->setLastModifiedBy("Seven")
									 ->setTitle("Reporte de VENTAS POR PERSONAL")
									 ->setSubject("Reporte de VENTAS POR PERSONAL")
									 ->setDescription("Reporte de VENTAS POR PERSONAL")
									 ->setKeywords("office 2010 openxml php")
									 ->setCategory("Archivo con resultado de reporte");
		
		// Combino las celdas desde A1 hasta F1
		$objPHPExcel->setActiveSheetIndex(0)->mergeCells('A1:H1');
		$objPHPExcel->setActiveSheetIndex(0)
		            ->setCellValue('A1', 'REPORTE DE VENTAS POR PERSONAL ENTRE : '.$fecha1.' & '.$fecha2)
		            ->setCellValue('A2', 'ITEM')
		            ->setCellValue('B2', 'LOCAL')
		            ->setCellValue('C2', 'PERSONAL')
		            ->setCellValue('D2', 'CLIENTE')
		            ->setCellValue('E2', 'RUC / DNI')
					->setCellValue('F2', 'FECHA DE EMISION')
					->setCellValue('G2', 'COMPROBANTE')
					->setCellValue('H2', 'MONTO S/')
					->setCellValue('I2', 'TIPO DE PAGO')
					->setCellValue('J2', 'OBSERVACION');
					
		// Fuente de la primera fila en negrita
		$boldArray = array('font' => array('bold' => true,),'alignment' => array('horizontal' => PHPExcel_Style_Alignment::HORIZONTAL_CENTER));
		$objPHPExcel->getActiveSheet()->getStyle('A1:J2')->applyFromArray($boldArray);


		//Ancho de las columnas
		$objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth(8);	
		$objPHPExcel->getActiveSheet()->getColumnDimension('B')->setWidth(40);	
		$objPHPExcel->getActiveSheet()->getColumnDimension('C')->setWidth(60);	
		$objPHPExcel->getActiveSheet()->getColumnDimension('D')->setWidth(80);	
		$objPHPExcel->getActiveSheet()->getColumnDimension('E')->setWidth(20);	
		$objPHPExcel->getActiveSheet()->getColumnDimension('F')->setWidth(30);
		$objPHPExcel->getActiveSheet()->getColumnDimension('G')->setWidth(20);
        $objPHPExcel->getActiveSheet()->getColumnDimension('H')->setWidth(20);
        $objPHPExcel->getActiveSheet()->getColumnDimension('I')->setWidth(20);
        $objPHPExcel->getActiveSheet()->getColumnDimension('J')->setWidth(100);
	
		$i = 3; //Numero de fila donde se va a comenzar a rellenar
		$suma = 0;
		$j = 1;

		if (!is_null($consulta)) {
			while ($fila = $resultado->fetch_array()) {
				$objPHPExcel->setActiveSheetIndex(0)
				    ->setCellValue('A'.$i, $j)
				    ->setCellValue('B'.$i, utf8_encode($fila['local']))
				    ->setCellValue('C'.$i, utf8_encode($fila['nombres'] .' '. $fila['apellidos']))
				    ->setCellValue('D'.$i, utf8_encode($fila['Titular']))
				    ->setCellValue('E'.$i, $fila['NUM'])
				    ->setCellValue('F'.$i, $fila['Fecha de Venta'])
				    ->setCellValue('G'.$i, $fila['nombre_comprobante'])
				    ->setCellValue('H'.$i, $fila['Monto S/'])
				    ->setCellValue('I'.$i, $fila['tipo_pago'])
				    ->setCellValue('J'.$i, $fila['observacion']);
				$i++;
				$j++;
				$suma = $suma+$fila['Monto S/'];
			}
		}
			
		if (!is_null($consulta2)) {
			while ($fila = $resultado2->fetch_array()) {
				$objPHPExcel->setActiveSheetIndex(0)
				    ->setCellValue('A'.$i, $j)
				    ->setCellValue('B'.$i, utf8_encode($fila['local']))
				    ->setCellValue('C'.$i, utf8_encode($fila['nombres'] .' '. $fila['apellidos']))
				    ->setCellValue('D'.$i, utf8_encode($fila['Titular']))
				    ->setCellValue('E'.$i, $fila['NUM'])
				    ->setCellValue('F'.$i, $fila['Fecha de Venta'])
				    ->setCellValue('G'.$i, $fila['nombre_comprobante']." N° ".$fila['id'])
				    ->setCellValue('H'.$i, $fila['Monto S/'])
				    ->setCellValue('I'.$i, $fila['tipo_pago'])
				    ->setCellValue('J'.$i, utf8_encode($fila['observacion']));
				$i++;
				$j++;
				$suma = $suma+$fila['Monto S/'];
			}
		}
		
		if (!is_null($consulta3)) {
			while ($fila = $resultado3->fetch_array()) {
				$objPHPExcel->setActiveSheetIndex(0)
				    ->setCellValue('A'.$i, $j)
				    ->setCellValue('B'.$i, utf8_encode( $fila['local_venta'] == null ? $fila['local_proforma'] : $fila['local_venta'] ))
				    ->setCellValue('C'.$i, utf8_encode( $fila['nombres'] .' '. $fila['apellidos'] ))
				    ->setCellValue('D'.$i, utf8_encode( $fila['cliente_venta'] == null ? $fila['cliente_proforma'] : $fila['cliente_venta']   ))
				    ->setCellValue('E'.$i, $fila['documento_venta'] == null ? $fila['documento_proforma'] : $fila['documento_venta'] )
				    ->setCellValue('F'.$i, $fila['Fecha de Venta'])
				    ->setCellValue('G'.$i, $fila['comprobante_venta']." N° ".$fila['id'])
				    ->setCellValue('H'.$i, $fila['Monto S/'])
				    ->setCellValue('I'.$i, $fila['tipo_pago'])
				    ->setCellValue('J'.$i, utf8_encode($fila['observacion']));
				$i++;
				$j++;
				$suma = $suma+$fila['Monto S/'];
			}
		}

		$objPHPExcel->setActiveSheetIndex(0)->setCellValue('G'.$i, "TOTAL");
		$objPHPExcel->setActiveSheetIndex(0)->setCellValue('H'.$i, $suma);
		$objPHPExcel->getActiveSheet()->getStyle('G'.$i)->getFont()->setBold(true);
		$objPHPExcel->getActiveSheet()->getStyle('H'.$i)->getFont()->setBold(true);
		$objPHPExcel->getActiveSheet()->getStyle('H3:H'.$i)->getNumberFormat()->setFormatCode('0.00');

		$i = $i-1;
		$H = "J".$i;
		$rango = "A2:$H";
		$styleArray = array('font' => array( 'name' => 'Arial','size' => 10),
		'borders'=>array('allborders'=>array('style'=> PHPExcel_Style_Border::BORDER_THIN,'color'=>array('argb' => 'FFF')))
		);
		$objPHPExcel->getActiveSheet()->getStyle($rango)->applyFromArray($styleArray);

		// Cambiar el nombre de hoja de cálculo
		$objPHPExcel->getActiveSheet()->setTitle('Reporte');

		// Establecer índice de hoja activa a la primera hoja , por lo que Excel abre esto como la primera hoja
		$objPHPExcel->setActiveSheetIndex(0);

		// Se manda el archivo al navegador web, con el nombre que se indica, en formato 2007
		header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
		header('Content-Disposition: attachment;filename="Reporte_Personal.xlsx"');
		header('Cache-Control: max-age=0');
		 
		$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
		$objWriter->save('php://output');
		exit;

	}
	else{
	    print_r('No hay resultados para mostrar');
	}



	







Copyright © 2019 | Powered By MecUs7