MIF_E31222596/website/app/Http/Controllers/PelanggaranController.php

124 lines
3.8 KiB
PHP

<?php
namespace App\Http\Controllers;
use App\Models\Pelanggaran;
use App\Models\Santri;
use App\Models\Kelas;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
class PelanggaranController extends Controller
{
public function index(Request $request)
{
$user = Auth::user();
$query = Pelanggaran::with(['santri', 'kelas', 'user'])
->orderBy('created_at', 'desc');
// filter berdasarkan role guru
if ($user->role === 'guru') {
$query->where('user_id', $user->id);
}
// filter search nama santri
if ($request->has('search') && $request->search != '') {
$query->whereHas('santri', function ($q) use ($request) {
$q->where('nama', 'like', '%' . $request->search . '%');
});
}
$pelanggarans = $query->paginate(10);
$view = $user->role === 'guru' ? 'guru.pelanggarans.index' : 'pelanggarans.index';
return view($view, compact('pelanggarans'));
}
public function create()
{
$santris = Santri::all();
$kelas = Kelas::all();
$view = auth()->user()->isGuru() ? 'guru.pelanggarans.create' : 'pelanggarans.create';
return view($view, compact('santris', 'kelas'));
}
public function store(Request $request)
{
$validated = $request->validate([
'santri_id' => 'required|exists:santris,id',
'kelas_id' => 'required|exists:kelas,id',
'jenis_pelanggaran' => 'required|string|max:255',
'hukuman' => 'required|in:Teguran Lisan,Teguran Tertulis,Skorsing,Lainnya',
'keterangan_hukuman' => 'nullable|string|max:255',
'hukuman_selesai' => 'nullable',
]);
$validated['user_id'] = Auth::id();
$validated['hukuman_selesai'] = $request->has('hukuman_selesai') ? 'selesai' : 'belum';
Pelanggaran::create($validated);
return redirect()->route('pelanggarans.index')->with('success', 'Data pelanggaran berhasil ditambahkan.');
}
public function update(Request $request, Pelanggaran $pelanggaran)
{
$validated = $request->validate([
'santri_id' => 'required|exists:santris,id',
'kelas_id' => 'required|exists:kelas,id',
'jenis_pelanggaran' => 'required|string|max:255',
'hukuman' => 'required|in:Teguran Lisan,Teguran Tertulis,Skorsing,Lainnya',
'keterangan_hukuman' => 'nullable|string|max:255',
'hukuman_selesai' => 'nullable',
]);
$validated['hukuman_selesai'] = $request->has('hukuman_selesai') ? 'selesai' : 'belum';
$pelanggaran->update($validated);
return redirect()->route('pelanggarans.index')->with('success', 'Data pelanggaran berhasil diperbarui.');
}
public function show(Pelanggaran $pelanggaran)
{
$this->authorizeAccess($pelanggaran);
$view = auth()->user()->isGuru() ? 'guru.pelanggarans.show' : 'pelanggarans.show';
return view($view, compact('pelanggaran'));
}
public function edit(Pelanggaran $pelanggaran)
{
$this->authorizeAccess($pelanggaran);
$santris = Santri::all();
$kelas = Kelas::all();
$view = auth()->user()->isGuru() ? 'guru.pelanggarans.edit' : 'pelanggarans.edit';
return view($view, compact('pelanggaran', 'santris', 'kelas'));
}
public function destroy(Pelanggaran $pelanggaran)
{
$this->authorizeAccess($pelanggaran);
$pelanggaran->delete();
return redirect()->route('pelanggarans.index')->with('success', 'Data pelanggaran berhasil dihapus.');
}
protected function authorizeAccess(Pelanggaran $pelanggaran)
{
$user = Auth::user();
if ($user->role === 'guru' && $pelanggaran->user_id !== $user->id) {
abort(403, 'Unauthorized');
}
}
}