f530f55577
- Dark mode complet : darkMode:'class' Tailwind, sélecteur clair/sombre/auto dans la navigation (mémorisé dans localStorage, sans flash au chargement) ; 53 vues et 8 composants Breeze mis à jour avec classes dark: - Composant user-picker : fenêtre modale avec recherche temps réel (nom/email) remplace les <select> d'ajout de membres dans sections et sources - Paramètres : option "Désactiver la vérification automatique des mises à jour" (case à cochage auto-soumise, route POST parametres/updates) - Panneau "Paramètres généraux" remonté en tête de la page de paramètres - README recentré sur l'installation manuelle hébergement PHP+MySQL - VERSION 1.0.1 Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
111 lines
6.6 KiB
PHP
111 lines
6.6 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 dark:text-gray-500">/</span>
|
|
<h2 class="text-xl font-semibold text-gray-800 dark:text-gray-200">{{ $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 dark:bg-green-900/30 border border-green-200 dark:border-green-700 text-green-800 dark:text-green-200 rounded-md">{{ session('success') }}</div>
|
|
@endif
|
|
@if(session('error'))
|
|
<div class="p-4 bg-red-50 dark:bg-red-900/30 border border-red-200 dark:border-red-700 text-red-800 dark:text-red-200 rounded-md">{{ session('error') }}</div>
|
|
@endif
|
|
|
|
{{-- Informations --}}
|
|
<div class="bg-white dark:bg-gray-800 shadow rounded-lg p-6 space-y-3">
|
|
<h3 class="text-sm font-semibold text-gray-700 dark:text-gray-300 uppercase tracking-wide">Informations</h3>
|
|
<dl class="grid grid-cols-2 gap-x-6 gap-y-3 text-sm">
|
|
<dt class="text-gray-500 dark:text-gray-400">Nom</dt>
|
|
<dd class="text-gray-900 dark:text-white font-medium">{{ $user->name }}</dd>
|
|
<dt class="text-gray-500 dark:text-gray-400">E-mail</dt>
|
|
<dd class="text-gray-900 dark:text-white">{{ $user->email }}</dd>
|
|
<dt class="text-gray-500 dark:text-gray-400">Inscrit le</dt>
|
|
<dd class="text-gray-900 dark:text-white">{{ $user->created_at->format('d/m/Y') }}</dd>
|
|
<dt class="text-gray-500 dark:text-gray-400">Sections</dt>
|
|
<dd class="text-gray-900 dark:text-white">
|
|
@if($user->sections->isNotEmpty())
|
|
{{ $user->sections->pluck('nom')->join(', ') }}
|
|
@else
|
|
—
|
|
@endif
|
|
</dd>
|
|
<dt class="text-gray-500 dark:text-gray-400">Sources assignées</dt>
|
|
<dd class="text-gray-900 dark:text-white">{{ $user->sourcesAssignees->count() }}</dd>
|
|
</dl>
|
|
</div>
|
|
|
|
{{-- Statut actif / inactif --}}
|
|
<div class="bg-white dark:bg-gray-800 shadow rounded-lg p-6 flex items-center justify-between">
|
|
<div>
|
|
<p class="text-sm font-medium text-gray-900 dark:text-white">Statut du compte</p>
|
|
<p class="text-sm text-gray-500 dark:text-gray-400 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 dark:bg-red-900/30 text-red-700 border border-red-200 dark:border-red-700 hover:bg-red-100'
|
|
: 'bg-green-50 dark:bg-green-900/30 text-green-700 border border-green-200 dark:border-green-700 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 dark:bg-gray-800 shadow rounded-lg p-6">
|
|
<h3 class="text-sm font-semibold text-gray-700 dark:text-gray-300 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 dark:hover:bg-gray-700
|
|
{{ $user->role === $role ? 'border-indigo-400 bg-indigo-50 dark:bg-indigo-900/30' : 'border-gray-200 dark:border-gray-700' }}">
|
|
<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 dark:text-white">{{ $role->label() }}</p>
|
|
<p class="text-xs text-gray-500 dark:text-gray-400 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 dark:text-gray-400 self-center hover:text-gray-700 dark:hover:text-gray-300">
|
|
Annuler
|
|
</a>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</x-app-layout>
|