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 @@ <template> <div class="container is-max-widescreen is-max-desktop animate__animated" :class="animation" v-show="!init"> <div class="buttons is-right"> + <a class="button is-success" :href="'/admin/exportar-pedido-a-csv/'+gdc"> + <span> + Exportar pedido barrial + </span> + <span class="icon is-small"> + <i class="fas fa-download"></i> + </span> + </a> <a class="button is-info" :href="'/admin/exportar-planillas-a-pdf/'+gdc"> <span> Imprimir Planillas diff --git a/routes/web.php b/routes/web.php index d9f49c9..ec3dc89 100644 --- a/routes/web.php +++ b/routes/web.php @@ -35,6 +35,7 @@ Route::get('/admin/obtener_sesion', function() { })->name('admin_obtener_sesion'); Route::get('/admin/exportar-planillas-a-pdf/{gdc}', 'AdminController@exportarPlanillasAPdf'); +Route::get('/admin/exportar-pedido-a-csv/{gdc}', 'AdminController@exportarPedidoACSV'); Route::middleware(['auth', 'admin'])->group( function () { //Route::get('/admin/exportar-planillas-a-pdf/{gdc}', 'AdminController@exportarPlanillasAPdf');