You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

69 lines
2.0 KiB
PHP

<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Models\Keuangan;
use App\Exports\KeuanganExport;
use Maatwebsite\Excel\Facades\Excel;
class KeuanganController extends Controller
{
public function index()
{
$keuangan = Keuangan::orderBy('created_at','desc')->paginate(10);
return view('keuangan.index', [
'keuangan' => $keuangan,
]);
}
public function store(Request $request)
{
$request->validate([
'keperluan' => 'required|in:in,out',
'jumlah' => 'required|numeric',
'keterangan' => 'nullable',
]);
$keuangan = Keuangan::orderBy('created_at','desc')->first();
if($keuangan != null){
$simpan = Keuangan::make([
'tipe' => $request->keperluan,
'jumlah' => $request->jumlah,
'keterangan' => $request->keterangan
]);
if($request->keperluan == 'in'){
$simpan->total_kas = $keuangan->total_kas + $request->jumlah;
}else if($request->keperluan == 'out'){
$simpan->total_kas = $keuangan->total_kas - $request->jumlah;
}
}else{
$simpan = Keuangan::make([
'tipe' => $request->keperluan,
'jumlah' => $request->jumlah,
'keterangan' => $request->keterangan
]);
$simpan->total_kas = $request->jumlah;
}
if($simpan->save()){
return redirect()->route('keuangan.index')->with([
'type' => 'success',
'msg' => 'Pencatatan Keuangan dibuat'
]);
}else{
return redirect()->route('keuangan.index')->with([
'type' => 'danger',
'msg' => 'Terjadi Kesalahan'
]);
}
}
public function export()
{
return Excel::download(new KeuanganExport, 'mutasi_keuangan-'.now().'.xlsx');
}
}