userService = $userService; $this->roleService = $roleService; } /** * Display a listing of the resource. */ public function index(?int $id = null) { $isEditing = !is_null($id); $user = $isEditing ? $this->userService->getUserById($id) : null; if (request()->ajax()) { $model = user::query()->orderBy('order'); return DataTables::eloquent($model) ->addIndexColumn() ->setRowClass('tableRow') ->addColumn('role', function (User $user) { if ($user->roles->isEmpty()) { return 'Not Assigned'; } $html = $user->roles->map(function ($role) { return "{$role->name}"; })->implode(' '); return $html; }) ->editColumn('can_login', function (User $user) { return $user->can_login ? 'Yes' : 'No'; }) ->editColumn('employee', function (User $user) { return $user->employee?->full_name ?? "-"; }) ->addColumn('action', 'user::user.datatable.action') ->rawColumns(['action', 'role', 'employee']) ->toJson(); } return view('user::user.index', [ 'user' => $user, 'title' => $isEditing ? 'Edit User' : 'Add User', ]); } /** * Show the form for creating a new resource. */ public function create() { // } /** * Store a newly created resource in storage. */ public function store(Request $request) { $isEditing = $request->has('id'); if ($isEditing) { $validated = $request->validate([ 'name' => ['required', 'string', 'max:255'], 'email' => [ 'required', 'string', 'lowercase', 'email', 'max:255', Rule::unique(User::class)->ignore($request->id), ], 'password' => ['nullable', 'confirmed', Rules\Password::defaults()], 'is_admin' => ['nullable'], ]); $user = $this->userService->updateUser($request->id, $validated); flash()->success("User for {$user->name} has been updated."); return to_route('user.index'); } $maxOrder = User::max('order'); $order = $maxOrder ? ++$maxOrder : 1; $request->mergeIfMissing([ 'order' => $order, ]); $validated = $request->validate([ 'name' => ['required', 'string', 'max:255'], 'email' => ['required', 'string', 'lowercase', 'email', 'max:255', 'unique:' . User::class], 'password' => ['required', 'confirmed', Rules\Password::defaults()], 'is_admin' => ['nullable'], 'order' => ['integer'], ]); $user = $this->userService->storeUser($validated); flash()->success("User for {$user->name} has been created."); return to_route('user.index'); } /** * Show the specified resource. */ public function show($id) { // } /** * Show the form for editing the specified resource. */ public function edit($id) { $user = $this->userService->getUserById($id); return view('user::user.edit', [ 'user' => $user, ]); } /** * Update the specified resource in storage. */ public function update(Request $request, $id) { // } /** * Remove the specified resource from storage. */ public function destroy($id) { $user = $this->userService->deleteUser($id); return response()->json(['status' => 200, 'message' => "User has been deleted."], 200); } public function reorder(Request $request) { $users = $this->userService->getAllUsers(); foreach ($users as $user) { foreach ($request->order as $order) { if ($order['id'] == $user->id) { $user->update(['order' => $order['position']]); } } } return response(['status' => true, 'message' => 'Reordered successfully'], 200); } public function showAssignRoleForm($id) { $user = $this->userService->getUserById($id); $roleOptions = $this->roleService->pluck(); $userRoleIds = $user->roles->pluck('id'); return view('user::user.partials._form', [ 'editable' => true, 'user' => $user, 'roleOptions' => $roleOptions, 'userRoleIds' => $userRoleIds, ]); } public function assignRole(Request $request, $id) { $validated = $request->validate([ 'role' => ['nullable', 'array'], ]); $user = $this->userService->getUserById($id); if (!isEmptyArray($request->role)) { $user->roles()->sync($validated['role']); $message = "Role has been assigned"; } else { $user->roles()->detach(); $message = "Role has been removed"; } if ($request->ajax()) { return response([ 'status' => 200, 'message' => $message, ], 200); } flash()->success($message); return to_route('user.index'); } public function toggleActivation(Request $request, $id) { $user = $this->userService->getUserById($id); $message = $user->can_login ? 'User has been deactivated' : 'User has been activated'; $user->update(['can_login' => !$user->can_login]); return response([ 'status' => 200, 'message' => $message, ], 200); } }