You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
|
|
|
|
use App\Models\Sale;
|
|
|
|
use Illuminate\Http\Request;
|
|
|
|
|
|
|
|
class SaleController extends Controller
|
|
|
|
{
|
|
|
|
public function index(Request $request)
|
|
|
|
{
|
|
|
|
$query = Sale::with(['items.voucher', 'customer.level'])
|
|
|
|
->withCount(['items'])
|
|
|
|
->orderBy('updated_at', 'desc');
|
|
|
|
|
|
|
|
if ($request->q != '') {
|
|
|
|
$query->where('code', 'like', "%$request->q%")
|
|
|
|
->orWhereHas('customer', function ($query) use ($request) {
|
|
|
|
$query->where('name', 'like', "%$request->q%")
|
|
|
|
->orWhere('fullname', 'like', "%$request->q%")
|
|
|
|
->orWhere('username', 'like', "%$request->q%");
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
return inertia('Sale/Index', [
|
|
|
|
'query' => $query->paginate(),
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function show(Sale $sale)
|
|
|
|
{
|
|
|
|
return inertia('Sale/Detail', [
|
|
|
|
'sale' => $sale->load(['items.voucher.location', 'customer.level']),
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
}
|