dbf0465b0a
Utilisateurs actifs/inactifs : - Migration : colonne is_active (boolean, default true) sur users - Middleware EnsureUserIsActive : déconnecte les utilisateurs désactivés sur chaque requête - LoginRequest : bloque la connexion si is_active=false (message explicite) - Admin : bouton Activer/Désactiver dans la liste et la page d'édition Protections : impossible de désactiver son propre compte ou le dernier admin actif - Badge « Inactif » + opacité réduite sur la ligne dans la liste admin - Sélection de membres (sources) : filtre is_active=true Sources liées aux sections : - Migration : colonne section_id nullable FK sur sources - Source::section() BelongsTo + Section::sources() HasMany - Formulaire sources/_form : sélecteur de section (sections de l'utilisateur ou toutes pour admin) - SourceController : passe les sections disponibles aux vues create/edit Tableau de bord enrichi (DashboardController) : - Membres et responsables : stats par section (sources par statut, total relevés) compteurs cliquables → liste filtrée, sources récentes de la section - Mes sources assignées (tri par urgence) + mes derniers relevés (inchangés) Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
111 lines
5.9 KiB
PHP
111 lines
5.9 KiB
PHP
<x-app-layout>
|
|
<x-slot name="header">
|
|
<div class="flex items-center gap-3">
|
|
<a href="{{ route('admin.utilisateurs.index') }}" class="text-sm text-indigo-600 hover:underline">← Utilisateurs</a>
|
|
<span class="text-gray-400">/</span>
|
|
<h2 class="text-xl font-semibold text-gray-800">{{ $user->name }}</h2>
|
|
</div>
|
|
</x-slot>
|
|
|
|
<div class="py-8 max-w-2xl mx-auto px-4 sm:px-6 lg:px-8 space-y-6">
|
|
|
|
@if(session('success'))
|
|
<div class="p-4 bg-green-50 border border-green-200 text-green-800 rounded-md">{{ session('success') }}</div>
|
|
@endif
|
|
@if(session('error'))
|
|
<div class="p-4 bg-red-50 border border-red-200 text-red-800 rounded-md">{{ session('error') }}</div>
|
|
@endif
|
|
|
|
{{-- Informations --}}
|
|
<div class="bg-white shadow rounded-lg p-6 space-y-3">
|
|
<h3 class="text-sm font-semibold text-gray-700 uppercase tracking-wide">Informations</h3>
|
|
<dl class="grid grid-cols-2 gap-x-6 gap-y-3 text-sm">
|
|
<dt class="text-gray-500">Nom</dt>
|
|
<dd class="text-gray-900 font-medium">{{ $user->name }}</dd>
|
|
<dt class="text-gray-500">E-mail</dt>
|
|
<dd class="text-gray-900">{{ $user->email }}</dd>
|
|
<dt class="text-gray-500">Inscrit le</dt>
|
|
<dd class="text-gray-900">{{ $user->created_at->format('d/m/Y') }}</dd>
|
|
<dt class="text-gray-500">Sections</dt>
|
|
<dd class="text-gray-900">
|
|
@if($user->sections->isNotEmpty())
|
|
{{ $user->sections->pluck('nom')->join(', ') }}
|
|
@else
|
|
—
|
|
@endif
|
|
</dd>
|
|
<dt class="text-gray-500">Sources assignées</dt>
|
|
<dd class="text-gray-900">{{ $user->sourcesAssignees->count() }}</dd>
|
|
</dl>
|
|
</div>
|
|
|
|
{{-- Statut actif / inactif --}}
|
|
<div class="bg-white shadow rounded-lg p-6 flex items-center justify-between">
|
|
<div>
|
|
<p class="text-sm font-medium text-gray-900">Statut du compte</p>
|
|
<p class="text-sm text-gray-500 mt-0.5">
|
|
@if($user->is_active)
|
|
Le compte est <span class="text-green-600 font-medium">actif</span> — l'utilisateur peut se connecter et être assigné à des sources.
|
|
@else
|
|
Le compte est <span class="text-red-600 font-medium">inactif</span> — l'utilisateur ne peut pas se connecter.
|
|
@endif
|
|
</p>
|
|
</div>
|
|
@if($user->id !== auth()->id())
|
|
<form method="POST" action="{{ route('admin.utilisateurs.toggle-active', $user) }}"
|
|
x-data
|
|
@submit.prevent="if(confirm('{{ $user->is_active ? 'Désactiver' : 'Activer' }} ce compte ?')) $el.submit()">
|
|
@csrf
|
|
<button type="submit"
|
|
class="px-4 py-2 text-sm font-medium rounded-md
|
|
{{ $user->is_active
|
|
? 'bg-red-50 text-red-700 border border-red-200 hover:bg-red-100'
|
|
: 'bg-green-50 text-green-700 border border-green-200 hover:bg-green-100' }}">
|
|
{{ $user->is_active ? 'Désactiver le compte' : 'Activer le compte' }}
|
|
</button>
|
|
</form>
|
|
@endif
|
|
</div>
|
|
|
|
{{-- Modifier le rôle --}}
|
|
<div class="bg-white shadow rounded-lg p-6">
|
|
<h3 class="text-sm font-semibold text-gray-700 uppercase tracking-wide mb-4">Rôle</h3>
|
|
<form method="POST" action="{{ route('admin.utilisateurs.update', $user) }}">
|
|
@csrf @method('PUT')
|
|
<div class="space-y-3">
|
|
@foreach(\App\Enums\UserRole::cases() as $role)
|
|
<label class="flex items-start gap-3 p-3 border rounded-lg cursor-pointer hover:bg-gray-50
|
|
{{ $user->role === $role ? 'border-indigo-400 bg-indigo-50' : 'border-gray-200' }}">
|
|
<input type="radio" name="role" value="{{ $role->value }}"
|
|
{{ $user->role === $role ? 'checked' : '' }}
|
|
class="mt-0.5 text-indigo-600">
|
|
<div>
|
|
<p class="text-sm font-medium text-gray-900">{{ $role->label() }}</p>
|
|
<p class="text-xs text-gray-500 mt-0.5">
|
|
@if($role === \App\Enums\UserRole::Admin)
|
|
Accès complet : gestion des utilisateurs, sections, dépôts, types de sources et statistiques.
|
|
@elseif($role === \App\Enums\UserRole::SectionManager)
|
|
Peut créer des sources, assigner des membres et valider les relevés de sa section.
|
|
@else
|
|
Peut saisir des relevés sur les sources auxquelles il est assigné.
|
|
@endif
|
|
</p>
|
|
</div>
|
|
</label>
|
|
@endforeach
|
|
</div>
|
|
<div class="mt-5 flex gap-4">
|
|
<button type="submit"
|
|
class="px-5 py-2 bg-indigo-600 text-white text-sm font-medium rounded-md hover:bg-indigo-700">
|
|
Enregistrer
|
|
</button>
|
|
<a href="{{ route('admin.utilisateurs.index') }}"
|
|
class="text-sm text-gray-500 self-center hover:text-gray-700">
|
|
Annuler
|
|
</a>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</x-app-layout>
|