forked from miguel456/rbrecruiter
108 lines
3.7 KiB
PHP
Executable File
108 lines
3.7 KiB
PHP
Executable File
<?php
|
|
|
|
/*
|
|
* Copyright © 2020 Miguel Nogueira
|
|
*
|
|
* This file is part of Raspberry Staff Manager.
|
|
*
|
|
* Raspberry Staff Manager is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Raspberry Staff Manager is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with Raspberry Staff Manager. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use App\Application;
|
|
use App\Appointment;
|
|
use App\Http\Requests\SaveNotesRequest;
|
|
use App\Notifications\ApplicationMoved;
|
|
use App\Notifications\AppointmentScheduled;
|
|
use Carbon\Carbon;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\Auth;
|
|
use Illuminate\Support\Facades\Log;
|
|
|
|
class AppointmentController extends Controller
|
|
{
|
|
private $allowedPlatforms = [
|
|
|
|
'ZOOM',
|
|
'DISCORD',
|
|
'SKYPE',
|
|
'MEET',
|
|
'TEAMSPEAK',
|
|
|
|
];
|
|
|
|
public function saveAppointment(Request $request, Application $application)
|
|
{
|
|
$this->authorize('create', Appointment::class);
|
|
$appointmentDate = Carbon::parse($request->appointmentDateTime);
|
|
|
|
$appointment = Appointment::create([
|
|
'appointmentDescription' => $request->appointmentDescription,
|
|
'appointmentDate' => $appointmentDate->toDateTimeString(),
|
|
'applicationID' => $application->id,
|
|
'appointmentLocation' => (in_array($request->appointmentLocation, $this->allowedPlatforms)) ? $request->appointmentLocation : 'DISCORD',
|
|
]);
|
|
$application->setStatus('STAGE_INTERVIEW_SCHEDULED');
|
|
|
|
Log::info('User '.Auth::user()->name.' has scheduled an appointment with '.$application->user->name.' for application ID'.$application->id, [
|
|
'datetime' => $appointmentDate->toDateTimeString(),
|
|
'scheduled' => now(),
|
|
]);
|
|
|
|
$application->user->notify(new AppointmentScheduled($appointment));
|
|
$request->session()->flash('success', 'Appointment successfully scheduled @ '.$appointmentDate->toDateTimeString());
|
|
|
|
return redirect()->back();
|
|
}
|
|
|
|
public function updateAppointment(Request $request, Application $application, $status)
|
|
{
|
|
$this->authorize('update', $application->appointment);
|
|
|
|
$validStatuses = [
|
|
'SCHEDULED',
|
|
'CONCLUDED',
|
|
];
|
|
|
|
// NOTE: This is a little confusing, refactor
|
|
$application->appointment->appointmentStatus = (in_array($status, $validStatuses)) ? strtoupper($status) : 'SCHEDULED';
|
|
$application->appointment->save();
|
|
|
|
$application->setStatus('STAGE_PEERAPPROVAL');
|
|
$application->user->notify(new ApplicationMoved());
|
|
|
|
$request->session()->flash('success', 'Interview finished! Staff members can now vote on it.');
|
|
|
|
return redirect()->back();
|
|
}
|
|
|
|
// also updates
|
|
public function saveNotes(SaveNotesRequest $request, Application $application)
|
|
{
|
|
if (! is_null($application)) {
|
|
$application->load('appointment');
|
|
|
|
$application->appointment->meetingNotes = $request->noteText;
|
|
$application->appointment->save();
|
|
|
|
$request->session()->flash('success', 'Meeting notes have been saved.');
|
|
} else {
|
|
$request->session()->flash('error', 'There\'s no appointment to save notes to!');
|
|
}
|
|
|
|
return redirect()->back();
|
|
}
|
|
}
|