daftar kelas dan siswa fixed

This commit is contained in:
RetasyaSalsabila 2026-04-08 12:04:57 +07:00
parent 4f29a9ed24
commit be6db46930
2 changed files with 48 additions and 20 deletions

View File

@ -4,26 +4,38 @@
use App\Http\Controllers\Controller; use App\Http\Controllers\Controller;
use App\Models\Kelas; use App\Models\Kelas;
use App\Models\Mengajar;
use Illuminate\Http\Request; use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
class KelasController extends Controller class KelasController extends Controller
{ {
public function index(Request $request) public function index(Request $request)
{ {
$query = Kelas::query(); $guru = Auth::guard('guru')->user();
// Ambil hanya id_kelas yang diajar guru ini
$kelasIds = Mengajar::where('id_guru', $guru->id_guru)
->pluck('id_kelas')
->unique();
$query = Kelas::whereIn('id_kelas', $kelasIds);
// SEARCH // SEARCH
if ($request->has('search')) { if ($request->filled('search')) {
$search = $request->search; $search = $request->search;
$query->where('nama_kelas', 'like', "%$search%") $query->where(function ($q) use ($search) {
->orWhere('id_kelas', 'like', "%$search%"); $q->where('nama_kelas', 'like', "%$search%")
->orWhere('tingkat', 'like', "%$search%");
});
} }
// SHOW PER PAGE
$perPage = $request->get('perPage', 10); $perPage = $request->get('perPage', 10);
$kelass = $query->orderBy('tingkat')
$kelass = $query->paginate($perPage)->appends($request->all()); ->orderBy('nama_kelas')
->paginate($perPage)
->appends($request->all());
return view('guru.kelas.index', compact('kelass')); return view('guru.kelas.index', compact('kelass'));
} }
} }

View File

@ -5,34 +5,50 @@
use App\Http\Controllers\Controller; use App\Http\Controllers\Controller;
use App\Models\Siswa; use App\Models\Siswa;
use App\Models\Kelas; use App\Models\Kelas;
use App\Models\Mengajar;
use Illuminate\Http\Request; use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
class SiswaController extends Controller class SiswaController extends Controller
{ {
public function index(Request $request) public function index(Request $request)
{ {
$query = Siswa::with('kelas'); $guru = Auth::guard('guru')->user();
// Ambil hanya id_kelas yang diajar guru ini
$kelasIds = Mengajar::where('id_guru', $guru->id_guru)
->pluck('id_kelas')
->unique();
$query = Siswa::with('kelas')
->whereIn('id_kelas', $kelasIds);
// SEARCH // SEARCH
if ($request->has('search')) { if ($request->filled('search')) {
$search = $request->search; $search = $request->search;
$query->where('nama', 'like', "%$search%") $query->where(function ($q) use ($search) {
$q->where('nama', 'like', "%$search%")
->orWhere('nisn', 'like', "%$search%"); ->orWhere('nisn', 'like', "%$search%");
});
} }
// FILTER BY KELAS // FILTER BY KELAS (hanya kelas yang diajar guru ini)
if ($request->has('filter_kelas') && $request->filter_kelas != '') { if ($request->filled('filter_kelas')) {
$query->where('id_kelas', $request->filter_kelas); // Pastikan filter kelas yang dipilih memang kelas yang diajar guru ini
if ($kelasIds->contains($request->filter_kelas)) {
$query->where('id_kelas', $request->filter_kelas);
}
} }
// SHOW PER PAGE
$perPage = $request->get('perPage', 10); $perPage = $request->get('perPage', 10);
$siswas = $query->paginate($perPage)->appends($request->all());
$siswas = $query->paginate($perPage)->appends($request->all()); // Dropdown filter hanya tampilkan kelas yang diajar guru ini
$kelass = Kelas::whereIn('id_kelas', $kelasIds)
// Ambil semua kelas untuk dropdown filter ->orderBy('tingkat')
$kelass = Kelas::orderBy('tingkat')->orderBy('nama_kelas')->get(); ->orderBy('nama_kelas')
->get();
return view('guru.siswa.index', compact('siswas', 'kelass')); return view('guru.siswa.index', compact('siswas', 'kelass'));
} }
} }