Files
portaldata/app/mahasiswa/berprestasi/page.tsx
Randa Firman Putra e028039ee2 First commit
2025-06-18 22:03:32 +07:00

80 lines
3.4 KiB
TypeScript

'use client';
import { useState } from "react";
import FilterTahunAngkatan from "@/components/FilterTahunAngkatan";
import FilterJenisPrestasi from "@/components/FilterJenisPrestasi";
import { Card, CardContent, CardHeader, CardTitle } from "@/components/ui/card";
import TotalPrestasiChart from "@/components/TotalPrestasiChart";
import TotalPrestasiPieChart from "@/components/TotalPrestasiPieChart";
import TingkatPrestasiChart from "@/components/TingkatPrestasiChart";
import TingkatPrestasiPieChart from "@/components/TingkatPrestasiPieChart";
import JenisPendaftaranPrestasiChart from "@/components/JenisPendaftaranPrestasiChart";
import JenisPendaftaranPrestasiPieChart from "@/components/JenisPendaftaranPrestasiPieChart";
import AsalDaerahPrestasiChart from "@/components/AsalDaerahPrestasiChart";
import IPKPrestasiChart from "@/components/IPKPrestasiChart";
export default function BerprestasiMahasiswaPage() {
const [selectedYear, setSelectedYear] = useState<string>("all");
const [selectedJenisPrestasi, setSelectedJenisPrestasi] = useState<string>("Akademik");
return (
<div className="container mx-auto p-4 space-y-6">
<h1 className="text-3xl font-bold mb-4">Mahasiswa Berprestasi</h1>
<div className="mb-4">
<p className="text-gray-600 dark:text-gray-300">
Mahasiswa yang mendapatkan prestasi akademik dan non akademik di program studi Informatika Fakultas Teknik Universitas Tanjungpura.
</p>
</div>
<Card className="bg-white dark:bg-slate-900 shadow-lg dark:text-white">
<CardHeader className="flex flex-row items-center justify-between space-y-0 pb-2">
<CardTitle className="text-sm font-medium dark:text-white">
Filter Data
</CardTitle>
</CardHeader>
<CardContent>
<div className="flex flex-col sm:flex-row items-start sm:items-center gap-4 sm:space-x-4">
<FilterTahunAngkatan
selectedYear={selectedYear}
onYearChange={setSelectedYear}
/>
<FilterJenisPrestasi
selectedJenisPrestasi={selectedJenisPrestasi}
onJenisPrestasiChange={setSelectedJenisPrestasi}
/>
</div>
</CardContent>
</Card>
{selectedYear === "all" ? (
<>
<TotalPrestasiChart selectedJenisPrestasi={selectedJenisPrestasi} />
<TingkatPrestasiChart selectedJenisPrestasi={selectedJenisPrestasi} />
<JenisPendaftaranPrestasiChart selectedJenisPrestasi={selectedJenisPrestasi} />
</>
) : (
<>
<TotalPrestasiPieChart
selectedYear={selectedYear}
selectedJenisPrestasi={selectedJenisPrestasi}
/>
<TingkatPrestasiPieChart
selectedYear={selectedYear}
selectedJenisPrestasi={selectedJenisPrestasi}
/>
<JenisPendaftaranPrestasiPieChart
selectedYear={selectedYear}
selectedJenisPrestasi={selectedJenisPrestasi}
/>
</>
)}
<AsalDaerahPrestasiChart selectedYear={selectedYear} selectedJenisPrestasi={selectedJenisPrestasi} />
{selectedYear === "all" && (
<IPKPrestasiChart selectedJenisPrestasi={selectedJenisPrestasi} />
)}
</div>
);
}