request; $spreadsheet = new Spreadsheet(); $sheet = $spreadsheet->getActiveSheet(); $sheet->setTitle('Informacion General'); $BASEPATH = \Yii::getAlias('@app') . "/web"; $logo = $BASEPATH . '/img/logos/edesarrollos-unicolor-azul.png'; $fechaInicio = (new DateTime($obra->fechaInicio))->format('d-m-Y'); $fechaFin = (new DateTime($obra->fechaFinal))->format('d-m-Y'); $drawing = new Drawing(); $drawing->setName('Logotipo'); $drawing->setDescription('Logotipo de la empresa'); $drawing->setPath($logo); $drawing->setHeight(70); $drawing->setCoordinates('A1'); $drawing->setOffsetX(10); $drawing->setOffsetY(10); $drawing->setWorksheet($sheet); $sheet->mergeCells('A5:N5'); $sheet->setCellValue('A5', 'Obra: ' . $obra->nombre); $sheet->mergeCells('A6:G6'); $sheet->setCellValue('A6', 'Fecha Inicial: ' . $fechaInicio); $sheet->mergeCells('H6:N6'); $sheet->setCellValue('H6', 'Fecha Final: ' . $fechaFin); $sheet->getStyle('A5')->getFont()->setBold(true); $sheet->getStyle('A5')->getFont()->setSize(16); $headerStyle = [ 'font' => [ 'bold' => true, 'color' => ['argb' => 'FFFFFFFF'] // Letras en blanco ], 'alignment' => [ 'horizontal' => Alignment::HORIZONTAL_CENTER, 'vertical' => Alignment::VERTICAL_CENTER, 'wrapText' => true ], 'fill' => [ 'fillType' => \PhpOffice\PhpSpreadsheet\Style\Fill::FILL_SOLID, 'startColor' => ['argb' => 'FF625FF5'] // Fondo azul (con opacidad FF) ], 'borders' => [ 'allBorders' => [ 'borderStyle' => \PhpOffice\PhpSpreadsheet\Style\Border::BORDER_THIN, 'color' => ['argb' => 'FF020073'], // Bordes azul oscuro (con opacidad FF) ], ], ]; // Aplicar el borde a las celdas combinadas $sheet->getStyle('A5:N5')->applyFromArray($headerStyle); $sheet->getStyle('A6:G6')->applyFromArray($headerStyle); $sheet->getStyle('H6:N6')->applyFromArray($headerStyle); //Empleados $empleados = ObraEmpleado::find() ->joinWith('empleado') ->andWhere(['{{ObraEmpleado}}.[[eliminado]]' => null])->andWhere(['{{ObraEmpleado}}.[[idObra]]' => $idObra]); $empleados->orderBy(['creado' => SORT_DESC]); $sheet->mergeCells('A8:G8'); $sheet->setCellValue('A8', 'Empleados'); $sheet->getStyle('A8:G8')->applyFromArray($headerStyle); $sheet->mergeCells('A9:D9'); $sheet->setCellValue('A9', 'Nombre'); $sheet->getStyle('A9:D9')->applyFromArray($headerStyle); $sheet->mergeCells('E9:G9'); $sheet->setCellValue('E9', 'Fecha Alta'); $sheet->getStyle('E9:G9')->applyFromArray($headerStyle); $cellBorderStyle = [ 'borders' => [ 'allBorders' => [ 'borderStyle' => \PhpOffice\PhpSpreadsheet\Style\Border::BORDER_THIN, 'color' => ['argb' => 'FF000000'], // Color negro ], ], ]; $rowEmpleados = 10; foreach ($empleados->each() as $obraEmpleado) { $empleado = $obraEmpleado->empleado; $fecha = (new DateTime($empleado->fechaAlta))->format('d-m-Y'); $sheet->mergeCells('A' . $rowEmpleados . ':D' . $rowEmpleados); $sheet->setCellValue('A' . $rowEmpleados, $empleado->nombre); $sheet->getStyle('A' . $rowEmpleados . ':D' . $rowEmpleados)->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_JUSTIFY); $sheet->getStyle('A' . $rowEmpleados . ':D' . $rowEmpleados)->applyFromArray($cellBorderStyle); $sheet->mergeCells('E' . $rowEmpleados . ':G' . $rowEmpleados); $sheet->setCellValue('E' . $rowEmpleados, $fecha); $sheet->getStyle('E' . $rowEmpleados . ':G' . $rowEmpleados)->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_JUSTIFY); $sheet->getStyle('E' . $rowEmpleados . ':G' . $rowEmpleados)->applyFromArray($cellBorderStyle); $rowEmpleados++; } //Herramientas $query = ObraHerramienta::find() ->joinWith('herramienta') ->andWhere(['{{ObraHerramienta}}.[[eliminado]]' => null])->andWhere(['{{ObraHerramienta}}.[[idObra]]' => $idObra]); $query->orderBy(['creado' => SORT_DESC]); $sheet->mergeCells('H8:N8'); $sheet->setCellValue('H8', 'Herramientas'); $sheet->getStyle('H8:N8')->applyFromArray($headerStyle); $sheet->mergeCells('H9:K9'); $sheet->setCellValue('H9', 'Herramienta'); $sheet->getStyle('H9:K9')->applyFromArray($headerStyle); $sheet->mergeCells('L9:N9'); $sheet->setCellValue('L9', 'Cantidad'); $sheet->getStyle('L9:N9')->applyFromArray($headerStyle); $rowHerramientas = 10; foreach ($query->each() as $obraHerramienta) { $herramienta = $obraHerramienta->herramienta; $sheet->mergeCells('H' . $rowHerramientas . ':K' . $rowHerramientas); $sheet->setCellValue('H' . $rowHerramientas, $herramienta->nombre); // Nombre del empleado $sheet->getStyle('H' . $rowHerramientas . ':K' . $rowHerramientas)->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_JUSTIFY); $sheet->getStyle('H' . $rowHerramientas . ':K' . $rowHerramientas)->applyFromArray($cellBorderStyle); $sheet->mergeCells('L' . $rowHerramientas . ':N' . $rowHerramientas); $sheet->setCellValue('L' . $rowHerramientas, $obraHerramienta->cantidad); // Nombre del empleado $sheet->getStyle('L' . $rowHerramientas . ':N' . $rowHerramientas)->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_JUSTIFY); $sheet->getStyle('L' . $rowHerramientas . ':N' . $rowHerramientas)->applyFromArray($cellBorderStyle); $rowHerramientas++; } //Totales $totalesController = new \v1\controllers\ObraController('totales', Yii::$app); $totalGasto = $totalesController->actionTotalGasto($idObra); $totalPago = $totalesController->actionTotalPago($idObra); $totalNomina = $totalesController->actionTotalNomina($idObra); $totalRubro = $totalesController->actionTotalRubro($idObra); $saldo = $totalesController->actionSaldo($totalGasto, $totalNomina, $totalPago); $ejercidoObra = $totalesController->actionEjercidoObra($totalGasto, $totalRubro); $ejercer = $totalesController->actionEjercer($totalRubro, $totalPago); $startRowTotales = max($rowEmpleados, $rowHerramientas) + 2; // Gasto total $sheet->mergeCells("A{$startRowTotales}:B{$startRowTotales}"); $sheet->getStyle("A{$startRowTotales}:B{$startRowTotales}")->applyFromArray($headerStyle); $sheet->setCellValue("A{$startRowTotales}", 'Gasto total'); $sheet->mergeCells("A" . ($startRowTotales + 1) . ":B" . ($startRowTotales + 1)); // Merge en la fila de resultados $sheet->setCellValue("A" . ($startRowTotales + 1), $totalGasto); $sheet->getStyle("A" . ($startRowTotales + 1))->getNumberFormat()->setFormatCode('"$"#,##0'); $sheet->getStyle("A" . ($startRowTotales + 1). ":B" . ($startRowTotales + 1))->applyFromArray($cellBorderStyle); // Pago total $sheet->mergeCells("C{$startRowTotales}:D{$startRowTotales}"); $sheet->getStyle("C{$startRowTotales}:D{$startRowTotales}")->applyFromArray($headerStyle); $sheet->setCellValue("C{$startRowTotales}", 'Pago total'); $sheet->mergeCells("C" . ($startRowTotales + 1) . ":D" . ($startRowTotales + 1)); // Merge en la fila de resultados $sheet->setCellValue("C" . ($startRowTotales + 1), $totalPago); $sheet->getStyle("C" . ($startRowTotales + 1))->getNumberFormat()->setFormatCode('"$"#,##0'); $sheet->getStyle("C" . ($startRowTotales + 1). ":D". ($startRowTotales + 1))->applyFromArray($cellBorderStyle); // Nómina total $sheet->mergeCells("E{$startRowTotales}:F{$startRowTotales}"); $sheet->getStyle("E{$startRowTotales}:F{$startRowTotales}")->applyFromArray($headerStyle); $sheet->setCellValue("E{$startRowTotales}", 'Nómina total'); $sheet->mergeCells("E" . ($startRowTotales + 1) . ":F" . ($startRowTotales + 1)); // Merge en la fila de resultados $sheet->setCellValue("E" . ($startRowTotales + 1), $totalNomina); $sheet->getStyle("E" . ($startRowTotales + 1))->getNumberFormat()->setFormatCode('"$"#,##0'); $sheet->getStyle("E" . ($startRowTotales + 1).":F". ($startRowTotales + 1))->applyFromArray($cellBorderStyle); // Rubro de Obra total $sheet->mergeCells("G{$startRowTotales}:H{$startRowTotales}"); $sheet->getStyle("G{$startRowTotales}:H{$startRowTotales}")->applyFromArray($headerStyle); $sheet->setCellValue("G{$startRowTotales}", 'Rubro de Obra total'); $sheet->mergeCells("G" . ($startRowTotales + 1) . ":H" . ($startRowTotales + 1)); // Merge en la fila de resultados $sheet->setCellValue("G" . ($startRowTotales + 1), $totalRubro); $sheet->getStyle("G" . ($startRowTotales + 1))->getNumberFormat()->setFormatCode('"$"#,##0'); $sheet->getStyle("G" . ($startRowTotales + 1). ":H". ($startRowTotales + 1))->applyFromArray($cellBorderStyle); // Saldo total $sheet->mergeCells("I{$startRowTotales}:J{$startRowTotales}"); $sheet->getStyle("I{$startRowTotales}:J{$startRowTotales}")->applyFromArray($headerStyle); $sheet->setCellValue("I{$startRowTotales}", 'Saldo total'); $sheet->mergeCells("I" . ($startRowTotales + 1) . ":J" . ($startRowTotales + 1)); // Merge en la fila de resultados $sheet->setCellValue("I" . ($startRowTotales + 1), $saldo); $sheet->getStyle("I" . ($startRowTotales + 1))->getNumberFormat()->setFormatCode('"$"#,##0'); $sheet->getStyle("I" . ($startRowTotales + 1). ":J" . ($startRowTotales + 1))->applyFromArray($cellBorderStyle); // Ejercido obra $sheet->mergeCells("K{$startRowTotales}:L{$startRowTotales}"); $sheet->getStyle("K{$startRowTotales}:L{$startRowTotales}")->applyFromArray($headerStyle); $sheet->setCellValue("K{$startRowTotales}", 'Ejercido obra'); $sheet->mergeCells("K" . ($startRowTotales + 1) . ":L" . ($startRowTotales + 1)); // Merge en la fila de resultados $sheet->setCellValue("K" . ($startRowTotales + 1), $ejercidoObra); $sheet->getStyle("K" . ($startRowTotales + 1))->getNumberFormat()->setFormatCode('"$"#,##0'); $sheet->getStyle("K" . ($startRowTotales + 1). ":L". ($startRowTotales + 1))->applyFromArray($cellBorderStyle); // Por ejercer $sheet->mergeCells("M{$startRowTotales}:N{$startRowTotales}"); $sheet->getStyle("M{$startRowTotales}:N{$startRowTotales}")->applyFromArray($headerStyle); $sheet->setCellValue("M{$startRowTotales}", 'Por ejercer'); $sheet->mergeCells("M" . ($startRowTotales + 1) . ":N" . ($startRowTotales + 1)); // Merge en la fila de resultados $sheet->setCellValue("M" . ($startRowTotales + 1), $ejercer); $sheet->getStyle("M" . ($startRowTotales + 1))->getNumberFormat()->setFormatCode('"$"#,##0'); $sheet->getStyle("M" . ($startRowTotales + 1). ":N" . ($startRowTotales + 1))->applyFromArray($cellBorderStyle); $excelGasto= new \app\modules\excel\controllers\ObraGastoController('totales', Yii::$app); $sheetGasto = $excelGasto->actionExcelGasto($idObra); $spreadsheet->addSheet($sheetGasto); $excelPago= new \app\modules\excel\controllers\ObraPagoController('totales', Yii::$app); $sheetPago = $excelPago->actionExcelPago($idObra); $spreadsheet->addSheet($sheetPago); $excelNomina= new \app\modules\excel\controllers\ObraNominaController('totales', Yii::$app); $sheetNomina = $excelNomina->actionExcelNomina($idObra); $spreadsheet->addSheet($sheetNomina); $excelRubro= new \app\modules\excel\controllers\ObraRubroController('totales', Yii::$app); $sheetRubro = $excelRubro->actionExcelRubro($idObra); $spreadsheet->addSheet($sheetRubro); $sheet->getStyle('A5')->getAlignment()->setHorizontal(Alignment::HORIZONTAL_CENTER); $writer = new \PhpOffice\PhpSpreadsheet\Writer\Xlsx($spreadsheet); try { ob_start(); $writer->save("php://output"); $documento = ob_get_contents(); ob_clean(); Yii::$app->getResponse()->sendContentAsFile($documento, "Obra.xlsx"); } catch (\Exception $exception) { return null; } } }