|
2 | 2 |
|
3 | 3 | namespace App\Http\Controllers; |
4 | 4 |
|
| 5 | +use App\Models\BlEmpaque; |
| 6 | +use App\Models\BlEstanteria; |
| 7 | +use App\Models\BlInventarioDetalle; |
| 8 | +use App\Models\BlProducto; |
5 | 9 | use Illuminate\Http\Request; |
6 | 10 | use Illuminate\Support\Facades\Auth; |
7 | 11 | use Illuminate\Support\Facades\DB; |
8 | 12 | use Inertia\Inertia; |
9 | 13 |
|
10 | 14 | class BLInventarioController extends Controller |
11 | 15 | { |
| 16 | + // public function index() |
| 17 | + // { |
| 18 | + // $user = Auth::user(); |
| 19 | + // return Inertia::render('BLInventario', [ |
| 20 | + // 'user' => $user, |
| 21 | + // ]); |
| 22 | + // } |
12 | 23 | public function index() |
13 | 24 | { |
14 | | - $user = Auth::user(); |
| 25 | + $productos = BlProducto::with([ |
| 26 | + 'color', |
| 27 | + 'empaques.inventarioDetalle.posicion.nivel.estanteria' |
| 28 | + ]) |
| 29 | + ->get() |
| 30 | + ->map(function ($producto) { |
| 31 | + // Obtener todas las ubicaciones donde está este producto |
| 32 | + $ubicaciones = []; |
| 33 | + foreach ($producto->empaques as $empaque) { |
| 34 | + foreach ($empaque->inventarioDetalle as $inventario) { |
| 35 | + if ($inventario->posicion && $inventario->posicion->nivel && $inventario->posicion->nivel->estanteria) { |
| 36 | + $ubicaciones[] = $inventario->posicion->nivel->estanteria->nombre; |
| 37 | + } |
| 38 | + } |
| 39 | + } |
| 40 | + |
| 41 | + // Si no tiene ubicación, mostrar "Sin ubicación" |
| 42 | + $estanteria = !empty($ubicaciones) ? implode(', ', array_unique($ubicaciones)) : 'Sin ubicación'; |
| 43 | + |
| 44 | + return [ |
| 45 | + 'id' => $producto->id, |
| 46 | + 'tipo_producto' => $producto->tipo_producto, |
| 47 | + 'tamanio' => $producto->tamanio, |
| 48 | + 'color_nombre' => $producto->color->nombre, |
| 49 | + 'descripcion' => $producto->descripcion, |
| 50 | + 'stock_total' => $producto->empaques |
| 51 | + ->where('estado', 'disponible') |
| 52 | + ->sum('cantidad_unidades'), |
| 53 | + 'estanteria' => $estanteria, |
| 54 | + 'tiene_ubicacion' => !empty($ubicaciones), |
| 55 | + ]; |
| 56 | + }); |
| 57 | + |
15 | 58 | return Inertia::render('BLInventario', [ |
16 | | - 'user' => $user, |
| 59 | + 'productos' => $productos, |
17 | 60 | ]); |
18 | 61 | } |
19 | 62 | } |
0 commit comments