<?php namespace App\Http\Controllers; use Illuminate\Http\Request; use App\vehicle; use DB; use Carbon\Carbon; // formatowanie daty function formatDate($date) { if ($date == null) return $date; else $fdate = Carbon::parse($date); return $fdate; } class VehiclesController extends Controller { public function create(){ if(auth()->user() != null && auth()->user()->fireStationID != null ){ $vehicles = DB::table('vehicles')->where("fireStationID", '=', auth()->user()->fireStationID) ->whereNull('deleted_at')->paginate(10); return view("vehicles", ["vehicles" => $vehicles]); } else{ return view('vehicles'); } } public function addForm(){ if(auth()->user() != null && auth()->user()->accessLevel() == 50 ){ //prezes,naczelnik return view('vehiclesAdd'); } else return redirect()->to('/pojazdy'); } public function editForm($id) { if(auth()->user() != null && auth()->user()->accessLevel() == 50 ) //prezes,naczelnik { $vehicle = DB::table('vehicles')->where("id", $id)->first(); return view('vehiclesEdit', ["vehicle" => $vehicle]); } else redirect()->to('/pojazdy'); } public function store(){ $this->validate(request(), [ 'vehicleName' => 'required|max:45', 'codename' => 'required|max:45', 'brand' => 'max:45', 'registrationNumber' => 'max:15', 'productionYear' => 'digits:4|nullable', 'driveType' => 'max:45', 'chassisType' => 'max:45', 'bodyProducer' => 'max:45', 'crewNumber' => 'numeric|nullable|digits_between:1,2', 'foamAgent' => 'numeric|nullable|digits_between:1,10', 'enginePower' => 'numeric|nullable|digits_between:1,10', 'mass' => 'numeric|nullable|digits_between:1,10', 'chassisNumber' => 'max:45', 'engineNumber' => 'max:45', 'fuelType' => 'max:45', 'chassisPoductionYear' => 'digits:4|nullable', 'fireEnginePumpDescription' => 'max:250', ], [ 'name' => 'nazwa', 'required' => ':attribute jest wymagany(e).', 'numeric' => ':attribute może zawierać tylko cyfry.', 'digits' => ':attribute musi składać się z :digits cyfr.', 'max' => ':attribute musi mieć nie więcej niż :max znaków.', 'digits_between' => ':attribute jest za duży(a)' ]); $request = request(); $vehicle = vehicle::create([ 'fireStationID' => auth()->user()->fireStationID, 'name' => $request-> vehicleName, 'codename' => $request-> codename, 'brand' => $request-> brand, 'registrationNumber' => $request-> registrationNumber, 'productionYear' => $request-> productionYear, 'examExpirationDate' => formatDate($request-> examExpirationDate), 'insuranceExpirationDate' => formatDate($request-> insuranceExpirationDate), 'driveType' => $request-> driveType, 'chassisType' => $request-> chassisType, 'bodyProducer' => $request-> bodyProducer, 'crewNumber' => $request-> crewNumber, 'foamAgent' => $request-> foamAgent, 'enginePower' => $request-> enginePower, 'mass' => $request-> mass, 'chassisNumber' => $request-> chassisNumber, 'engineNumber' => $request-> engineNumber, 'fuelType' => $request-> fuelType, 'chassisPoductionYear' => $request-> chassisPoductionYear, 'entryIntoServiceDate' => formatDate($request-> entryIntoServiceDate), 'fireEnginePumpDescription' => $request-> fireEnginePumpDescription, 'status' => $request-> status ]); return redirect()->to('/pojazdy'); } public function update(){ $this->validate(request(), [ 'vehicleName' => 'required|max:45', 'codename' => 'required|max:45', 'brand' => 'max:45', 'registrationNumber' => 'max:15', 'productionYear' => 'digits:4|nullable', 'driveType' => 'max:45', 'chassisType' => 'max:45', 'bodyProducer' => 'max:45', 'crewNumber' => 'numeric|nullable|digits_between:1,2', 'foamAgent' => 'numeric|nullable|digits_between:1,10', 'enginePower' => 'numeric|nullable|digits_between:1,10', 'mass' => 'numeric|nullable|digits_between:1,10', 'chassisNumber' => 'max:45', 'engineNumber' => 'max:45', 'fuelType' => 'max:45', 'chassisPoductionYear' => 'digits:4|nullable', 'fireEnginePumpDescription' => 'max:250', ], [ 'name' => 'nazwa', 'required' => ':attribute jest wymagany(e).', 'numeric' => ':attribute może zawierać tylko cyfry.', 'digits' => ':attribute musi składać się z :digits cyfr.', 'max' => ':attribute musi mieć nie więcej niż :max znaków.', 'digits_between' => ':attribute jest za duży(a)' ]); $request = request(); $vehicle = vehicle::find( $request->vehicleID); $vehicle-> name = $request-> vehicleName; $vehicle-> codename = $request-> codename; $vehicle-> brand = $request-> brand; $vehicle-> registrationNumber = $request-> registrationNumber; $vehicle-> productionYear = $request-> productionYear; $vehicle-> examExpirationDate = formatDate($request-> examExpirationDate); $vehicle-> insuranceExpirationDate = formatDate($request-> insuranceExpirationDate); $vehicle-> driveType = $request-> driveType; $vehicle-> chassisType = $request-> chassisType; $vehicle-> bodyProducer = $request-> bodyProducer; $vehicle-> crewNumber = $request-> crewNumber; $vehicle-> foamAgent = $request-> foamAgent; $vehicle-> enginePower = $request-> enginePower; $vehicle-> mass = $request-> mass; $vehicle-> chassisNumber = $request-> chassisNumber; $vehicle-> engineNumber = $request-> engineNumber; $vehicle-> fuelType = $request-> fuelType; $vehicle-> chassisPoductionYear = $request-> chassisPoductionYear; $vehicle-> entryIntoServiceDate = formatDate($request-> entryIntoServiceDate); $vehicle-> fireEnginePumpDescription = $request-> fireEnginePumpDescription; $vehicle-> status = $request-> status; $vehicle->save(); return redirect()->to('/pojazdy');; } public function destroy($id) { vehicle::where('id',$id)->delete(); return response()->json([ 'success' => 'Record deleted successfully!' ]); } public function activate() { $request = request(); $vehicle = vehicle::find( $request-> vehicleID); $vehicle-> status = 1; $vehicle->save(); return redirect()->to('/pojazdy'); } public function deactivate() { $request = request(); $vehicle = vehicle::find( $request-> vehicleID); $vehicle-> status = 0; $vehicle->save(); return redirect()->to('/pojazdy'); } }