Étape 10 : interface admin (tableau de bord + gestion utilisateurs)
- DashboardController : stats globales (sources par statut, relevés, utilisateurs, activité mensuelle 6 mois) - UserController : liste filtrée (nom/email/rôle) + édition de rôle avec protections (auto-demotion, dernier admin) - Vue admin/dashboard : compteurs par statut cliquables, graphique barres mensuel, sources à valider, relevés récents - Vue admin/utilisateurs : liste paginée avec sections et sources assignées, page d'édition avec radio-cards - Dashboard principal enrichi : bloc accès admin, mes sources assignées triées par urgence, mes derniers relevés - Navigation : ajout Tableau de bord admin et Utilisateurs dans le menu Administration Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -0,0 +1,64 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Admin;
|
||||
|
||||
use App\Enums\UserRole;
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Models\User;
|
||||
use Illuminate\Http\RedirectResponse;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Validation\Rules\Enum;
|
||||
use Illuminate\View\View;
|
||||
|
||||
class UserController extends Controller
|
||||
{
|
||||
public function index(Request $request): View
|
||||
{
|
||||
$query = User::withCount('sourcesAssignees')->with('sections')->orderBy('name');
|
||||
|
||||
if ($request->filled('role')) {
|
||||
$query->where('role', $request->input('role'));
|
||||
}
|
||||
|
||||
if ($request->filled('q')) {
|
||||
$q = trim($request->get('q'));
|
||||
$query->where(fn ($wq) => $wq
|
||||
->where('name', 'ilike', "%{$q}%")
|
||||
->orWhere('email', 'ilike', "%{$q}%")
|
||||
);
|
||||
}
|
||||
|
||||
$users = $query->paginate(25)->withQueryString();
|
||||
|
||||
return view('admin.utilisateurs.index', compact('users'));
|
||||
}
|
||||
|
||||
public function edit(User $user): View
|
||||
{
|
||||
$user->load('sections', 'sourcesAssignees');
|
||||
|
||||
return view('admin.utilisateurs.edit', compact('user'));
|
||||
}
|
||||
|
||||
public function update(Request $request, User $user): RedirectResponse
|
||||
{
|
||||
$data = $request->validate([
|
||||
'role' => ['required', new Enum(UserRole::class)],
|
||||
]);
|
||||
|
||||
if ($user->id === auth()->id()) {
|
||||
return back()->with('error', 'Vous ne pouvez pas modifier votre propre rôle.');
|
||||
}
|
||||
|
||||
if ($user->role === UserRole::Admin && $data['role'] !== UserRole::Admin->value) {
|
||||
$adminCount = User::where('role', UserRole::Admin->value)->count();
|
||||
if ($adminCount <= 1) {
|
||||
return back()->with('error', 'Impossible de retirer le rôle admin au dernier administrateur.');
|
||||
}
|
||||
}
|
||||
|
||||
$user->update(['role' => $data['role']]);
|
||||
|
||||
return back()->with('success', 'Rôle mis à jour.');
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user