60 lines
1.8 KiB
PHP
60 lines
1.8 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use App\Models\Audition;
|
|
use App\Models\Entry;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\Auth;
|
|
|
|
use function abort;
|
|
|
|
class EntryController extends Controller
|
|
{
|
|
// TODO authorization policies
|
|
public function index()
|
|
{
|
|
|
|
$entries = Auth::user()->entries()->with(['student', 'audition'])->get();
|
|
$auditions = Audition::deadlineNotPast();
|
|
$students = Auth::user()->students;
|
|
|
|
return view('entries.index', ['entries' => $entries, 'students' => $students, 'auditions' => $auditions]);
|
|
}
|
|
|
|
public function store(Request $request)
|
|
{
|
|
if ($request->user()->cannot('create', Entry::class)) {
|
|
abort(403);
|
|
}
|
|
// TODO write custom rule to verify the combination of student and audition is unique
|
|
$validData = $request->validate([
|
|
'student_id' => ['required', 'exists:students,id'],
|
|
'audition_id' => ['required', 'exists:auditions,id'],
|
|
]);
|
|
|
|
$validData['for_seating'] = $request->get('for_seating') ? 1 : 0;
|
|
$validData['for_advancement'] = $request->get('for_advancement') ? 1 : 0;
|
|
|
|
$entry = Entry::create([
|
|
'student_id' => $validData['student_id'],
|
|
'audition_id' => $validData['audition_id'],
|
|
'for_seating' => $validData['for_seating'],
|
|
'for_advancement' => $validData['for_advancement'],
|
|
]);
|
|
|
|
return redirect('/entries');
|
|
}
|
|
|
|
public function destroy(Request $request, Entry $entry)
|
|
{
|
|
if ($request->user()->cannot('delete', $entry)) {
|
|
abort(403);
|
|
}
|
|
$entry->delete();
|
|
|
|
return redirect('/entries')->with('success', 'The '.$entry->audition->name.'entry for '.$entry->student->full_name().'has been deleted.');
|
|
|
|
}
|
|
}
|