43 lines
1.4 KiB
PHP
43 lines
1.4 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Staff;
|
|
|
|
use App\Http\Controllers\HashidControllerBase;
|
|
use App\Http\Requests\StudyHistoryRequest;
|
|
use App\Models\Enums\Permission;
|
|
use App\Models\StudyDetails;
|
|
|
|
class StudyHistoryController extends HashidControllerBase
|
|
{
|
|
public function view()
|
|
{
|
|
abort_unless(auth()->user()->can(Permission::StudyHistoryView) || auth()->user()->isAdmin(), 403);
|
|
$this->decodeKeys();
|
|
$details = StudyDetails::historyOnly($this->key);
|
|
|
|
return view('staff.history.view', compact('details'));
|
|
}
|
|
|
|
public function edit()
|
|
{
|
|
abort_unless(auth()->user()->can(Permission::StudyHistoryEdit) || auth()->user()->isAdmin(), 403);
|
|
$this->decodeKeys();
|
|
$details = StudyDetails::historyOnly($this->key);
|
|
|
|
return view('staff.history.edit', compact('details'));
|
|
}
|
|
|
|
public function save(StudyHistoryRequest $request)
|
|
{
|
|
abort_unless(auth()->user()->can(Permission::StudyHistoryEdit) || auth()->user()->isAdmin(), 403);
|
|
$this->decodeKeys();
|
|
$details = StudyDetails::historyOnly($this->key);
|
|
$payload = array_trim_strings($request->validated());
|
|
unset($payload['study_id']);
|
|
$details->update($payload);
|
|
|
|
// return redirect()->route('staff.history.view', _h($this->key));
|
|
return redirect()->route('staff.history.view', $details->hash);
|
|
}
|
|
}
|