MIF_E31230892/sim-pkpps/resources/views/admin/kelas/kenaikan/index.blade.php

282 lines
13 KiB
PHP

@extends('layouts.app')
@section('title', 'Kenaikan Kelas Massal')
@section('content')
<div class="page-header" style="display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 10px;">
<div>
<h2><i class="fas fa-graduation-cap"></i> Kenaikan Kelas Massal</h2>
<p class="text-muted" style="margin: 0;">Kelola kenaikan kelas santri per tahun ajaran</p>
</div>
<a href="{{ route('admin.kelas.index') }}" class="btn btn-secondary">
<i class="fas fa-arrow-left"></i> Kembali ke Kelola Kelas
</a>
</div>
@if (session('success'))
<div class="alert alert-success alert-dismissible fade show" role="alert">
<i class="fas fa-check-circle"></i> {{ session('success') }}
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
@endif
@if (session('error'))
<div class="alert alert-danger alert-dismissible fade show" role="alert">
<i class="fas fa-exclamation-circle"></i> {{ session('error') }}
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
@endif
<!-- Info Card -->
<div class="content-box" style="margin-bottom: 14px;">
<div class="row-cards">
<div class="card card-info">
<h3>Tahun Ajaran Aktif</h3>
<div class="card-value">{{ $tahunAjaranAktif }}</div>
<p class="text-muted" style="margin: 0;">Tahun ajaran saat ini</p>
</div>
<div class="card card-success">
<h3>Total Santri Aktif</h3>
<div class="card-value">{{ $totalSantriAktif }}</div>
<p class="text-muted" style="margin: 0;">Santri dengan status aktif</p>
</div>
<div class="card card-warning">
<h3>Tahun Ajaran Baru</h3>
<div class="card-value" style="font-size: 1.8rem;">{{ $tahunAjaranBaru }}</div>
<p class="text-muted" style="margin: 0;">Target kenaikan kelas</p>
</div>
</div>
</div>
<!-- Filter by Kelompok -->
<div class="content-box" style="margin-bottom: 14px;">
<form method="GET" action="{{ route('admin.kelas.kenaikan.index') }}" style="display: flex; gap: 10px; flex-wrap: wrap; align-items: center;">
<label style="margin: 0; font-weight: 600; color: var(--primary-dark);">
<i class="fas fa-filter"></i> Pilih Kelompok Kelas:
</label>
<select name="kelompok" class="form-control" style="max-width: 300px;" onchange="this.form.submit()">
@foreach ($kelompokKelas as $kelompok)
<option value="{{ $kelompok->id_kelompok }}"
{{ $selectedKelompok == $kelompok->id_kelompok ? 'selected' : '' }}>
{{ $kelompok->nama_kelompok }}
</option>
@endforeach
</select>
</form>
</div>
@if ($kelasList->isNotEmpty())
@php
$currentKelompok = $kelompokKelas->where('id_kelompok', $selectedKelompok)->first();
@endphp
<div class="content-box" style="margin-bottom: 25px;">
<div style="background: linear-gradient(135deg, #E8F7F2 0%, #D4F1E3 100%); padding: 14px; border-radius: 8px; margin-bottom: 14px;">
<h3 style="margin: 0 0 8px 0; color: var(--primary-dark);">
<i class="fas fa-layer-group"></i>
{{ $currentKelompok->nama_kelompok ?? 'Kelas' }}
</h3>
<p style="margin: 0; color: var(--text-light); font-size: 0.95rem;">
{{ $currentKelompok->deskripsi ?? 'Kelola kenaikan kelas untuk kelompok ini' }}
</p>
</div>
<div class="table-wrapper">
<table class="data-table">
<thead>
<tr>
<th style="width: 50px;">No</th>
<th>Kelas Asal</th>
<th style="width: 140px; text-align: center;">Santri Aktif</th>
<th style="width: 280px;">Naik ke Kelas</th>
<th style="width: 200px; text-align: center;">Aksi</th>
</tr>
</thead>
<tbody>
@foreach ($kelasList as $kelas)
<tr>
<td>{{ $loop->iteration }}</td>
<td>
<strong style="color: var(--primary-dark);">{{ $kelas->nama_kelas }}</strong>
<br>
<span class="text-muted" style="font-size: 0.85rem;">
<i class="fas fa-tag"></i> {{ $kelas->kode_kelas }}
</span>
</td>
<td style="text-align: center;">
@if($kelas->santri_aktif_count > 0)
<span class="badge badge-info" style="font-size: 0.95rem; padding: 8px 14px;">
<i class="fas fa-users"></i> {{ $kelas->santri_aktif_count }} santri
</span>
@else
<span class="badge badge-secondary" style="font-size: 0.9rem; padding: 7px 12px;">
<i class="fas fa-user-slash"></i> 0 santri
</span>
@endif
</td>
<td>
@if($kelas->santri_aktif_count > 0)
<select class="form-control form-control-sm target-kelas-select"
data-kelas-id="{{ $kelas->id }}"
style="font-size: 0.9rem;">
<option value="">-- Pilih Kelas Tujuan --</option>
@foreach ($allKelasList as $targetKelas)
@if ($targetKelas->id != $kelas->id)
<option value="{{ $targetKelas->id }}">
{{ $targetKelas->kelompok->nama_kelompok }} - {{ $targetKelas->nama_kelas }}
</option>
@endif
@endforeach
</select>
@else
<span class="text-muted" style="font-size:0.85rem;"></span>
@endif
</td>
<td style="text-align: center;">
@if ($kelas->santri_aktif_count > 0)
<div style="display: flex; gap: 5px; justify-content: center;">
<button type="button"
class="btn btn-sm btn-success btn-naikkan"
data-kelas-id="{{ $kelas->id }}"
data-kelas-nama="{{ $kelas->nama_kelas }}"
data-santri-count="{{ $kelas->santri_aktif_count }}"
disabled
title="Pilih kelas tujuan terlebih dahulu">
<i class="fas fa-arrow-up"></i> Naikkan
</button>
<a href="{{ route('admin.kelas.kenaikan.preview', $kelas->id) }}"
class="btn btn-sm btn-info"
title="Lihat & Pilih Santri">
<i class="fas fa-eye"></i> Lihat
</a>
</div>
@else
<span class="badge badge-secondary">
<i class="fas fa-user-slash"></i> Tidak ada santri
</span>
@endif
</td>
</tr>
@endforeach
</tbody>
</table>
</div>
</div>
@else
<div class="content-box">
<div class="text-center py-5">
<i class="fas fa-graduation-cap fa-3x text-muted mb-3"></i>
<h5 class="text-muted">Tidak ada kelas ditemukan</h5>
<p class="text-muted">Belum ada kelas aktif di kelompok yang dipilih.</p>
</div>
</div>
@endif
<div class="alert alert-info" style="border-left: 4px solid var(--info-color); background: #E3F7FC;">
<div style="display: flex; gap: 11px;">
<div style="font-size: 2rem; color: var(--info-color);"><i class="fas fa-info-circle"></i></div>
<div>
<strong style="color: var(--primary-dark); font-size: 1.1rem;">Cara Menggunakan Kenaikan Kelas:</strong>
<ol style="margin: 10px 0 0 0; padding-left: 20px; color: var(--text-color);">
<li style="margin-bottom: 8px;"><strong>Pilih Kelompok Kelas</strong> dari dropdown untuk menampilkan daftar kelas</li>
<li style="margin-bottom: 8px;"><strong>Pilih Kelas Tujuan</strong> di kolom dropdown tiap baris</li>
<li style="margin-bottom: 8px;">Klik <span class="badge badge-success"><i class="fas fa-arrow-up"></i> Naikkan</span> untuk memproses semua santri di kelas tersebut</li>
<li style="margin-bottom: 8px;">Atau klik <span class="badge badge-info"><i class="fas fa-eye"></i> Lihat</span> untuk memilih santri secara individual</li>
<li style="margin-bottom: 8px;">Santri akan dipindahkan ke <strong>Tahun Ajaran {{ $tahunAjaranBaru }}</strong></li>
</ol>
</div>
</div>
</div>
@endsection
@section('scripts')
<script>
document.addEventListener('DOMContentLoaded', function () {
// ── Enable/disable tombol Naikkan berdasarkan pilihan dropdown ──
document.querySelectorAll('.target-kelas-select').forEach(function (select) {
var kelasId = select.dataset.kelasId;
var button = document.querySelector('.btn-naikkan[data-kelas-id="' + kelasId + '"]');
if (!button) return;
select.addEventListener('change', function () {
if (this.value) {
button.disabled = false;
button.title = 'Klik untuk menaikkan kelas semua santri';
} else {
button.disabled = true;
button.title = 'Pilih kelas tujuan terlebih dahulu';
}
});
});
// ── Handle klik tombol Naikkan ──
document.querySelectorAll('.btn-naikkan').forEach(function (button) {
button.addEventListener('click', function (e) {
e.preventDefault();
var kelasId = this.dataset.kelasId;
var kelasNama = this.dataset.kelasNama;
var santriCount = this.dataset.santriCount;
var select = document.querySelector('.target-kelas-select[data-kelas-id="' + kelasId + '"]');
if (!select || !select.value) {
if (select) {
select.focus();
select.style.border = '2px solid #FF8B94';
setTimeout(function () { select.style.border = ''; }, 2000);
}
alert('Silakan pilih kelas tujuan terlebih dahulu!');
return;
}
var targetKelasText = select.options[select.selectedIndex].text;
var tahunAjaranBaru = '{{ $tahunAjaranBaru }}';
var confirmMessage =
'KONFIRMASI KENAIKAN KELAS\n\n' +
'Kelas Asal : ' + kelasNama + '\n' +
'Kelas Tujuan : ' + targetKelasText + '\n' +
'Jumlah Santri: ' + santriCount + ' orang\n' +
'Tahun Ajaran : ' + tahunAjaranBaru + '\n\n' +
'Proses ini akan memindahkan SEMUA santri aktif ke kelas dan tahun ajaran baru.\n' +
'Lanjutkan?';
if (!confirm(confirmMessage)) return;
// Disable tombol agar tidak double-submit
this.disabled = true;
this.innerHTML = '<i class="fas fa-spinner fa-spin"></i> Memproses...';
// Buat form dan submit
var form = document.createElement('form');
form.method = 'POST';
form.action = '{{ route("admin.kelas.kenaikan.process") }}';
[
{ name: '_token', value: '{{ csrf_token() }}' },
{ name: 'id_kelas_asal', value: kelasId },
{ name: 'id_kelas_tujuan', value: select.value },
].forEach(function (item) {
var input = document.createElement('input');
input.type = 'hidden';
input.name = item.name;
input.value = item.value;
form.appendChild(input);
});
document.body.appendChild(form);
form.submit();
});
});
});
</script>
@endsection