get();
return response()->json($users);
}
public function index()
{
$departments = Department::all();
return view('pages.users.index', compact('departments'));
}
public function getUsersData(Request $request)
{
$responses = User::with(['role', 'department'])
->select('users.*');
// Apply filters
if ($request->has('department') && !empty($request->department)) {
$responses->where('department_id', $request->department);
}
if ($request->has('role') && !empty($request->role)) {
$responses->where('role_id', $request->role);
}
return DataTables::of($responses)
->addColumn('department_name', function ($response) {
return $response->department ? $response->department->name : 'Unknown';
})
->addColumn('role_name', function ($response) {
$roles = [
1 => 'Admin',
2 => 'HOD',
3 => 'Faculty',
];
$options = '';
foreach ($roles as $id => $name) {
$selected = $response->role_id == $id ? 'selected' : '';
$options .= "";
}
return "";
})
->addColumn('action', function ($response) {
$actions = [];
// Edit button with role-appropriate route
$userRole = auth()->user()->role->name;
// Determine the appropriate route based on user role
// if ($userRole === 'Admin') {
// $editRoute = route('admin.users.edit', $response->id);
// } elseif ($userRole === 'Coordinator') {
// $editRoute = route('coordinator.users.edit', $response->id);
// } else {
// $editRoute = route('faculty.users.edit', $response->id);
// }
// $actions[] = '';
$deleteRoute = route('users.destroy', $response->id);
$actions[] = '';
return implode(' ', $actions);
})
->rawColumns(['action', 'role_name'])
->make(true);
}
public function store(Request $request)
{
$request->validate([
'name' => 'required|string',
'email' => 'required|email|unique:users',
'password' => 'required|string|min:8',
'role_id' => 'required|exists:roles,id',
'department_id' => 'nullable|exists:departments,id',
]);
$user = User::create([
'name' => $request->name,
'email' => $request->email,
'password' => bcrypt($request->password),
'role_id' => $request->role_id,
'department_id' => $request->department_id,
]);
return $user;
}
public function show(User $user)
{
return $user->load(['role', 'department']);
}
public function update(Request $request, User $user)
{
$request->validate([
'name' => 'sometimes|required|string',
'email' => 'sometimes|required|email|unique:users,email,' . $user->id,
'password' => 'nullable|string|min:8',
'role_id' => 'sometimes|required|exists:roles,id',
'department_id' => 'nullable|exists:departments,id',
]);
$user->update(array_filter($request->all()));
return $user->load(['role', 'department']);
}
public function destroy(User $user)
{
$user->delete();
return response()->noContent();
}
}