Files
preregister/app/Http/Controllers/Admin/UserController.php

76 lines
1.9 KiB
PHP

<?php
declare(strict_types=1);
namespace App\Http\Controllers\Admin;
use App\Http\Controllers\Controller;
use App\Http\Requests\Admin\StoreUserRequest;
use App\Http\Requests\Admin\UpdateUserRequest;
use App\Models\User;
use Illuminate\Http\RedirectResponse;
use Illuminate\Support\Facades\Hash;
use Illuminate\View\View;
class UserController extends Controller
{
public function __construct()
{
$this->authorizeResource(User::class, 'user', [
'except' => ['show'],
]);
}
public function index(): View
{
$users = User::query()->orderBy('name')->paginate(25);
return view('admin.users.index', compact('users'));
}
public function create(): View
{
return view('admin.users.create');
}
public function store(StoreUserRequest $request): RedirectResponse
{
$data = $request->validated();
$data['password'] = Hash::make($data['password']);
User::query()->create($data);
return redirect()
->route('admin.users.index')
->with('status', __('User created.'));
}
public function edit(User $user): View
{
return view('admin.users.edit', compact('user'));
}
public function update(UpdateUserRequest $request, User $user): RedirectResponse
{
$data = $request->validated();
if ($request->filled('password')) {
$data['password'] = Hash::make($data['password']);
} else {
unset($data['password']);
}
$user->update($data);
return redirect()
->route('admin.users.index')
->with('status', __('User updated.'));
}
public function destroy(User $user): RedirectResponse
{
$user->delete();
return redirect()
->route('admin.users.index')
->with('status', __('User deleted.'));
}
}