Heera/Modules/User/app/Http/Controllers/UserController.php
2024-05-16 09:31:08 +05:45

149 lines
3.8 KiB
PHP

<?php
namespace Modules\User\Http\Controllers;
use App\Http\Controllers\Controller;
use App\Models\User;
use Illuminate\Http\RedirectResponse;
use Illuminate\Http\Request;
use Modules\Employee\Repositories\EmployeeInterface;
use Modules\User\Repositories\RoleInterface;
use Modules\User\Repositories\UserInterface;
class UserController extends Controller
{
/**
* Display a listing of the resource.
*/
protected $userRepository;
protected $employeeRepository;
protected $roleRepository;
public function __construct(UserInterface $userRepository, EmployeeInterface $employeeRepository, RoleInterface $roleRepository)
{
$this->userRepository = $userRepository;
$this->employeeRepository = $employeeRepository;
$this->roleRepository = $roleRepository;
}
public function index()
{
$data['users'] = $this->userRepository->findAll();
$data['editable'] = false;
$data['roleLists'] = $this->roleRepository->pluck();
$data['employeeLists'] = $this->employeeRepository->pluck();
return view('user::user.index', $data);
}
/**
* Show the form for creating a new resource.
*/
public function create()
{
$data['title'] = "Create User";
$data['editable'] = false;
$data['roleLists'] = $this->roleRepository->pluck();
$data['employeeLists'] = $this->employeeRepository->pluck();
return view('user::user.create', $data);
}
/**
* Store a newly created resource in storage.
*/
public function store(Request $request): RedirectResponse
{
try {
$validated = $request->validate([
'name' => 'required|min:5',
'email' => 'required',
'password' => 'required',
]);
$validated['password'] = bcrypt($validated['password']);
$this->userRepository->create($validated, $request->role);
toastr()->success('User has been created!');
} catch (\Throwable $th) {
echo $th->getMessage();
toastr()->error($th->getMessage());
}
return redirect()->route('user.index');
}
/**
* Show the specified resource.
*/
public function show($id)
{
$data['user'] = $this->userRepository->getUserById($id);
return view('user::user.show');
}
/**
* Show the form for editing the specified resource.
*/
public function edit($id)
{
$data['title'] = "Edit User";
$data['editable'] = true;
$data['roleLists'] = $this->roleRepository->pluck();
$data['employeeLists'] = $this->employeeRepository->pluck();
$data['user'] = $this->userRepository->getUserById($id);
return view('user::user.edit', $data);
}
/**
* Update the specified resource in storage.
*/
public function update(Request $request, $id): RedirectResponse
{
try {
$validated = $request->validate([
'name' => 'required|min:5',
'email' => 'required',
'password' => 'required',
]);
$validated['password'] = bcrypt($validated['password']);
$this->userRepository->update($id, $validated, $request->role);
toastr()->success('User has been updated!');
} catch (\Throwable $th) {
toastr()->error($th->getMessage());
}
return redirect()->route('user.index');
}
/**
* Remove the specified resource from storage.
*/
public function destroy($id)
{
try {
$this->userRepository->delete($id);
toastr()->success('User has been deleted!');
} catch (\Throwable $th) {
toastr()->error($th->getMessage());
}
}
}