ObraController.php 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. <?php
  2. namespace app\modules\excel\controllers;
  3. use v1\models\ObraEmpleado;
  4. use v1\models\Usuario;
  5. use DateTime;
  6. use DateTimeZone;
  7. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  8. use PhpOffice\PhpSpreadsheet\Style\Alignment;
  9. use PhpOffice\PhpSpreadsheet\Style\NumberFormat;
  10. use PhpOffice\PhpSpreadsheet\Worksheet\Drawing;
  11. use v1\models\Obra;
  12. use Yii;
  13. use yii\web\Controller;
  14. class ObraController extends Controller {
  15. public function actionExcelObra($idObra) {
  16. $obra = Obra::findOne($idObra);
  17. $request = Yii::$app->request;
  18. $spreadsheet = new Spreadsheet();
  19. $sheet = $spreadsheet->getActiveSheet();
  20. $sheet->setTitle('Empleados');
  21. $BASEPATH = \Yii::getAlias('@app') . "/web";
  22. $logo = $BASEPATH . '/img/logos/edesarrollos-unicolor-azul.png';
  23. $fechaInicio = (new DateTime($obra->fechaInicio))->format('d-m-Y');
  24. $fechaFin = (new DateTime($obra->fechaFinal))->format('d-m-Y');
  25. $drawing = new Drawing();
  26. $drawing->setName('Logotipo');
  27. $drawing->setDescription('Logotipo de la empresa');
  28. $drawing->setPath($logo);
  29. $drawing->setHeight(70);
  30. $drawing->setCoordinates('A1');
  31. $drawing->setOffsetX(10);
  32. $drawing->setOffsetY(10);
  33. $drawing->setWorksheet($sheet);
  34. $sheet->mergeCells('A5:N5');
  35. $sheet->setCellValue('A5','Obra: ' . $obra->nombre);
  36. $sheet->mergeCells('A6:G6');
  37. $sheet->setCellValue('A6','Fecha Inicial: ' .$fechaInicio);
  38. $sheet->mergeCells('H6:N6');
  39. $sheet->setCellValue('H6','Fecha Final: ' .$fechaFin);
  40. $sheet->getStyle('A5')->getFont()->setBold(true);
  41. $sheet->getStyle('A5')->getFont()->setSize(16);
  42. $headerStyle = [
  43. 'font' => [
  44. 'bold' => true,
  45. 'color' => ['argb' => 'FFFFFFFF'] // Letras en blanco
  46. ],
  47. 'alignment' => [
  48. 'horizontal' => Alignment::HORIZONTAL_CENTER,
  49. 'vertical' => Alignment::VERTICAL_CENTER,
  50. 'wrapText' => true
  51. ],
  52. 'fill' => [
  53. 'fillType' => \PhpOffice\PhpSpreadsheet\Style\Fill::FILL_SOLID,
  54. 'startColor' => ['argb' => 'FF625FF5'] // Fondo azul (con opacidad FF)
  55. ],
  56. 'borders' => [
  57. 'allBorders' => [
  58. 'borderStyle' => \PhpOffice\PhpSpreadsheet\Style\Border::BORDER_THIN,
  59. 'color' => ['argb' => 'FF020073'], // Bordes azul oscuro (con opacidad FF)
  60. ],
  61. ],
  62. ];
  63. // Aplicar el borde a las celdas combinadas
  64. $sheet->getStyle('A5:N5')->applyFromArray( $headerStyle);
  65. $sheet->getStyle('A6:G6')->applyFromArray( $headerStyle);
  66. $sheet->getStyle('H6:N6')->applyFromArray( $headerStyle);
  67. //Empleados
  68. $empleados= ObraEmpleado::find()
  69. ->joinWith('empleado')
  70. ->andWhere(['{{ObraEmpleado}}.[[eliminado]]'=>null])->andWhere(['{{ObraEmpleado}}.[[idObra]]'=>$idObra]);
  71. $empleados->orderBy(['creado' => SORT_DESC]);
  72. $sheet->mergeCells('A8:G8');
  73. $sheet->setCellValue('A8', 'Empleados');
  74. $sheet->getStyle('A8:G8')->applyFromArray( $headerStyle);
  75. $sheet->mergeCells('A9:D9');
  76. $sheet->setCellValue('A9', 'Nombre');
  77. $sheet->getStyle('A9:D9')->applyFromArray( $headerStyle);
  78. $sheet->mergeCells('E9:G9');
  79. $sheet->setCellValue('E9', 'Fecha Alta');
  80. $sheet->getStyle('E9:G9')->applyFromArray( $headerStyle);
  81. $cellBorderStyle = [
  82. 'borders' => [
  83. 'allBorders' => [
  84. 'borderStyle' => \PhpOffice\PhpSpreadsheet\Style\Border::BORDER_THIN,
  85. 'color' => ['argb' => 'FF000000'], // Color negro
  86. ],
  87. ],
  88. ];
  89. $row = 10;
  90. foreach ($empleados->each() as $obraEmpleado) {
  91. $empleado = $obraEmpleado->empleado;
  92. $sheet->mergeCells('A' . $row . ':D' . $row);
  93. $sheet->setCellValue('A' . $row, $empleado->nombre);
  94. $sheet->getStyle('A' . $row . ':D' . $row)->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_JUSTIFY);
  95. $sheet->getStyle('A' . $row . ':D' . $row)->applyFromArray($cellBorderStyle);
  96. $sheet->mergeCells('E' . $row . ':G' . $row);
  97. $sheet->setCellValue('E' . $row, $empleado->fechaAlta);
  98. $sheet->getStyle('E' . $row . ':G' . $row)->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_JUSTIFY);
  99. $sheet->getStyle('E' . $row . ':G' . $row)->applyFromArray($cellBorderStyle);
  100. $row++;
  101. }
  102. //Herramientas
  103. /*
  104. // Aplicar el borde a las celdas combinadas
  105. $sheet->getStyle('A5:J5')->applyFromArray( $headerStyle);
  106. $sheet->getStyle('A6:E6')->applyFromArray( $headerStyle);
  107. $sheet->getStyle('F6:J6')->applyFromArray( $headerStyle);
  108. $sheet->mergeCells('A8:B8');
  109. $sheet->getStyle('A8:B8')->applyFromArray( $headerStyle);
  110. $sheet->setCellValue('A8', 'Gasto total');
  111. $sheet->mergeCells('C8:D8');
  112. $sheet->getStyle('C8:D8')->applyFromArray( $headerStyle);
  113. $sheet->setCellValue('C8', 'Pago total');
  114. $sheet->mergeCells('E8:G8');
  115. $sheet->getStyle('E8:G8')->applyFromArray( $headerStyle);
  116. $sheet->setCellValue('E8', 'Pago total');
  117. $sheet->mergeCells('H8:J8');
  118. $sheet->getStyle('E8:F8')->applyFromArray( $headerStyle);
  119. $sheet->setCellValue('E8', 'Pago total');
  120. */
  121. $sheet->getStyle('A5')->getAlignment()->setHorizontal(Alignment::HORIZONTAL_CENTER);
  122. $writer = new \PhpOffice\PhpSpreadsheet\Writer\Xlsx($spreadsheet);
  123. try {
  124. ob_start();
  125. $writer->save("php://output");
  126. $documento = ob_get_contents();
  127. ob_clean();
  128. Yii::$app->getResponse()->sendContentAsFile($documento, "Obra.xlsx");
  129. } catch (\Exception $exception) {
  130. return null;
  131. }
  132. }
  133. }