testing yuk
This commit is contained in:
@@ -7,9 +7,9 @@ export async function GET(request: Request) {
|
||||
const tahunAngkatan = searchParams.get('tahunAngkatan');
|
||||
const jenisPrestasi = searchParams.get('jenisPrestasi');
|
||||
|
||||
// Validate jenisPrestasi parameter (allow null)
|
||||
// Validasi parameter jenisPrestasi (izinkan null)
|
||||
if (jenisPrestasi && jenisPrestasi !== 'null' && jenisPrestasi !== 'undefined') {
|
||||
// Validate against valid enum values only if jenisPrestasi is provided
|
||||
// Validasi terhadap nilai enum yang valid hanya jika jenisPrestasi diberikan
|
||||
const validJenisPrestasi = ['Akademik', 'Non-Akademik'];
|
||||
if (!validJenisPrestasi.includes(jenisPrestasi)) {
|
||||
return NextResponse.json(
|
||||
@@ -19,7 +19,7 @@ export async function GET(request: Request) {
|
||||
}
|
||||
}
|
||||
|
||||
// Build query based on parameters
|
||||
// Bangun query berdasarkan parameter
|
||||
let query = supabase
|
||||
.from('mahasiswa')
|
||||
.select(`
|
||||
@@ -30,12 +30,12 @@ export async function GET(request: Request) {
|
||||
)
|
||||
`);
|
||||
|
||||
// Add tahun angkatan filter if provided
|
||||
// Tambahkan filter tahun angkatan jika diberikan
|
||||
if (tahunAngkatan && tahunAngkatan !== 'null' && tahunAngkatan !== 'undefined') {
|
||||
query = query.eq('tahun_angkatan', parseInt(tahunAngkatan));
|
||||
}
|
||||
|
||||
// Add jenis prestasi filter if provided
|
||||
// Tambahkan filter jenis prestasi jika diberikan
|
||||
if (jenisPrestasi && jenisPrestasi !== 'null' && jenisPrestasi !== 'undefined') {
|
||||
query = query.eq('prestasi_mahasiswa.jenis_prestasi', jenisPrestasi);
|
||||
}
|
||||
@@ -50,18 +50,18 @@ export async function GET(request: Request) {
|
||||
);
|
||||
}
|
||||
|
||||
// Group and count the data in JavaScript
|
||||
// Kelompokkan dan hitung data di JavaScript
|
||||
const groupedData = data.reduce((acc: any[], row: any) => {
|
||||
const tahunAngkatan = row.tahun_angkatan;
|
||||
|
||||
// Handle array of prestasi_mahasiswa
|
||||
// Tangani array prestasi_mahasiswa
|
||||
const prestasiArray = Array.isArray(row.prestasi_mahasiswa) ? row.prestasi_mahasiswa : [row.prestasi_mahasiswa];
|
||||
|
||||
if (!tahunAngkatan) {
|
||||
return acc;
|
||||
}
|
||||
|
||||
// Process each prestasi in the array
|
||||
// Proses setiap prestasi dalam array
|
||||
prestasiArray.forEach((prestasi: any) => {
|
||||
if (!prestasi || !prestasi.tingkat_prestasi) {
|
||||
return;
|
||||
@@ -90,7 +90,7 @@ export async function GET(request: Request) {
|
||||
return acc;
|
||||
}, []);
|
||||
|
||||
// Sort the results
|
||||
// Urutkan hasil
|
||||
const sortedData = groupedData.sort((a: any, b: any) => {
|
||||
if (a.tahun_angkatan !== b.tahun_angkatan) {
|
||||
return b.tahun_angkatan - a.tahun_angkatan;
|
||||
|
||||
Reference in New Issue
Block a user