Files
Faculty-Documentation/app/Http/Controllers/UserController.php

139 lines
4.9 KiB
PHP

<?php
namespace App\Http\Controllers;
use App\Models\Department;
use App\Models\Role;
use App\Models\User;
use Illuminate\Http\Request;
use Yajra\DataTables\Facades\DataTables;
class UserController extends Controller
{
/**
* Fetch all user names.
*
* @return \Illuminate\Http\JsonResponse
*/
public function getAllUserNames()
{
$users = User::select('id', 'name')->get();
return response()->json($users);
}
public function index()
{
$departments = Department::all();
$roles = Role::all();
return view('pages.users.index', compact('departments', 'roles'));
}
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 .= "<option value='$id' $selected>$name</option>";
}
return "<select class='form-select form-select-sm user-role-dropdown' data-user-id='{$response->id}'>$options</select>";
})
->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[] = '<a href="' . $editRoute . '" class="btn btn-sm btn-info mx-1"><i class="fas fa-edit"></i></a>';
$deleteRoute = route('users.destroy', $response->id);
$actions[] = '<button type="button" class="btn btn-sm btn-danger delete-btn" data-id="' . $response->id . '" data-url="' . $deleteRoute . '"><i class="fas fa-trash"></i></button>';
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' => 'required|exists:departments,id',
'mobile_no' => 'nullable|string|max:15',
'extension' => 'nullable|string|max:10',
'orcid_id' => 'nullable|string|max:19|unique:users',
'scopus_id' => 'nullable|string|max:20|unique:users',
]);
$user = User::create([
'name' => $request->name,
'email' => $request->email,
'password' => bcrypt($request->password),
'role_id' => $request->role_id,
'department_id' => $request->department_id,
'mobile_no' => $request->mobile_no,
'extension' => $request->extension,
'orcid_id' => $request->orcid_id,
'scopus_id' => $request->scopus_id,
]);
return response()->json($user, 201);
}
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();
}
}