* #118 - wip * #118 - keys * #118 - fix * #118 - fix menu * #118 - fix to policies and added translations * #118 - wip * #118 - tests * #118 - fix * #118 - fix * #118 - fix * Update resources/lang/pl.json Co-authored-by: Ewelina Lasowy <56546832+EwelinaLasowy@users.noreply.github.com> * #118 - cr fix Co-authored-by: EwelinaLasowy <ewelina.lasowy@blumilk.pl> Co-authored-by: Ewelina Lasowy <56546832+EwelinaLasowy@users.noreply.github.com>
		
			
				
	
	
		
			105 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			105 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
declare(strict_types=1);
 | 
						|
 | 
						|
namespace Toby\Infrastructure\Http\Controllers;
 | 
						|
 | 
						|
use Illuminate\Auth\Access\AuthorizationException;
 | 
						|
use Illuminate\Http\Request;
 | 
						|
use Inertia\Response;
 | 
						|
use Symfony\Component\HttpFoundation\RedirectResponse;
 | 
						|
use Toby\Eloquent\Models\Key;
 | 
						|
use Toby\Eloquent\Models\User;
 | 
						|
use Toby\Infrastructure\Http\Requests\GiveKeyRequest;
 | 
						|
use Toby\Infrastructure\Http\Resources\KeyResource;
 | 
						|
use Toby\Infrastructure\Http\Resources\SimpleUserResource;
 | 
						|
 | 
						|
class KeysController extends Controller
 | 
						|
{
 | 
						|
    public function index(Request $request): Response
 | 
						|
    {
 | 
						|
        $keys = Key::query()
 | 
						|
            ->oldest()
 | 
						|
            ->get();
 | 
						|
 | 
						|
        $users = User::query()
 | 
						|
            ->orderByProfileField("last_name")
 | 
						|
            ->orderByProfileField("first_name")
 | 
						|
            ->get();
 | 
						|
 | 
						|
        return inertia("Keys", [
 | 
						|
            "keys" => KeyResource::collection($keys),
 | 
						|
            "users" => SimpleUserResource::collection($users),
 | 
						|
            "can" => [
 | 
						|
                "manageKeys" => $request->user()->can("manage", Key::class),
 | 
						|
            ],
 | 
						|
        ]);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @throws AuthorizationException
 | 
						|
     */
 | 
						|
    public function store(Request $request): RedirectResponse
 | 
						|
    {
 | 
						|
        $this->authorize("manage", Key::class);
 | 
						|
 | 
						|
        $key = $request->user()->keys()->create();
 | 
						|
 | 
						|
        return redirect()
 | 
						|
            ->back()
 | 
						|
            ->with("success", __("Key no :number has been created.", [
 | 
						|
                "number" => $key->id,
 | 
						|
            ]));
 | 
						|
    }
 | 
						|
 | 
						|
    public function take(Key $key, Request $request): RedirectResponse
 | 
						|
    {
 | 
						|
        $previousUser = $key->user;
 | 
						|
 | 
						|
        $key->user()->associate($request->user());
 | 
						|
 | 
						|
        $key->save();
 | 
						|
 | 
						|
        return redirect()
 | 
						|
            ->back()
 | 
						|
            ->with("success", __("Key no :number has been taken from :user.", [
 | 
						|
                "number" => $key->id,
 | 
						|
                "user" => $previousUser->profile->full_name,
 | 
						|
            ]));
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @throws AuthorizationException
 | 
						|
     */
 | 
						|
    public function give(Key $key, GiveKeyRequest $request): RedirectResponse
 | 
						|
    {
 | 
						|
        $this->authorize("give", $key);
 | 
						|
 | 
						|
        $recipient = $request->recipient();
 | 
						|
 | 
						|
        $key->user()->associate($recipient);
 | 
						|
 | 
						|
        $key->save();
 | 
						|
 | 
						|
        return redirect()
 | 
						|
            ->back()
 | 
						|
            ->with("success", __("Key no :number has been given to :user.", [
 | 
						|
                "number" => $key->id,
 | 
						|
                "user" => $recipient->profile->full_name,
 | 
						|
            ]));
 | 
						|
    }
 | 
						|
 | 
						|
    public function destroy(Key $key): RedirectResponse
 | 
						|
    {
 | 
						|
        $this->authorize("manage", Key::class);
 | 
						|
 | 
						|
        $key->delete();
 | 
						|
 | 
						|
        return redirect()
 | 
						|
            ->back()
 | 
						|
            ->with("success", __("Key no :number has been deleted.", [
 | 
						|
                "number" => $key->id,
 | 
						|
            ]));
 | 
						|
    }
 | 
						|
}
 |