Feat: User Management
This commit is contained in:
@@ -1,8 +1,11 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Models\Department;
|
||||
use App\Models\User;
|
||||
use Illuminate\Http\Request;
|
||||
use Yajra\DataTables\Facades\DataTables;
|
||||
|
||||
class UserController extends Controller
|
||||
{
|
||||
@@ -13,8 +16,63 @@ class UserController extends Controller
|
||||
*/
|
||||
public function index()
|
||||
{
|
||||
$users = User::select('name')->get();
|
||||
return response()->json($users);
|
||||
$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 => 'Coordinator',
|
||||
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)
|
||||
|
||||
Reference in New Issue
Block a user