json(['message' => $e->getMessage()], 500); } $pattern = storage_path('csv/exports/pedidos-por-barrio-*.csv'); $files = glob($pattern); usort($files, function ($a, $b) { return filemtime($b) <=> filemtime($a); }); return response()->download($files[0]); } public function descargarNotas(): BinaryFileResponse { Producto::planillaNotas(); $pattern = storage_path('csv/exports/notas-por-barrio-*.csv'); $files = glob($pattern); usort($files, function ($a, $b) { return filemtime($b) <=> filemtime($a); }); return response()->download($files[0]); } public function pdf() { GrupoDeCompra::exportarPedidosBarrialesAPdf(); } public function cargarCanasta(Request $request): JsonResponse { $request->validate([ 'data' => 'required|file|mimes:csv,txt|max:2048', ]); $nombre = CanastaHelper::guardarCanasta($request->file('data'), self::CANASTAS_PATH); try { CanastaHelper::cargarCanasta(storage_path(self::CANASTAS_PATH . $nombre)); } catch (Exception $e) { return response()->json(['message' => $e->getMessage()], 500); } return response()->json([ 'message' => 'Canasta cargada exitosamente', ]); } public function descargarCanastaEjemplo(): BinaryFileResponse { $file = storage_path('csv/productos.csv'); return response()->download($file); } public function cargarSaldos(Request $request): JsonResponse { $request->validate([ 'data' => 'required|file|mimes:csv,txt|max:2048', ]); $file = $request->file('data')->getPathname(); try { $records = CsvHelper::getRecords($file, "No se pudo leer el archivo."); } catch (Exception $e) { return response()->json(['message' => $e->getMessage()], 500); } foreach ($records as $record) { $barrio = $record[self::BARRIO]; $saldo = $record[self::SALDO]; GrupoDeCompra::where('nombre', $barrio) ->update(['saldo' => $saldo]); } return response()->json(GrupoDeCompraResource::collection(GrupoDeCompra::all())); } }