MIF_E31221259/app/Http/Controllers/Admin/ManajemenUserController.php

141 lines
4.8 KiB
PHP

<?php
namespace App\Http\Controllers\Admin;
use App\Http\Controllers\Controller;
use App\Models\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Log;
class ManajemenUserController extends Controller
{
public function index(Request $request)
{
try {
// Ambil kata kunci dari query string ?search=...
$search = $request->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);
}
}
}