File: /home/marketing.cfbon.ru/public_html/app/Http/Controllers/AdminUsers/AdminUserController.php
<?php
namespace App\Http\Controllers\AdminUsers;
use App\Enums\UserRole;
use App\Http\Controllers\Controller;
use App\Http\Requests\AdminUsers\StoreRequest;
use App\Http\Requests\AdminUsers\UpdateRequest;
use App\Models\User;
use Illuminate\Http\RedirectResponse;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Hash;
use Illuminate\View\View;
class AdminUserController extends Controller
{
/**
* Display a listing of the resource.
*/
public function index(): View
{
return view('admin-users.index', [
'users' => collect(User::all()),
'roles' => collect(UserRole::cases())
->mapWithKeys(fn($role) => [$role->value => $role->label()])
]);
}
/**
* Show the form for creating a new resource.
*/
public function create(): View
{
return view('admin-users.create', [
'roles' => collect(UserRole::cases())
->mapWithKeys(fn($role) => [$role->value => $role->label()])
]);
}
/**
* Store a newly created resource in storage.
*/
public function store(StoreRequest $request): RedirectResponse
{
$validatedData = $request->validated();
User::create([
'name' => $validatedData['name'],
'email' => $validatedData['email'],
'role' => $validatedData['role'],
'password' => Hash::make($validatedData['password']),
]);
return redirect()->route('admin-user.index')->with('success', 'Пользователь успешно создан!');
}
/**
* Show the form for editing the specified resource.
*/
public function edit(string $id): View
{
$user = User::findOrFail($id);
$roles = collect(UserRole::cases())
->mapWithKeys(fn($role) => [$role->value => $role->label()]);
return view('admin-users.edit', compact('user', 'roles'));
}
/**
* Update the specified resource in storage.
*/
public function update(UpdateRequest $request, string $id)
{
$validatedData = $request->validated();
$user = User::findOrFail($id);
$user->update($validatedData);
return redirect()->route('admin-user.edit', $id)->with('success', 'Пользователь успешно отредактирован!');
}
/**
* Remove the specified resource from storage.
*/
public function destroy(string $id)
{
$user = User::findOrFail($id);
$user->delete();
return redirect()->route('admin-user.index')->with('success', 'Пользователь успешно удален!');
}
}