* fix css focuses * #90 - wip * #90 - fix to generate PDF * #90 - wip * #90 - wip * #90 - wip * #90 - wip * #90 - fix to calendar * #90 - wip * #90 - fix * #90 - fix lint * #90 - fix * Apply suggestions from code review Co-authored-by: Krzysztof Rewak <krzysztof.rewak@gmail.com> Co-authored-by: Ewelina Lasowy <56546832+EwelinaLasowy@users.noreply.github.com> * #90 - cr fixes * #90 - fix Co-authored-by: EwelinaLasowy <ewelina.lasowy@blumilk.pl> Co-authored-by: Krzysztof Rewak <krzysztof.rewak@gmail.com> Co-authored-by: Ewelina Lasowy <56546832+EwelinaLasowy@users.noreply.github.com>
		
			
				
	
	
		
			126 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			126 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| declare(strict_types=1);
 | |
| 
 | |
| namespace Toby\Infrastructure\Http\Controllers;
 | |
| 
 | |
| use Illuminate\Auth\Access\AuthorizationException;
 | |
| use Illuminate\Http\RedirectResponse;
 | |
| use Illuminate\Http\Request;
 | |
| use Inertia\Response;
 | |
| use Toby\Domain\Actions\CreateUserAction;
 | |
| use Toby\Domain\Actions\UpdateUserAction;
 | |
| use Toby\Domain\Enums\EmploymentForm;
 | |
| use Toby\Domain\Enums\Role;
 | |
| use Toby\Eloquent\Models\User;
 | |
| use Toby\Infrastructure\Http\Requests\UserRequest;
 | |
| use Toby\Infrastructure\Http\Resources\UserFormDataResource;
 | |
| use Toby\Infrastructure\Http\Resources\UserResource;
 | |
| 
 | |
| class UserController extends Controller
 | |
| {
 | |
|     /**
 | |
|      * @throws AuthorizationException
 | |
|      */
 | |
|     public function index(Request $request): Response
 | |
|     {
 | |
|         $this->authorize("manageUsers");
 | |
| 
 | |
|         $users = User::query()
 | |
|             ->withTrashed()
 | |
|             ->search($request->query("search"))
 | |
|             ->orderByProfileField("last_name")
 | |
|             ->orderByProfileField("first_name")
 | |
|             ->paginate()
 | |
|             ->withQueryString();
 | |
| 
 | |
|         return inertia("Users/Index", [
 | |
|             "users" => UserResource::collection($users),
 | |
|             "filters" => $request->only("search"),
 | |
|         ]);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @throws AuthorizationException
 | |
|      */
 | |
|     public function create(): Response
 | |
|     {
 | |
|         $this->authorize("manageUsers");
 | |
| 
 | |
|         return inertia("Users/Create", [
 | |
|             "employmentForms" => EmploymentForm::casesToSelect(),
 | |
|             "roles" => Role::casesToSelect(),
 | |
|         ]);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @throws AuthorizationException
 | |
|      */
 | |
|     public function store(UserRequest $request, CreateUserAction $createUserAction): RedirectResponse
 | |
|     {
 | |
|         $this->authorize("manageUsers");
 | |
| 
 | |
|         $createUserAction->execute($request->userData(), $request->profileData());
 | |
| 
 | |
|         return redirect()
 | |
|             ->route("users.index")
 | |
|             ->with("success", __("User has been created."));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @throws AuthorizationException
 | |
|      */
 | |
|     public function edit(User $user): Response
 | |
|     {
 | |
|         $this->authorize("manageUsers");
 | |
| 
 | |
|         return inertia("Users/Edit", [
 | |
|             "user" => new UserFormDataResource($user),
 | |
|             "employmentForms" => EmploymentForm::casesToSelect(),
 | |
|             "roles" => Role::casesToSelect(),
 | |
|         ]);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @throws AuthorizationException
 | |
|      */
 | |
|     public function update(UserRequest $request, UpdateUserAction $updateUserAction, User $user): RedirectResponse
 | |
|     {
 | |
|         $this->authorize("manageUsers");
 | |
| 
 | |
|         $updateUserAction->execute($user, $request->userData(), $request->profileData());
 | |
| 
 | |
|         return redirect()
 | |
|             ->route("users.index")
 | |
|             ->with("success", __("User has been updated."));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @throws AuthorizationException
 | |
|      */
 | |
|     public function destroy(User $user): RedirectResponse
 | |
|     {
 | |
|         $this->authorize("manageUsers");
 | |
| 
 | |
|         $user->delete();
 | |
| 
 | |
|         return redirect()
 | |
|             ->route("users.index")
 | |
|             ->with("success", __("User has been deleted."));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @throws AuthorizationException
 | |
|      */
 | |
|     public function restore(User $user): RedirectResponse
 | |
|     {
 | |
|         $this->authorize("manageUsers");
 | |
| 
 | |
|         $user->restore();
 | |
| 
 | |
|         return redirect()
 | |
|             ->route("users.index")
 | |
|             ->with("success", __("User has been restored."));
 | |
|     }
 | |
| }
 |