Compare commits
	
		
			No commits in common. "e6fe5e89604b9012572f2b276bdab2f74fe0fe42" and "14193ba027e10e7f047cc9dbaa207fb515eddccc" have entirely different histories.
		
	
	
		
			e6fe5e8960
			...
			14193ba027
		
	
		
					 5 changed files with 21 additions and 64 deletions
				
			
		|  | @ -35,7 +35,6 @@ class PedidosExportHelper | ||||||
|             ) |             ) | ||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|     /** |     /** | ||||||
|      * @throws InvalidArgument |      * @throws InvalidArgument | ||||||
|      * @throws CannotInsertRecord |      * @throws CannotInsertRecord | ||||||
|  | @ -44,16 +43,16 @@ class PedidosExportHelper | ||||||
|     static public function pedidosDeOllas() |     static public function pedidosDeOllas() | ||||||
|     { |     { | ||||||
|         $filePath = "csv/exports/pedidos-de-ollas-" . now()->format('Y-m-d') . ".csv"; |         $filePath = "csv/exports/pedidos-de-ollas-" . now()->format('Y-m-d') . ".csv"; | ||||||
|         $tipo_olla = self::getTipoId('olla'); |  | ||||||
|         $barrios = GrupoDeCompra::barriosMenosPrueba() |         $barrios = GrupoDeCompra::barriosMenosPrueba() | ||||||
|             ->whereHas('subpedidos', function ($query) use ($tipo_olla) { |             ->whereHas('subpedidos', function ($query) { | ||||||
|  |                 $tipo_olla = self::getTipoId('olla'); | ||||||
|                 $query->where('tipo_pedido_id', $tipo_olla); |                 $query->where('tipo_pedido_id', $tipo_olla); | ||||||
|             }) |             }) | ||||||
|             ->get(); |             ->get(); | ||||||
| 
 | 
 | ||||||
|         $contenido = self::generarContenidoCSV($barrios, |         $contenido = self::generarContenidoCSV($barrios, | ||||||
|             fn($grupoId) => "subpedidos.grupo_de_compra_id = $grupoId |             fn($grupoId) => "subpedidos.grupo_de_compra_id = $grupoId | ||||||
|                     AND subpedidos.tipo_pedido_id = $tipo_olla");
 |                     AND subpedidos.tipo_pedido_id = 2");
 | ||||||
|         $ollas = self::cantidadDeOllasParaCSV($barrios, $contenido); |         $ollas = self::cantidadDeOllasParaCSV($barrios, $contenido); | ||||||
| 
 | 
 | ||||||
|         self::exportarCSV( |         self::exportarCSV( | ||||||
|  | @ -129,32 +128,6 @@ class PedidosExportHelper | ||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |  | ||||||
|      * @throws InvalidArgument |  | ||||||
|      * @throws CannotInsertRecord |  | ||||||
|      * @throws Exception |  | ||||||
|      */ |  | ||||||
|     static public function faltantesYSobrantes() |  | ||||||
|     { |  | ||||||
|         $filePath = "csv/exports/faltantes-y-sobrantes-" . now()->format('Y-m-d') . ".csv"; |  | ||||||
|         $tipoPedidoId = self::getTipoId('faltantes_y_sobrantes'); |  | ||||||
|         $barrios = GrupoDeCompra::barriosMenosPrueba() |  | ||||||
|             ->whereHas('subpedidos', function ($query) use ($tipoPedidoId) { |  | ||||||
|                 $query->where('tipo_pedido_id', $tipoPedidoId); |  | ||||||
|             }) |  | ||||||
|             ->get(); |  | ||||||
| 
 |  | ||||||
|         $contenido = self::generarContenidoCSV($barrios, |  | ||||||
|             fn($grupoId) => "subpedidos.grupo_de_compra_id = $grupoId |  | ||||||
|                     AND subpedidos.tipo_pedido_id = $tipoPedidoId");
 |  | ||||||
| 
 |  | ||||||
|         self::exportarCSV( |  | ||||||
|             $filePath, |  | ||||||
|             $barrios, |  | ||||||
|             $contenido |  | ||||||
|         ); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |     /** | ||||||
|      * @throws InvalidArgument |      * @throws InvalidArgument | ||||||
|      * @throws CannotInsertRecord |      * @throws CannotInsertRecord | ||||||
|  | @ -279,7 +252,7 @@ class PedidosExportHelper | ||||||
|      */ |      */ | ||||||
|     public static function getTipoId(string $tipo) |     public static function getTipoId(string $tipo) | ||||||
|     { |     { | ||||||
|         $tipoPedido = TipoPedido::where('nombre', $tipo)->first()->id; |         $tipo_olla = TipoPedido::where('nombre', $tipo)->first()->id; | ||||||
|         return $tipoPedido; |         return $tipo_olla; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -137,7 +137,7 @@ class SubpedidoController extends Controller | ||||||
| 
 | 
 | ||||||
|         $producto = Producto::find($valid['producto_id']); |         $producto = Producto::find($valid['producto_id']); | ||||||
|         if ($producto->bono) |         if ($producto->bono) | ||||||
|             abort(400, "No puede haber faltado un bono"); |             abort(400, "No te puede haber faltado un bono"); | ||||||
| 
 | 
 | ||||||
|         $cantidad = $valid['cantidad']; |         $cantidad = $valid['cantidad']; | ||||||
|         if ($cantidad < 0) { // caso faltantes
 |         if ($cantidad < 0) { // caso faltantes
 | ||||||
|  | @ -145,11 +145,11 @@ class SubpedidoController extends Controller | ||||||
| 
 | 
 | ||||||
|             $productoPedido = $barrio->productosPedidos()->where('producto_id', $producto->id)->first(); |             $productoPedido = $barrio->productosPedidos()->where('producto_id', $producto->id)->first(); | ||||||
|             if (!$productoPedido) |             if (!$productoPedido) | ||||||
|                 abort(400, "No pueden faltar productos no pedidos"); |                 abort(400, "No te puede faltar algo que no pediste"); | ||||||
| 
 | 
 | ||||||
|             $cantidadPedida = intval($productoPedido->cantidad_pedida); |             $cantidadPedida = intval($productoPedido->cantidad_pedida); | ||||||
|             if ($cantidadPedida + $cantidad < 0) |             if ($cantidadPedida + $cantidad < 0) | ||||||
|                 abort(400, 'No puede faltar más de lo pedido'); |                 abort(400, 'No te puede faltar más de lo que pediste'); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         $subpedido->syncProducto($producto, $cantidad); |         $subpedido->syncProducto($producto, $cantidad); | ||||||
|  |  | ||||||
|  | @ -65,23 +65,6 @@ class ComisionesController | ||||||
|         return response()->download($files[0]); |         return response()->download($files[0]); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public function descargarFaltantesYSobrantes() |  | ||||||
|     { |  | ||||||
|         try { |  | ||||||
|             PedidosExportHelper::faltantesYSobrantes(); |  | ||||||
|         } catch (CannotInsertRecord|InvalidArgument|Exception $e) { |  | ||||||
|             return response()->json(['message' => $e->getMessage()], 500); |  | ||||||
|         } |  | ||||||
|         $pattern = storage_path('csv/exports/faltantes-y-sobrantes-*.csv'); |  | ||||||
|         $files = glob($pattern); |  | ||||||
| 
 |  | ||||||
|         usort($files, function ($a, $b) { |  | ||||||
|             return filemtime($b) <=> filemtime($a); |  | ||||||
|         }); |  | ||||||
| 
 |  | ||||||
|         return response()->download($files[0]); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public function descargarNotas() |     public function descargarNotas() | ||||||
|     { |     { | ||||||
|         try { |         try { | ||||||
|  |  | ||||||
|  | @ -14,8 +14,17 @@ | ||||||
|             </div> |             </div> | ||||||
|             <div class="dropdown-menu" id="dropdown-menu" role="menu"> |             <div class="dropdown-menu" id="dropdown-menu" role="menu"> | ||||||
|                 <div class="dropdown-content"> |                 <div class="dropdown-content"> | ||||||
|                     <a v-for="(opcion,i) in opciones" :key="i" :href="opcion.href" class="dropdown-item"> |                     <a href="/comisiones/pedidos/descargar" class="dropdown-item"> | ||||||
|                         {{ opcion.nombre }} |                         Pedidos por barrio en csv | ||||||
|  |                     </a> | ||||||
|  |                     <a href="/comisiones/pedidos/notas" class="dropdown-item"> | ||||||
|  |                         Notas por barrio en csv | ||||||
|  |                     </a> | ||||||
|  |                     <a href="/comisiones/pedidos/pdf" class="dropdown-item"> | ||||||
|  |                         Pedidos por barrio en pdf | ||||||
|  |                     </a> | ||||||
|  |                     <a href="/comisiones/pedidos/ollas" class="dropdown-item"> | ||||||
|  |                         Pedidos de ollas en csv | ||||||
|                     </a> |                     </a> | ||||||
|                 </div> |                 </div> | ||||||
|             </div> |             </div> | ||||||
|  | @ -27,14 +36,7 @@ | ||||||
| export default { | export default { | ||||||
|     data() { |     data() { | ||||||
|         return { |         return { | ||||||
|             dropdownActivo: false, |             dropdownActivo: false | ||||||
|             opciones: [ |  | ||||||
|                 { nombre: 'Pedidos por barrio en csv', href: '/comisiones/pedidos/descargar' }, |  | ||||||
|                 { nombre: 'Notas por barrio en csv', href: '/comisiones/pedidos/notas' }, |  | ||||||
|                 { nombre: 'Pedidos por barrio en pdf', href: '/comisiones/pedidos/pdf' }, |  | ||||||
|                 { nombre: 'Pedidos de ollas en csv', href: '/comisiones/pedidos/ollas' }, |  | ||||||
|                 { nombre: 'Faltantes y sobrantes en csv', href: '/comisiones/faltantes-y-sobrantes' }, |  | ||||||
|             ], |  | ||||||
|         } |         } | ||||||
|     }, |     }, | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -58,8 +58,7 @@ Route::middleware(['auth', 'role:comision'])->prefix('comisiones')->group( funct | ||||||
|     Route::post('/canasta', 'ComisionesController@cargarCanasta')->name('comisiones.canasta'); |     Route::post('/canasta', 'ComisionesController@cargarCanasta')->name('comisiones.canasta'); | ||||||
|     Route::get('/saldos/ejemplo', 'ComisionesController@descargarSaldosEjemplo')->name('comisiones.saldos.ejemplo'); |     Route::get('/saldos/ejemplo', 'ComisionesController@descargarSaldosEjemplo')->name('comisiones.saldos.ejemplo'); | ||||||
|     Route::post('/saldos', 'ComisionesController@cargarSaldos')->name('comisiones.saldos'); |     Route::post('/saldos', 'ComisionesController@cargarSaldos')->name('comisiones.saldos'); | ||||||
|     Route::put('/parametros/{parametro_id}', 'ComisionesController@modificarParametros')->name('comisiones.parametros.modificar'); |     Route::put('/parametros/{parametro_id}', 'ComisionesController@modificarParametros'); | ||||||
|     Route::get('/faltantes-y-sobrantes', 'ComisionesController@descargarFaltantesYSobrantes')->name('comisiones.faltantesYsobrantes'); |  | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| Route::get('/ollas/login', 'OllasController@show')->name('ollas.login'); | Route::get('/ollas/login', 'OllasController@show')->name('ollas.login'); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue