IMMREX7
<?php
namespace App\Http\Controllers\School\Hostel;
use Illuminate\Http\Request;
use App\Http\Controllers\School\SchoolController;
use Auth;
use DB;
class BedController extends SchoolController {
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function index() {
$beds = \App\HostelBed::where('idSchool', '=', Auth::guard('school')->user()->idSchool)
->orderBy('idBed', 'desc')->get();
$floors = ['' => '---Select---'] + \App\HostelFloor::where('idSchool', '=', Auth::guard('school')->user()->idSchool)
->get()->pluck('floorName', 'idFloor')->toArray();
return view('schools.hostel.bed', compact('floors', 'beds'));
}
/**
* Show the form for creating a new resource.
*
* @return \Illuminate\Http\Response
*/
public function create() {
//
}
/**
* Store a newly created resource in storage.
*
* @param \Illuminate\Http\Request $request
* @return \Illuminate\Http\Response
*/
public function store(Request $request) {
$rules['bedName'] = 'unique:hostel_beds,bedName,NULL,idBed,idSchool,' . Auth::guard('school')->user()->idSchool;
$message = [
'bedName.unique' => 'Bed Already Exist.',
];
$this->Validate($request, $rules, $message);
foreach ($request->beds as $var) {
$bed = new \App\HostelBed();
$bed->fill($request->all());
$bed->idSchool = Auth::guard('school')->user()->idSchool;
$bed->bedName = $var['bedName'];
$bed->save();
}
flash('Data has been added successfully!!');
if ($request->ajax()) {
return response()->json(['success' => "SUCCESS"], 200, ['app-status' => 'success']);
}
return redirect('school/beds');
}
/**
* Display the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function show($id) {
//
}
/**
* Show the form for editing the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function edit($id) {
$beds = \App\HostelBed::where('idSchool', '=', Auth::guard('school')->user()->idSchool)
->orderBy('idBed', 'desc')->get();
$floors = ['' => '---Select---'] + \App\HostelFloor::where('idSchool', '=', Auth::guard('school')->user()->idSchool)
->get()->pluck('floorName', 'idFloor')->toArray();
$bed = \App\HostelBed::where('idBed', '=', $id)->first();
$rooms = ['' => '---Select---'] + \App\HostelRoom::where('idFloor', '=',$bed->idFloor)
->get()->pluck('roomName', 'idRoom')->toArray();
return view('schools.hostel.bed', compact('floors', 'beds', 'bed','rooms'));
}
/**
* Update the specified resource in storage.
*
* @param \Illuminate\Http\Request $request
* @param int $id
* @return \Illuminate\Http\Response
*/
public function update(Request $request, $id) {
$bed = \App\HostelBed::where('idBed', '=', $id)->first();
$rules = [
'bedName' => 'required|unique:hostel_beds,bedName,' . $id . ',idBed,idSchool,' . Auth::guard('school')->user()->idSchool,
];
$this->validate($request, $rules);
$bed->fill($request->all());
$bed->update();
return redirect('school/beds');
}
/**
* Remove the specified resource from storage.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function destroy($id) {
$bed = \App\HostelBed::where('idBed', '=', $id)->first();
$bed->delete();
return response()->json(['success' => "SUCCESS"], 200, ['app-status' => 'success']);
}
}
Copyright © 2021 -