feat: Phase 2 - page CRUD, subscriber management, user management
This commit is contained in:
@@ -5,38 +5,71 @@ 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\Request;
|
||||
use Illuminate\Http\RedirectResponse;
|
||||
use Illuminate\Support\Facades\Hash;
|
||||
use Illuminate\View\View;
|
||||
|
||||
class UserController extends Controller
|
||||
{
|
||||
public function index(): \Illuminate\View\View
|
||||
public function __construct()
|
||||
{
|
||||
return view('admin.users.index');
|
||||
$this->authorizeResource(User::class, 'user', [
|
||||
'except' => ['show'],
|
||||
]);
|
||||
}
|
||||
|
||||
public function create(): \Illuminate\View\View
|
||||
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(Request $request): \Illuminate\Http\RedirectResponse
|
||||
public function store(StoreUserRequest $request): RedirectResponse
|
||||
{
|
||||
return redirect()->route('admin.users.index');
|
||||
$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): \Illuminate\View\View
|
||||
public function edit(User $user): View
|
||||
{
|
||||
return view('admin.users.edit', compact('user'));
|
||||
}
|
||||
|
||||
public function update(Request $request, User $user): \Illuminate\Http\RedirectResponse
|
||||
public function update(UpdateUserRequest $request, User $user): RedirectResponse
|
||||
{
|
||||
return redirect()->route('admin.users.index');
|
||||
$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): \Illuminate\Http\RedirectResponse
|
||||
public function destroy(User $user): RedirectResponse
|
||||
{
|
||||
return redirect()->route('admin.users.index');
|
||||
$user->delete();
|
||||
|
||||
return redirect()
|
||||
->route('admin.users.index')
|
||||
->with('status', __('User deleted.'));
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user