Feat: User Management

This commit is contained in:
Sallu9007
2025-05-13 23:05:24 +05:30
parent 78e4207e65
commit 7ead83e69f
4 changed files with 582 additions and 10 deletions

View File

@@ -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)