<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use function dd;
use function redirect;
use Illuminate\Support\Facades\Validator;
use Illuminate\Support\Facades\Redirect;
use App\Models\Reservation;
use App\Models\SpecialCall;
use function response;
class ReservationsController extends Controller
{
public function index(Request $request)
{
//$activities = Reservation::addSelect([
//'specialCall' => SpecialCall::select('sign')
////->whereColumn('reservations.specialCall', 'special_calls.id')
//->whereColumn('specialCall', 'id')
//->limit(1)
//])->get();
if ($request->isMethod('post')) {
$request->validate([
'call-sign' => 'required|alphanum'
]);
if ($request->input('call-sign') == 'all') {
$activities = Reservation::where('approved', '1')
->select('operatorCall', 'fromTime', 'toTime', 'specialCall', 'frequencies', 'qso')
->get()->toArray();
$data = [
'status' => 'OK',
'data' => $activities
];
return response($data);
} else {
$activities = Reservation::where('approved', '1')
->select('operatorCall', 'fromTime', 'toTime', 'specialCall', 'frequencies', 'qso')
->where('specialCall', $request->input('call-sign'))
->get()
->toArray();
$data = [
'status' => 'OK',
'data' => $activities
];
return response($data);
}
} else if ($request->isMethod('get')) {
$signs = SpecialCall::all();
return view('pages.activities', compact('signs'));
}
}
public function create(Request $request)
{
$signs = SpecialCall::all();
return view('pages.reserve', compact('signs'));
}
public function store(Request $request)
{
//$validatedData = $request->validate([
//...
//]);
$rules = [
'scall' => 'required|alphanum',
'sdate' => 'required|date',
'stime' => 'required',
'edate' => 'required|date',
'etime' => 'required',
'freqs' => 'required',
'modes' => 'required',
'ocall' => 'required|alphanum',
'oname' => 'required',
'email' => 'required|email',
'phone' => ['required', 'regex:/^[0-9 ]+$/'],
];
$messages = [
'freqs.required' => 'You need to choose at least one frequency.',
'modes.required' => 'You need to choose at least one mode.',
'ocall.alphanum' => 'Callsigns must be alpha-numeric!',
];
$validator = Validator::make($request->all(), $rules, $messages);
$validator->after(function ($validator) use ($request) {
$fromStamp = strtotime($request->sdate . ' ' . $request->stime);
$toStamp = strtotime($request->edate . ' ' . $request->etime);
if (!($fromStamp < $toStamp)) {
$validator->errors()->add('time', 'FROM time and date needs to be before TO time and date.');
}
});
if ($validator->fails()) {
return Redirect::back()
->withErrors($validator)
->withInput();
}
$reservation = new Reservation();
$reservation->specialCall = $request->scall;
$reservation->fromTime = $request->sdate . ' ' . $request->stime;
$reservation->toTime = $request->edate . ' ' . $request->etime;
$reservation->frequencies = implode(', ', $request->freqs);
$reservation->modes = implode(', ', $request->modes);
$reservation->operatorCall = $request->ocall;
$reservation->operatorName = $request->oname;
$reservation->operatorEmail = $request->email;
$reservation->operatorPhone = $request->phone;
$reservation->saveOrFail();
return redirect()->route('reserve')->with('status', 'Reservation submitted.');
}
// Administration
public function edit(Request $request)
{
$data = Reservation::all();
return view('pages.reservations', compact('data'));
}
public function update(Request $request)
{
return Redirect::back();
}
}