phpvms/app/Http/Controllers/Frontend/FlightController.php

123 lines
3.3 KiB
PHP
Raw Normal View History

2017-08-03 04:12:26 +08:00
<?php
namespace App\Http\Controllers\Frontend;
2017-12-05 04:21:46 +08:00
use App\Repositories\AirlineRepository;
use App\Repositories\AirportRepository;
use Log;
2017-08-03 04:12:26 +08:00
use Illuminate\Http\Request;
2017-08-03 04:29:04 +08:00
use Illuminate\Support\Facades\Auth;
2017-08-03 04:12:26 +08:00
2017-12-05 04:21:46 +08:00
use App\Http\Controllers\AppBaseController;
2017-08-04 10:02:02 +08:00
use App\Models\UserFlight;
2017-12-05 04:21:46 +08:00
use App\Repositories\FlightRepository;
use App\Repositories\Criteria\WhereCriteria;
2017-12-05 04:21:46 +08:00
2017-08-04 10:02:02 +08:00
use Mockery\Exception;
use Prettus\Repository\Exceptions\RepositoryException;
2017-08-03 04:12:26 +08:00
class FlightController extends AppBaseController
{
2017-12-05 04:21:46 +08:00
private $airlineRepo, $airportRepo, $flightRepo;
public function __construct(
AirlineRepository $airlineRepo,
AirportRepository $airportRepo,
FlightRepository $flightRepo
) {
$this->airlineRepo = $airlineRepo;
$this->airportRepo = $airportRepo;
2017-08-03 04:12:26 +08:00
$this->flightRepo = $flightRepo;
}
public function index(Request $request)
{
2017-08-03 04:29:04 +08:00
$where = ['active' => true];
2017-08-03 04:12:26 +08:00
2017-08-03 04:29:04 +08:00
// default restrictions on the flights shown. Handle search differently
if (config('phpvms.only_flights_from_current')) {
$where['dpt_airport_id'] = Auth::user()->curr_airport_id;
}
try {
$this->flightRepo->pushCriteria(new WhereCriteria($request, $where));
} catch (RepositoryException $e) {
Log::emergency($e);
}
$flights = $this->flightRepo->paginate();
2017-08-03 04:29:04 +08:00
2017-08-04 10:02:02 +08:00
$saved_flights = UserFlight::where('user_id', Auth::id())
->pluck('flight_id')->toArray();
2017-08-03 04:12:26 +08:00
return $this->view('flights.index', [
2017-12-05 04:21:46 +08:00
'airlines' => $this->airlineRepo->selectBoxList(true),
'airports' => $this->airportRepo->selectBoxList(true),
2017-08-03 04:12:26 +08:00
'flights' => $flights,
2017-08-04 10:02:02 +08:00
'saved' => $saved_flights,
2017-08-03 04:12:26 +08:00
]);
}
/**
* Make a search request using the Repository search
* @param Request $request
* @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View
* @throws \Prettus\Repository\Exceptions\RepositoryException
*/
2017-08-04 10:02:02 +08:00
public function search(Request $request)
2017-08-03 04:12:26 +08:00
{
$flights = $this->flightRepo->searchCriteria($request)->paginate();
2017-08-03 04:29:04 +08:00
2017-08-04 10:02:02 +08:00
$saved_flights = UserFlight::where('user_id', Auth::id())
->pluck('flight_id')->toArray();
2017-08-03 04:29:04 +08:00
return $this->view('flights.index', [
2017-12-05 04:21:46 +08:00
'airlines' => $this->airlineRepo->selectBoxList(true),
'airports' => $this->airportRepo->selectBoxList(true),
2017-08-03 04:29:04 +08:00
'flights' => $flights,
2017-08-04 10:02:02 +08:00
'saved' => $saved_flights,
2017-08-03 04:29:04 +08:00
]);
}
2017-08-04 10:02:02 +08:00
public function save(Request $request)
{
$user_id = Auth::id();
$flight_id = $request->input('flight_id');
$action = strtolower($request->input('action'));
2017-08-04 10:02:02 +08:00
$cols = ['user_id' => $user_id, 'flight_id' => $flight_id];
if($action === 'save') {
2017-08-04 10:02:02 +08:00
$uf = UserFlight::create($cols);
$uf->save();
return response()->json([
'id' => $uf->id,
'message' => 'Saved!',
]);
}
elseif ($action === 'remove') {
2017-08-04 10:02:02 +08:00
try {
$uf = UserFlight::where($cols)->first();
$uf->delete();
} catch (Exception $e) { }
return response()->json([
'message' => 'Deleted!'
]);
}
}
2017-08-03 04:12:26 +08:00
public function update()
{
}
2017-08-04 10:02:02 +08:00
public function show($id)
{
}
2017-08-03 04:12:26 +08:00
}