input('search'); // Jika ada keyword, filter; jika tidak, ambil semua $users = User::when($search, function($query, $s) { $query->where('nim', 'like', "%{$s}%") ->orWhere('username','like', "%{$s}%") ->orWhere('name', 'like', "%{$s}%") ->orWhere('email', 'like', "%{$s}%"); }) ->orderBy('id') ->get(); // Kirim juga variabel search ke view supaya bisa di-fill ulang inputnya return view('admin.manajemenuser', compact('users', 'search')); } catch (\Exception $e) { Log::error('Gagal mengambil data user: ' . $e->getMessage()); return back()->with('error', 'Gagal mengambil data user.'); } } public function show($id) { try { $user = User::findOrFail($id); return view('admin.manajemenuser-show', compact('user')); } catch (\Exception $e) { Log::error('Gagal menampilkan user: ' . $e->getMessage()); return back()->with('error', 'User tidak ditemukan.'); } } public function edit($id) { try { $user = User::findOrFail($id); return view('admin.manajemenuser-edit', compact('user')); } catch (\Exception $e) { Log::error('Gagal mengedit user: ' . $e->getMessage()); return back()->with('error', 'User tidak ditemukan untuk diedit.'); } } public function update(Request $request, $id) { \Log::info('UPDATE hit', ['id'=>$id, 'payload'=>$request->all()]); try { $user = User::findOrFail($id); $data = $request->validate([ 'nim' => 'required|size:7|unique:users,nim,'.$user->id, 'username' => 'required|max:50|unique:users,username,'.$user->id, 'name' => 'required|max:100', 'email' => 'required|email|unique:users,email,'.$user->id, 'no_hp' => 'nullable|max:15', 'role' => 'required|in:admin,user', 'password' => 'nullable|min:6', ]); if ($request->filled('password')) { $data['password'] = bcrypt($request->password); } $user->update($data); return redirect()->route('admin.manajemen-user.index') ->with('success', 'User berhasil diperbarui.'); } catch (\Exception $e) { Log::error('Gagal update user: ' . $e->getMessage()); return back()->with('error', 'Gagal mengupdate user.'); } } public function destroy($id) { try { $user = User::findOrFail($id); $user->delete(); return redirect()->route('admin.manajemen-user.index') ->with('success', 'User berhasil dihapus.'); } catch (\Exception $e) { Log::error('Gagal hapus user: ' . $e->getMessage()); return back()->with('error', 'Gagal menghapus user.'); } } public function store(Request $request) { try { $data = $request->validate([ 'nim' => 'required|size:7|unique:users,nim', 'username' => 'required|max:50|unique:users,username', 'name' => 'required|max:100', 'email' => 'required|email|unique:users,email', 'no_hp' => 'nullable|max:15', 'role' => 'required|in:admin,user', 'password' => 'required|min:6', ]); $data['password'] = bcrypt($data['password']); User::create($data); return redirect()->route('admin.manajemen-user.index') ->with('success', 'User berhasil ditambahkan.'); } catch (\Exception $e) { Log::error('Gagal tambah user: ' . $e->getMessage()); return back()->with('error', 'Gagal menambahkan user.'); } } // File: app/Http/Controllers/Admin/ManajemenUserController.php public function getUser($id) { try { $user = User::findOrFail($id); return response()->json($user); // Mengembalikan data user dalam format JSON } catch (\Exception $e) { Log::error('Gagal mengambil data user: ' . $e->getMessage()); return response()->json(['error' => 'User tidak ditemukan'], 404); } } }