From 60e8725ac3db63dcefbecf0cfe3121edea0cb170 Mon Sep 17 00:00:00 2001 From: nat Date: Sat, 1 Oct 2022 15:29:31 -0300 Subject: [PATCH 01/11] exportar csv de pedidos --- app/GrupoDeCompra.php | 41 ++++++++++++++--------- app/Http/Controllers/AdminController.php | 7 ++++ app/Producto.php | 12 +++++++ resources/js/components/SubpedidosGdc.vue | 8 +++++ routes/web.php | 1 + 5 files changed, 53 insertions(+), 16 deletions(-) diff --git a/app/GrupoDeCompra.php b/app/GrupoDeCompra.php index 0d4fb66..0e22a5d 100644 --- a/app/GrupoDeCompra.php +++ b/app/GrupoDeCompra.php @@ -34,23 +34,32 @@ class GrupoDeCompra extends Model $mpdf->Output(); } - public function exportarPedidoEnCSV(){ - $productos = Producto::pluck('id','fila')->all(); - $ultima_fila = end(array_keys($productos)); - $productos_en_pedido = DB::table('pedidos_aprobados')->where('grupo_de_compra_id',$this->id)->get()->keyBy('producto_id'); - - $records = []; - for ($i=1; $i <= $ultima_fila; $i++) { - if ($productos[$i]) { - if ($productos_en_pedido[$productos[$i]]){ - $producto_en_pedido = $productos_en_pedido[$productos[$i]]; - $records[] = [$producto_en_pedido->producto_nombre,$producto_en_pedido->cantidad_pedida]; - } else { - $records[] = ['producto no pedido',0]; - } - } else { - $records[] = ['','']; + //Asume que los productos están gruadados en orden de fila + private function obtenerTemplateDeFilasVacias(){ + $productosFilaID = Producto::productosFilaID(); + $productosIDNombre = Producto::productosIDNombre(); + $num_fila = 1; + $template = []; + foreach ($productosFilaID as $fila => $id) { + for ($i = $num_fila; $i < $fila; $i++) { + $template[$i] = ["", "0"]; } + $template[$fila] = [$productosIDNombre[$id], "0"]; + $num_fila = $fila+1; + } + return $template; + } + + public function exportarPedidoEnCSV(){ + $productos_en_pedido = DB::table('pedidos_aprobados')->where('grupo_de_compra_id',$this->id)->get()->keyBy('producto_id'); + + //si no hay pedidos aprobados, salir + if ($productos_en_pedido->count() == 0) { \Log::debug("El grupo de compra ". $this->nombre . " no tiene pedidos aprobados."); return; } + $records = $this->obtenerTemplateDeFilasVacias(); + $productos_id_fila = Producto::productosIdFila(); + foreach ($productos_en_pedido as $id => $producto_pedido){ + $fila = $productos_id_fila[$id]; + $records[$fila][1] = $producto_pedido->cantidad_pedida; } try { diff --git a/app/Http/Controllers/AdminController.php b/app/Http/Controllers/AdminController.php index d5b1bef..804b084 100644 --- a/app/Http/Controllers/AdminController.php +++ b/app/Http/Controllers/AdminController.php @@ -4,6 +4,7 @@ namespace App\Http\Controllers; use App\GrupoDeCompra; use Illuminate\Http\Request; +use Response; class AdminController extends Controller { @@ -19,4 +20,10 @@ class AdminController extends Controller public function exportarPlanillasAPdf(GrupoDeCompra $gdc) { return $gdc->exportarPlanillasAPdf(); } + + public function exportarPedidoACSV(GrupoDeCompra $gdc) { + $gdc->exportarPedidoEnCSV(); + $file = resource_path('csv/exports/'.$gdc->nombre.'.csv'); + return response()->download($file); + } } diff --git a/app/Producto.php b/app/Producto.php index aa9059f..a37d16a 100644 --- a/app/Producto.php +++ b/app/Producto.php @@ -32,5 +32,17 @@ class Producto extends Model { return $request->has('paginar') && intval($request->input('paginar')) ? intval($request->input('paginar')) : self::$paginarPorDefecto; } + + public static function productosIDFila() { + return Producto::pluck('fila', 'id',)->all(); + } + + public static function productosFilaID() { + return Producto::pluck('id', 'fila',)->all(); + } + + public static function productosIDNombre() { + return Producto::pluck('nombre', 'id',)->all(); + } } diff --git a/resources/js/components/SubpedidosGdc.vue b/resources/js/components/SubpedidosGdc.vue index c216c68..c72268b 100644 --- a/resources/js/components/SubpedidosGdc.vue +++ b/resources/js/components/SubpedidosGdc.vue @@ -1,6 +1,14 @@