141 lines
3.9 KiB
PHP
141 lines
3.9 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Admin;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Models\User;
|
|
use Illuminate\Http\Request;
|
|
use Spatie\Permission\Models\Role;
|
|
use Inertia\Inertia;
|
|
use Illuminate\Validation\Rule;
|
|
use Illuminate\Support\Facades\Hash;
|
|
|
|
class UserController extends Controller
|
|
{
|
|
/**
|
|
* Display a listing of the resource.
|
|
*/
|
|
public function index(Request $request)
|
|
{
|
|
$perPage = $request->input('per_page', 10);
|
|
|
|
$users = User::with('roles')
|
|
->orderBy('id')
|
|
->paginate($perPage)
|
|
->withQueryString();
|
|
|
|
return Inertia::render('Admin/User/Index', [
|
|
'users' => $users,
|
|
'filters' => $request->only(['per_page']),
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Show the form for creating a new resource.
|
|
*/
|
|
public function create()
|
|
{
|
|
$roles = Role::pluck('display_name', 'name');
|
|
|
|
return Inertia::render('Admin/User/Create', [
|
|
'roles' => $roles
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Store a newly created resource in storage.
|
|
*/
|
|
public function store(Request $request)
|
|
{
|
|
$validated = $request->validate([
|
|
'name' => ['required', 'string', 'max:255'],
|
|
'email' => ['nullable', 'string', 'email', 'max:255', 'unique:users'],
|
|
'username' => ['required', 'string', 'max:255', 'unique:users'],
|
|
'password' => ['required', 'string', 'min:8', 'confirmed'],
|
|
'roles' => ['array'],
|
|
]);
|
|
|
|
$user = User::create([
|
|
'name' => $validated['name'],
|
|
'email' => $validated['email'],
|
|
'username' => $validated['username'],
|
|
'password' => Hash::make($validated['password']),
|
|
]);
|
|
|
|
if (!empty($validated['roles'])) {
|
|
$user->syncRoles($validated['roles']);
|
|
}
|
|
|
|
return redirect()->route('users.index')->with('success', '使用者建立成功');
|
|
}
|
|
|
|
/**
|
|
* Show the form for editing the specified resource.
|
|
*/
|
|
public function edit(string $id)
|
|
{
|
|
$user = User::with('roles')->findOrFail($id);
|
|
$roles = Role::get(['id', 'name', 'display_name']);
|
|
|
|
return Inertia::render('Admin/User/Edit', [
|
|
'user' => $user,
|
|
'roles' => $roles,
|
|
'currentRoles' => $user->getRoleNames()
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Update the specified resource in storage.
|
|
*/
|
|
public function update(Request $request, string $id)
|
|
{
|
|
$user = User::findOrFail($id);
|
|
|
|
$validated = $request->validate([
|
|
'name' => ['required', 'string', 'max:255'],
|
|
'email' => ['nullable', 'string', 'email', 'max:255', Rule::unique('users')->ignore($user->id)],
|
|
'username' => ['required', 'string', 'max:255', Rule::unique('users')->ignore($user->id)],
|
|
'password' => ['nullable', 'string', 'min:8', 'confirmed'],
|
|
'roles' => ['array'],
|
|
]);
|
|
|
|
$userData = [
|
|
'name' => $validated['name'],
|
|
'email' => $validated['email'],
|
|
'username' => $validated['username'],
|
|
];
|
|
|
|
if (!empty($validated['password'])) {
|
|
$userData['password'] = Hash::make($validated['password']);
|
|
}
|
|
|
|
$user->update($userData);
|
|
|
|
if (isset($validated['roles'])) {
|
|
$user->syncRoles($validated['roles']);
|
|
}
|
|
|
|
return redirect()->route('users.index')->with('success', '使用者更新成功');
|
|
}
|
|
|
|
/**
|
|
* Remove the specified resource from storage.
|
|
*/
|
|
public function destroy(string $id)
|
|
{
|
|
$user = User::findOrFail($id);
|
|
|
|
if ($user->hasRole('super-admin')) {
|
|
return back()->with('error', '無法刪除超級管理員帳號');
|
|
}
|
|
|
|
if ($user->id === auth()->id()) {
|
|
return back()->with('error', '無法刪除自己');
|
|
}
|
|
|
|
$user->delete();
|
|
|
|
return redirect()->route('users.index')->with('success', '使用者已刪除');
|
|
}
|
|
}
|