mirror of
https://github.com/InvoiceShelf/InvoiceShelf.git
synced 2026-04-07 05:31:24 +00:00
Add scopeWhereCompany() to User model using whereHas through the user_company pivot table. Apply it in UsersController::index() and SearchController so users only see members of their current company. Previously, the users page showed ALL users across all companies. Ref #574
40 lines
901 B
PHP
40 lines
901 B
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\V1\Admin\General;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Models\Customer;
|
|
use App\Models\User;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Http\Response;
|
|
|
|
class SearchController extends Controller
|
|
{
|
|
/**
|
|
* Handle the incoming request.
|
|
*
|
|
* @return Response
|
|
*/
|
|
public function __invoke(Request $request)
|
|
{
|
|
$user = $request->user();
|
|
|
|
$customers = Customer::applyFilters($request->only(['search']))
|
|
->whereCompany()
|
|
->latest()
|
|
->paginate(10);
|
|
|
|
if ($user->isOwner()) {
|
|
$users = User::whereCompany()
|
|
->applyFilters($request->only(['search']))
|
|
->latest()
|
|
->paginate(10);
|
|
}
|
|
|
|
return response()->json([
|
|
'customers' => $customers,
|
|
'users' => $users ?? [],
|
|
]);
|
|
}
|
|
}
|