| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287 |
- <?php
- namespace App\Http\Controllers;
- use Illuminate\Support\Facades\Log;
- use Illuminate\Http\Request;
- use Illuminate\Support\Facades\DB;
- use Illuminate\Support\Facades\Storage;
- use PhpOffice\PhpSpreadsheet\Spreadsheet;
- use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
- use PhpOffice\PhpSpreadsheet\Style\Fill;
- use PhpOffice\PhpSpreadsheet\Style\Border;
- use PhpOffice\PhpSpreadsheet\Worksheet\Drawing;
- class NivelExportController extends Controller
- {
- public function exportarExcel(Request $request)
- {
- $tabla = $request->input('tabla');
- switch ($tabla) {
- case 'niveles':
- return $this->generarReporte('niveles', 'NIVELES EDUCATIVOS', ['idNivel', 'nombreNivel', 'estado']);
- case 'materias_categorias':
- return $this->generarReporte('materias_categorias', 'CATEGORÍAS DE MATERIAS', ['categoria', 'ordenBoleta', 'estado']);
- case 'materias':
- return $this->generarReporte('materias', 'MATERIAS', ['idMateria','categoria','nombreMateria','idGradoGrupoRelacionado','afectaBoleta','materiaAcademica','mostrarMateria','estado']);
- case 'grados':
- return $this->generarReporte('vista_grados_niveles', 'GRADOS', ['idGrado', 'nombreGrado', 'nombreNivel']);
- case 'grupos':
- return $this->generarReporte('grupos', 'GRUPOS', ['idGrupo', 'nombreGrupo','Estado']);
- case 'usuarios':
- return $this->generarReporte('usuarios', 'USUARIOS', ['idUsuario', 'tipoUsuario', 'primerNombre','apellidoPaterno','grado','estatus']);
- case 'tipos_tareas':
- return $this->generarReporte('tareas_tipos', 'TIPOS DE TAREAS', ['idTareasTipos', 'nombreTareasTipos', 'envioPlatTareasTipos','estado']);
- case 'relacion_Alumno':
- return $this->generarReporte('vista_alumnos_padres_grupos', 'Relacion Alumno', ['idUsuario', 'nombreAlumno', 'grado','nombrePadre','nombreGrupo']);
- case 'profesor':
- return $this->generarReporte('vista_profesores_materias_grupos', 'Relacion Profesores', ['idUsuario', 'nombreProfesor', 'idMateria','gradoGrupo']);
- case 'periodos':
- return $this->generarReporte('periodos', 'Periodos', ['idPeriodo', 'fechaFinalizacion', 'estatus']);
- default:
- return response()->json(['error' => 'Tabla no válida'], 400);
- }
- }
- private function aclararColor(string $hexColor, float $factor = 0.7): string
- {
- $hexColor = ltrim($hexColor, '#');
- $r = hexdec(substr($hexColor, 0, 2));
- $g = hexdec(substr($hexColor, 2, 2));
- $b = hexdec(substr($hexColor, 4, 2));
- $r = min(255, (int)($r + (255 - $r) * $factor));
- $g = min(255, (int)($g + (255 - $g) * $factor));
- $b = min(255, (int)($b + (255 - $b) * $factor));
- return sprintf('%02X%02X%02X', $r, $g, $b);
- }
- private function generarReporte($tabla, $titulo, $headers)
- {
- $spreadsheet = new Spreadsheet();
- $sheet = $spreadsheet->getActiveSheet();
- $colorEncabezado = DB::table('personalizar')->value('PERPR_COL_BAR') ?: '4F81BD';
- $colorEncabezado = ltrim($colorEncabezado, '#');
- // Título
- $sheet->mergeCells('A1:P2');
- $sheet->setCellValue('A1', "REPORTE DE $titulo");
- $sheet->getStyle('A1:P2')->applyFromArray([
- 'font' => ['bold' => true, 'size' => 18, 'name' => 'Century', 'color' => ['rgb' => 'FFFFFF']],
- 'alignment' => ['horizontal' => \PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_CENTER,
- 'vertical' => \PhpOffice\PhpSpreadsheet\Style\Alignment::VERTICAL_CENTER],
- 'fill' => ['fillType' => Fill::FILL_SOLID, 'startColor' => ['rgb' => $colorEncabezado]],
- 'borders' => ['bottom' => ['borderStyle' => Border::BORDER_THICK, 'color' => ['rgb' => 'FFFFFF']]],
- ]);
- $sheet->getRowDimension(1)->setRowHeight(70);
- // Logo
- $logoPathS3 = DB::table('personalizar')->value('PERLOGO');
- if ($logoPathS3 && Storage::disk('s3')->exists($logoPathS3)) {
- $tempLogoPath = tempnam(sys_get_temp_dir(), 'logo');
- file_put_contents($tempLogoPath, Storage::disk('s3')->get($logoPathS3));
- $logo = new Drawing();
- $logo->setName('Logo');
- $logo->setDescription('Logo de la empresa');
- $logo->setPath($tempLogoPath);
- $logo->setHeight(90);
- $logo->setCoordinates('A1');
- $logo->setOffsetX(10);
- $logo->setOffsetY(5);
- $logo->setWorksheet($sheet);
- }
- // Descripción
- $sheet->mergeCells('H3:J3');
- $sheet->setCellValue('H3', "Este reporte muestra los datos registrados en la tabla $tabla.");
- $sheet->getStyle('H3')->applyFromArray([
- 'font' => ['italic' => true, 'size' => 10, 'name' => 'Century', 'color' => ['rgb' => '333333']],
- 'alignment' => ['horizontal' => \PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_CENTER,
- 'vertical' => \PhpOffice\PhpSpreadsheet\Style\Alignment::VERTICAL_CENTER],
- ]);
- // Encabezados
- $sheet->fromArray($headers, null, 'H4');
- $lastCol = chr(72 + count($headers) - 1);
- $sheet->getStyle("H4:$lastCol" . '4')->applyFromArray([
- 'font' => ['bold' => true, 'color' => ['rgb' => 'FFFFFF'], 'size' => 12, 'name' => 'Century'],
- 'fill' => ['fillType' => Fill::FILL_SOLID, 'startColor' => ['rgb' => $colorEncabezado]],
- 'alignment' => ['horizontal' => \PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_CENTER,
- 'vertical' => \PhpOffice\PhpSpreadsheet\Style\Alignment::VERTICAL_CENTER],
- 'borders' => ['allBorders' => ['borderStyle' => Border::BORDER_THIN, 'color' => ['rgb' => 'FFFFFF']]],
- ]);
- // Datos con paginación
- $datos = DB::table($tabla)
- ->select($headers)
- ->get();
- $row = 5;
- $colorClaro = $this->aclararColor($colorEncabezado, 0.85);
- foreach ($datos as $index => $registro) {
- $col = 'H';
- foreach ((array)$registro as $value) {
- $sheet->setCellValue($col . $row, $value);
- $col++;
- }
- $sheet->getRowDimension($row)->setRowHeight(25);
- $fillColor = $index % 2 === 0 ? $colorClaro : 'FFFFFF';
- $sheet->getStyle("H$row:$lastCol$row")->applyFromArray([
- 'fill' => ['fillType' => Fill::FILL_SOLID, 'startColor' => ['rgb' => $fillColor]],
- 'font' => ['name' => 'Calibri', 'size' => 11],
- 'borders' => ['allBorders' => ['borderStyle' => Border::BORDER_THIN, 'color' => ['rgb' => 'BFBFBF']]],
- ]);
- $row++;
- }
- foreach (range('H', $lastCol) as $col) {
- $sheet->getColumnDimension($col)->setAutoSize(true);
- }
- $sheet->setAutoFilter("H4:$lastCol" . '4');
- $writer = new Xlsx($spreadsheet);
- $filename = "$titulo.xlsx";
- return response()->streamDownload(function () use ($writer) {
- $writer->save('php://output');
- }, $filename, [
- 'Content-Type' => 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
- ]);
- }
- public function exportarAlumnosRegistro()
- {
- // === Reutilizamos tu lógica para obtener los datos ===
- $data = DB::table('usuarios')
- ->leftJoin('registroacademico', 'usuarios.idUsuario', '=', 'registroacademico.idAlumno')
- ->leftJoin('usuarios as u2', 'u2.idUsuario', '=', 'registroacademico.usuarioRegistro')
- ->select(
- DB::raw("CONCAT(COALESCE(usuarios.primerNombre, ''), ' ', COALESCE(usuarios.segundoNombre, ''), ' ', COALESCE(usuarios.apellidoPaterno, ''), ' ', COALESCE(usuarios.apellidoMaterno, '')) AS nombreCompleto"),
- DB::raw("CONCAT(COALESCE(u2.primerNombre, ''), ' ', COALESCE(u2.segundoNombre, ''), ' ', COALESCE(u2.apellidoPaterno, ''), ' ', COALESCE(u2.apellidoMaterno, '')) AS nombrePadre"),
- 'usuarios.idUsuario',
- 'registroacademico.*'
- )
- ->where('usuarios.tipoUsuario', 'AL')
- ->get()
- ->map(function($item) {
- $hasEmptyField = collect($item)->some(fn($v) => $v === null || $v === '');
- return [
- 'idUsuario' => $item->idUsuario,
- 'quienRegistra' => $item->nombrePadre ?: 'No Aplica',
- 'ultActualizacion' => $item->lastUpdate ?: 'No Aplica',
- 'nombreCompleto' => $item->nombreCompleto,
- 'registroAcCompleto' => $hasEmptyField ? 'No' : 'Sí'
- ];
- });
- $dataAd = DB::table('usuarios')
- ->select('usuarios.idUsuario','registroadministrativo.*')
- ->leftJoin('registroadministrativo', 'usuarios.idUsuario', '=', 'registroadministrativo.idAlumno')
- ->where('usuarios.tipoUsuario', 'AL')
- ->get()
- ->map(function($item) {
- $hasEmptyField = collect($item)->some(fn($v) => $v === null || $v === '');
- return [
- 'idUsuario' => $item->idUsuario,
- 'registroAdCompleto' => $hasEmptyField ? 'No' : 'Sí'
- ];
- });
- $completo = $dataAd->map(function($item) use ($data) {
- $registro = $data->firstWhere('idUsuario', $item['idUsuario']);
- return [
- 'idUsuario' => $item['idUsuario'],
- 'quienRegistra' => $registro['quienRegistra'],
- 'ultActualizacion' => $registro['ultActualizacion'],
- 'nombreCompleto' => $registro['nombreCompleto'],
- 'registroAcCompleto' => $registro['registroAcCompleto'],
- 'registroAdCompleto' => $item['registroAdCompleto']
- ];
- })->toArray();
- // === Ahora formateamos el Excel ===
- $spreadsheet = new Spreadsheet();
- $sheet = $spreadsheet->getActiveSheet();
- $titulo = "REPORTE DE ALUMNOS";
- $headers = ['ID', 'Alumno', 'Quién Registró', 'Última Actualización', 'Académico Completo', 'Administrativo Completo'];
- // Estilos título
- $sheet->mergeCells('A1:F2');
- $sheet->setCellValue('A1', $titulo);
- $sheet->getStyle('A1:F2')->applyFromArray([
- 'font' => ['bold' => true, 'size' => 18, 'name' => 'Century', 'color' => ['rgb' => 'FFFFFF']],
- 'alignment' => ['horizontal' => 'center', 'vertical' => 'center'],
- 'fill' => ['fillType' => Fill::FILL_SOLID, 'startColor' => ['rgb' => '4F81BD']],
- ]);
- $sheet->getRowDimension(1)->setRowHeight(50);
- // Logo
- $logoPathS3 = DB::table('personalizar')->value('PERLOGO');
- if ($logoPathS3 && Storage::disk('s3')->exists($logoPathS3)) {
- $tempLogoPath = tempnam(sys_get_temp_dir(), 'logo');
- file_put_contents($tempLogoPath, Storage::disk('s3')->get($logoPathS3));
- $logo = new Drawing();
- $logo->setPath($tempLogoPath);
- $logo->setHeight(80);
- $logo->setCoordinates('A1');
- $logo->setWorksheet($sheet);
- }
- // Encabezados
- $sheet->fromArray($headers, null, 'A4');
- $sheet->getStyle("A4:F4")->applyFromArray([
- 'font' => ['bold' => true, 'color' => ['rgb' => 'FFFFFF'], 'size' => 12],
- 'fill' => ['fillType' => Fill::FILL_SOLID, 'startColor' => ['rgb' => '4F81BD']],
- 'alignment' => ['horizontal' => 'center'],
- 'borders' => ['allBorders' => ['borderStyle' => Border::BORDER_THIN]],
- ]);
- // Datos
- $row = 5;
- foreach ($completo as $index => $item) {
- $sheet->fromArray([
- $item['idUsuario'],
- $item['nombreCompleto'],
- $item['quienRegistra'],
- $item['ultActualizacion'],
- $item['registroAcCompleto'],
- $item['registroAdCompleto'],
- ], null, "A$row");
- $fillColor = $index % 2 === 0 ? 'F2F2F2' : 'FFFFFF';
- $sheet->getStyle("A$row:F$row")->applyFromArray([
- 'fill' => ['fillType' => Fill::FILL_SOLID, 'startColor' => ['rgb' => $fillColor]],
- 'font' => ['name' => 'Calibri', 'size' => 11],
- 'borders' => ['allBorders' => ['borderStyle' => Border::BORDER_THIN, 'color' => ['rgb' => 'BFBFBF']]],
- ]);
- $row++;
- }
- foreach (range('A', 'F') as $col) {
- $sheet->getColumnDimension($col)->setAutoSize(true);
- }
- $sheet->setAutoFilter("A4:F4");
- $writer = new Xlsx($spreadsheet);
- $filename = "Alumnos_Registro.xlsx";
- return response()->streamDownload(function () use ($writer) {
- $writer->save('php://output');
- }, $filename, [
- 'Content-Type' => 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
- ]);
- }
- }
|