daftar kelas dan siswa fixed
This commit is contained in:
parent
4f29a9ed24
commit
be6db46930
|
|
@ -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'));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -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'));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Loading…
Reference in New Issue