aircraftRepo = $aircraftRepo; $this->importSvc = $importSvc; } /** * Display a listing of the Aircraft. * * @param Request $request * * @throws \Prettus\Repository\Exceptions\RepositoryException * * @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View */ public function index(Request $request) { // If subfleet ID is passed part of the query string, then only // show the aircraft that are in that subfleet $w = []; if ($request->filled('subfleet')) { $w['subfleet_id'] = $request->input('subfleet'); } $aircraft = $this->aircraftRepo->whereOrder($w, 'registration', 'asc'); $aircraft = $aircraft->all(); return view('admin.aircraft.index', [ 'aircraft' => $aircraft, 'subfleet_id' => $request->input('subfleet'), ]); } /** * Show the form for creating a new Aircraft. * * @param Request $request * * @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View */ public function create(Request $request) { return view('admin.aircraft.create', [ 'subfleets' => Subfleet::all()->pluck('name', 'id'), 'statuses' => AircraftStatus::select(true), 'subfleet_id' => $request->query('subfleet'), ]); } /** * Store a newly created Aircraft in storage. * * @throws \Prettus\Validator\Exceptions\ValidatorException */ public function store(CreateAircraftRequest $request) { $attrs = $request->all(); $aircraft = $this->aircraftRepo->create($attrs); Flash::success('Aircraft saved successfully.'); return redirect(route('admin.aircraft.edit', ['id' => $aircraft->id])); } /** * Display the specified Aircraft. * * @param mixed $id */ public function show($id) { $aircraft = $this->aircraftRepo->findWithoutFail($id); if (empty($aircraft)) { Flash::error('Aircraft not found'); return redirect(route('admin.aircraft.index')); } return view('admin.aircraft.show', [ 'aircraft' => $aircraft, ]); } /** * Show the form for editing the specified Aircraft. * * @param mixed $id */ public function edit($id) { $aircraft = $this->aircraftRepo->findWithoutFail($id); if (empty($aircraft)) { Flash::error('Aircraft not found'); return redirect(route('admin.aircraft.index')); } return view('admin.aircraft.edit', [ 'subfleets' => Subfleet::all()->pluck('name', 'id'), 'statuses' => AircraftStatus::select(true), 'aircraft' => $aircraft, ]); } /** * Update the specified Aircraft in storage. * * @param mixed $id * * @throws \Prettus\Validator\Exceptions\ValidatorException */ public function update($id, UpdateAircraftRequest $request) { $aircraft = $this->aircraftRepo->findWithoutFail($id); if (empty($aircraft)) { Flash::error('Aircraft not found'); return redirect(route('admin.aircraft.index')); } $attrs = $request->all(); $this->aircraftRepo->update($attrs, $id); Flash::success('Aircraft updated successfully.'); return redirect(route('admin.aircraft.index')); } /** * Remove the specified Aircraft from storage. * * @param mixed $id */ public function destroy($id) { $aircraft = $this->aircraftRepo->findWithoutFail($id); if (empty($aircraft)) { Flash::error('Aircraft not found'); return redirect(route('admin.aircraft.index')); } $this->aircraftRepo->delete($id); Flash::success('Aircraft deleted successfully.'); return redirect(route('admin.aircraft.index')); } /** * Run the aircraft exporter * * @param Request $request * * @throws \League\Csv\Exception * * @return \Symfony\Component\HttpFoundation\BinaryFileResponse */ public function export(Request $request) { $exporter = app(ExportService::class); $aircraft = $this->aircraftRepo->all(); $path = $exporter->exportAircraft($aircraft); return response() ->download($path, 'aircraft.csv', [ 'content-type' => 'text/csv', ]) ->deleteFileAfterSend(true); } /** * @param Request $request * * @throws \Illuminate\Validation\ValidationException * * @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View */ public function import(Request $request) { $logs = [ 'success' => [], 'errors' => [], ]; if ($request->isMethod('post')) { ImportRequest::validate($request); $path = Storage::putFileAs( 'import', $request->file('csv_file'), 'import_aircraft.csv' ); $path = storage_path('app/'.$path); Log::info('Uploaded aircraft import file to '.$path); $logs = $this->importSvc->importAircraft($path); } return view('admin.aircraft.import', [ 'logs' => $logs, ]); } /** * @param Aircraft|null $aircraft * * @return mixed */ protected function return_expenses_view(Aircraft $aircraft) { $aircraft->refresh(); return view('admin.aircraft.expenses', [ 'aircraft' => $aircraft, ]); } /** * Operations for associating ranks to the subfleet * * @param $id * @param Request $request * * @throws \Exception * * @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View */ public function expenses($id, Request $request) { $aircraft = $this->aircraftRepo->findWithoutFail($id); if (empty($aircraft)) { return $this->return_expenses_view($aircraft); } if ($request->isMethod('get')) { return $this->return_expenses_view($aircraft); } if ($request->isMethod('post')) { $expense = new Expense($request->post()); $expense->ref_model = Aircraft::class; $expense->ref_model_id = $aircraft->id; $expense->save(); } elseif ($request->isMethod('put')) { $expense = Expense::findOrFail($request->input('expense_id')); $expense->{$request->name} = $request->value; $expense->save(); } // dissassociate fare from teh aircraft elseif ($request->isMethod('delete')) { $expense = Expense::findOrFail($request->input('expense_id')); $expense->delete(); } return $this->return_expenses_view($aircraft); } }