IMMREX7
<?php
namespace App\Http\Controllers\School;
use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use Auth;
use DB;
use Session;
class EmpExpencesController extends SchoolController {
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function index(Request $request) {
$empexpensess = \App\EmployeeExpense::where('idSchool', '=', Auth::guard('school')->user()->idSchool)
->orderBy('idExpense', 'desc');
if ($request->has('idFinancialYear')) {
$empexpensess = $empexpensess->where('idFinancialYear', '=', $request->idFinancialYear)->get();
} else {
$empexpensess = $empexpensess->where('idFinancialYear', '=', Session::get('idFinancialYear'))->get();
}
$employees = ['' => 'Select'] + \App\Employee::where('idSchool', '=', Auth::guard('school')->user()->idSchool)->get()->pluck('name', 'idEmployee')->toArray();
return view('schools.hrms.empexpences', compact('empexpensess', 'employees'));
}
/**
* 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 = [
'idEmployee' => 'required',
'amount' => 'required',
'remarks' => 'required',
// 'billCopy' => 'mimes:pdf'
];
$messages = [
'idEmployee.required' => 'Employee must be selected.',
'remarks.required' => 'Please Enter Purpose of Expence',
];
$this->validate($request, $rules, $messages);
$expence = new \App\EmployeeExpense();
$expence->fill($request->all());
$expence->expense_date = $request->date;
$expence->idFinancialYear = getFinancialYear();
$expence->idSchool = Auth::guard('school')->user()->idSchool;
DB::beginTransaction();
$expence->save();
if ($request->hasFile('billCopy')) {
$doc = 'billcopy_' . $expence->idExpense . '.' . $request->file('billCopy')->getClientOriginalExtension();
$request->file('billCopy')->storeAs('public/schools/' . Auth::guard('school')->user()->idSchool . '/employees/', $doc);
$expence->billCopy = $doc;
}
$expence->update();
DB::commit();
return redirect('school/empexpenses');
}
/**
* Display the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function show($id) {
$expence = \App\EmployeeExpense::where('idExpense', '=', $id)->first();
$path = storage_path('app/public/schools/' . $expence->idSchool . '/employees/' . $expence->billCopy);
return response()->file($path);
}
/**
* Show the form for editing the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function edit($id) {
$empexpensess = \App\EmployeeExpense::where('idSchool', '=', Auth::guard('school')->user()->idSchool)
->where('idFinancialYear', '=', getFinancialYear())
->orderBy('idExpense', 'desc')->get();
$employees = ['' => 'Select'] + \App\Employee::where('idSchool', '=', Auth::guard('school')->user()->idSchool)->get()->pluck('name', 'idEmployee')->toArray();
$expence = \App\EmployeeExpense::where('idExpense', '=', $id)->first();
return view('schools.hrms.empexpences', compact('empexpensess', 'employees', 'expence'));
}
/**
* Update the specified resource in storage.
*
* @param \Illuminate\Http\Request $request
* @param int $id
* @return \Illuminate\Http\Response
*/
public function update(Request $request, $id) {
$rules = [
'idEmployee' => 'required',
'amount' => 'required',
'remarks' => 'required',
'billCopy' => 'required'
];
$messages = [
'idEmployee.required' => 'Employee must be selected.',
'remarks.required' => 'Please Enter Purpose of Expence',
];
$this->validate($request, $rules, $messages);
$expence = \App\EmployeeExpense::where('idExpense', '=', $id)->first();
$expence->fill($request->all());
$expence->expense_date = $request->date;
DB::beginTransaction();
if ($request->hasFile('billCopy')) {
$doc = 'billcopy_' . $expence->idExpense . '.' . $request->file('billCopy')->getClientOriginalExtension();
$request->file('billCopy')->storeAs('public/schools/' . Auth::guard('school')->user()->idSchool . '/employees/', $doc);
$expence->billCopy = $doc;
}
$expence->update();
DB::commit();
return redirect('school/empexpenses');
}
/**
* Remove the specified resource from storage.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function destroy($id) {
$expence = \App\EmployeeExpense::where('idExpense', '=', $id)->first();
$expence->delete();
return response()->json(['success' => "SUCCESS"], 200, ['app-status' => 'success']);
}
}
Copyright © 2021 -