123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326 |
- <?php
- namespace app\modules\excel\controllers;
- use DateTime;
- use DateTimeZone;
- use PhpOffice\PhpSpreadsheet\Spreadsheet;
- use PhpOffice\PhpSpreadsheet\Style\Alignment;
- use PhpOffice\PhpSpreadsheet\Style\Fill;
- use PhpOffice\PhpSpreadsheet\Style\NumberFormat;
- use PhpOffice\PhpSpreadsheet\Worksheet\Drawing;
- use v1\models\Obra;
- use v1\models\Pago;
- use Yii;
- use excel\web\Controller;
- use yii\web\Response;
- class ObraPagoController extends Controller {
- //Version de hugo
- public static $estiloCeldaIzquierda12 = [
- 'font' => [
- 'bold' => true,
- 'size' => 12,
- 'color' => ['argb' => 'FF000000'],
- ],
- 'alignment' => [
- 'horizontal' => Alignment::HORIZONTAL_LEFT,
- 'vertical' => Alignment::VERTICAL_CENTER,
- ],
- ];
- public static $celdaVertical = [
- 'font' => [
- 'bold' => true,
- 'size' => 14,
- 'color' => ['argb' => 'FFFFFFFF'],
- ],
- 'alignment' => [
- // 'textRotation' => 90,
- 'horizontal' => Alignment::HORIZONTAL_CENTER,
- 'vertical' => Alignment::VERTICAL_CENTER
- ],
- 'fill' => [
- 'fillType' => Fill::FILL_SOLID,
- 'startColor' => ['argb' => "FF625FF5"]
- ],
- ];
- public static $celdaHorizontal = [
- 'font' => [
- 'bold' => true,
- 'size' => 14,
- 'color' => ['argb' => 'FF000000'],
- ],
- 'alignment' => [
- 'horizontal' => Alignment::HORIZONTAL_CENTER,
- 'vertical' => Alignment::VERTICAL_CENTER
- ],
- 'fill' => [
- 'fillType' => Fill::FILL_SOLID,
- 'startColor' => ['argb' => "FFE7E7E7"]
- ],
- ];
- public static $celdaFuente12 = [
- 'font' => [
- 'bold' => true,
- 'size' => 10,
- 'color' => ['argb' => 'FF000000'],
- ],
- 'alignment' => [
- 'horizontal' => Alignment::HORIZONTAL_LEFT,
- 'vertical' => Alignment::VERTICAL_CENTER
- ],
- ];
- public static $celdaVerticalF12 = [
- 'font' => [
- 'bold' => true,
- 'size' => 10,
- 'color' => ['argb' => 'FF000000'],
- ],
- 'alignment' => [
- 'textRotation' => 90,
- 'horizontal' => Alignment::HORIZONTAL_CENTER,
- 'vertical' => Alignment::VERTICAL_CENTER
- ],
- 'fill' => [
- 'fillType' => Fill::FILL_SOLID,
- 'startColor' => ['argb' => "FFE7E7E7"]
- ],
- ];
- public function encabezadoHoja($logo)
- {
- $celdas = [
- "A1" => [
- "valor" => $logo,
- "combinar" => "G4",
- ],
- ];
- foreach ($celdas as $coordenada => $valor) {
- $this->agregarCelda($coordenada, $valor);
- }
- $this->renglonActual = 6;
- return $this;
- }
- public function actionExcelObraPago($idObra) {
- $json = intval($this->req->get("json", ""));
- $obra = Obra::findOne($idObra);
- $query= Pago::find()
- ->joinWith('conceptosObra')
- ->andWhere(['{{Pago}}.[[eliminado]]'=>null])->andWhere(['{{Pago}}.[[idObra]]'=>$idObra]);
- $query->orderBy(['fechaPago' => SORT_DESC]);
- if ($json) {
- \Yii::$app->getResponse()->format = Response::FORMAT_JSON;
- return $json;
- }
-
- $BASEPATH = \Yii::getAlias('@app') . "/web";
- $logo = $BASEPATH . '/img/logos/edesarrollos-unicolor-azul.png';
- $this->encabezadoHoja($this->logo($logo, 'A1'));
- $fechaInicio = (new DateTime($obra->fechaInicio))->format('d-m-Y');
- $fechaFin = (new DateTime($obra->fechaFinal))->format('d-m-Y');
- $estiloEncabezado = array_merge(self::$celdaVertical, self::$bordes);
- $encabezadoTabla = [
- "A6" => [
- "valor" => "Pagos relacionado a la obra: $obra->nombre",
- "combinar" => "D6",
- "estilo" => $estiloEncabezado
- ],
- "A7" => [
- "valor" => "Fecha Inicial: $fechaInicio ",
- "combinar" => "B7",
- "estilo" => $estiloEncabezado
- ],
- "C7" => [
- "valor" => "Fecha Final: $fechaFin",
- "combinar" => "D7",
- "estilo" => $estiloEncabezado
- ]
- ];
-
- $this->agregarRenglones($encabezadoTabla);
-
- $encabezadoTabla = [
- "A9" => [
- "valor" => "Concepto Obra",
- "estilo" => $estiloEncabezado
- ],
- "B9" => [
- "valor" => "Cantidad ",
- "estilo" => $estiloEncabezado
- ],
- "C9" => [
- "valor" => "Fecha Pago",
- "estilo" => $estiloEncabezado
- ],
- "D9" => [
- "valor" => "Descripción",
- "estilo" => $estiloEncabezado
- ]
- ];
-
- $r = 10;
- $this->agregarRenglones($encabezadoTabla);
- $estiloCeldaIzquierda = array_merge(self::$bordes, self::$celdaFuente12);
- $estiloCondicional = $this->estiloCondicional();
-
- foreach ($query->each() as $obraPago) {
- $fecha = (new DateTime($obraPago->fechaPago))->format('d-m-Y');
- $Pago = $obraPago->conceptosObra;
-
- $renglones = [
- "A{$r}" => [
- "valor" => $Pago->concepto,
- "estilo" => $estiloCeldaIzquierda
- ],
- "B{$r}" => [
- "valor" => $obraPago->cantidad,
- "estilo" => $estiloCeldaIzquierda,
- "formato" => "$#,##0.00",
- "estiloCondicional" => $estiloCondicional
-
- ],
- "C{$r}" => [
- "valor" => $fecha,
- "estilo" => $estiloCeldaIzquierda
- ],
- "D{$r}" => [
- "valor" => $obraPago->descripcion,
- "estilo" => $estiloCeldaIzquierda
- ]
- ];
- $this->agregarRenglones($renglones);
- $r += 1;
- }
- $anchoColumnas = [
- "A" => ["ancho" => 20],
- "B" => ["ancho" => 20],
- "C" => ["ancho" => 20],
- "D" => ["ancho" => 20],
- ];
- $this->anchoColumnas($anchoColumnas);
- $documento = $this->obtenerHojaDeCalculo();
- $this->crear($documento, "Pago_" . date("YmdHis"), self::TIPO_EXCEL);
- \Yii::$app->end();
- }
- public function actionPagoConceptoExcel($idObra)
- {
- $json = intval($this->req->get("json", ""));
-
- $obra = Obra::findOne($idObra);
- $query = Pago::find()
- ->select(['{{ConceptoObra}}.[[concepto]] AS concepto', 'SUM({{Pago}}.[[cantidad]]) AS totalPago'])
- ->innerJoin('{{ConceptoObra}}', '{{Pago}}.[[idConceptoObra]] = {{ConceptoObra}}.[[id]]')
- ->andWhere(['{{Pago}}.[[eliminado]]' => null])
- ->andWhere(['{{Pago}}.[[idObra]]' => $idObra])
- ->groupBy('{{ConceptoObra}}.[[id]]')
- ->asArray()
- ->all();
- if ($json) {
- \Yii::$app->getResponse()->format = Response::FORMAT_JSON;
- return $json;
- }
-
- $BASEPATH = \Yii::getAlias('@app') . "/web";
- $logo = $BASEPATH . '/img/logos/edesarrollos-unicolor-azul.png';
- $this->encabezadoHoja($this->logo($logo, 'A1'));
- $fechaInicio = (new DateTime($obra->fechaInicio))->format('d-m-Y');
- $fechaFin = (new DateTime($obra->fechaFinal))->format('d-m-Y');
- $estiloEncabezado = array_merge(self::$celdaVertical, self::$bordes);
- $encabezadoTabla = [
- "A6" => [
- "valor" => "Pagos por Concepto de Obra, relacionado a la obra: $obra->nombre",
- "combinar" => "D6",
- "estilo" => $estiloEncabezado
- ],
- "A7" => [
- "valor" => "Fecha Inicial: $fechaInicio ",
- "combinar" => "B7",
- "estilo" => $estiloEncabezado
- ],
- "C7" => [
- "valor" => "Fecha Final: $fechaFin",
- "combinar" => "D7",
- "estilo" => $estiloEncabezado
- ]
- ];
-
- $this->agregarRenglones($encabezadoTabla);
-
- $encabezadoTabla = [
- "A9" => [
- "valor" => "Concepto Obra",
- "estilo" => $estiloEncabezado
- ],
- "B9" => [
- "valor" => "Total:",
- "estilo" => $estiloEncabezado
- ],
-
- ];
-
- $r = 10;
- $estiloCondicional = $this->estiloCondicional();
- $this->agregarRenglones($encabezadoTabla);
- $estiloCeldaIzquierda = array_merge(self::$bordes, self::$celdaFuente12);
- $TotalPago= 0;
- foreach ($query as $obraPago) {
- $TotalPago=$TotalPago+$obraPago['totalPago'];
- $renglones = [
- "A{$r}" => [
- "valor" => $obraPago['concepto'],
- "estilo" => $estiloCeldaIzquierda
- ],
- "B{$r}" => [
- "valor" => $obraPago['totalPago'],
- "estilo" => $estiloCeldaIzquierda,
- "formato" => "$#,##0.00",
- "estiloCondicional" => $estiloCondicional
-
- ],
-
- ];
- $this->agregarRenglones($renglones);
- $r += 1;
- }
- $r+=1;
- $renglonesTotales = [
- "A{$r}" => [
- "valor" => "TOTAL",
- "estilo" => $estiloEncabezado
- ],
- "B{$r}" => [
- "valor" => $TotalPago,
- "estilo" => $estiloCeldaIzquierda,
- "formato" => "$#,##0.00",
- "estiloCondicional" => $estiloCondicional
- ],
- ];
- $this->agregarRenglones($renglonesTotales);
- $anchoColumnas = [
- "A" => ["ancho" => 20],
- "B" => ["ancho" => 20],
- "C" => ["ancho" => 20],
- "D" => ["ancho" => 20],
- ];
- $this->anchoColumnas($anchoColumnas);
- $documento = $this->obtenerHojaDeCalculo();
- $this->crear($documento, "PagoConcepto_" . date("YmdHis"), self::TIPO_EXCEL);
- \Yii::$app->end();
- return $documento;
- }
- }
|