57 lines
2.3 KiB
TypeScript
57 lines
2.3 KiB
TypeScript
'use client';
|
|
|
|
import { useState } from "react";
|
|
import StatistikMahasiswaChart from "@/components/charts/StatistikMahasiswaChart";
|
|
import StatistikPerAngkatanChart from "@/components/charts/StatistikPerAngkatanChart";
|
|
import JenisPendaftaranChart from "@/components/charts/JenisPendaftaranChart";
|
|
import AsalDaerahChart from "@/components/charts/AsalDaerahChart";
|
|
import IPKChart from "@/components/charts/IPKChart";
|
|
import FilterTahunAngkatan from "@/components/FilterTahunAngkatan";
|
|
import JenisPendaftaranPerAngkatanChart from "@/components/charts/JenisPendaftaranPerAngkatanChart";
|
|
import AsalDaerahPerAngkatanChart from "@/components/charts/AsalDaerahPerAngkatanChart";
|
|
import StatusMahasiswaChart from "@/components/charts/StatusMahasiswaChart";
|
|
import { Card, CardContent, CardHeader, CardTitle } from "@/components/ui/card";
|
|
|
|
export default function TotalMahasiswaPage() {
|
|
const [selectedYear, setSelectedYear] = useState<string>("all");
|
|
|
|
return (
|
|
<div className="container mx-auto p-4 space-y-6">
|
|
<h1 className="text-3xl font-bold mb-4">Mahasiswa</h1>
|
|
|
|
<div className="mb-4">
|
|
<p className="text-gray-600 dark:text-gray-300">
|
|
Informasi jumlah mahasiswa, jenis pendaftaran, status mahasiswa, rata-rata IPK, dan asal daerah dengan filter tahun angkatan.
|
|
</p>
|
|
</div>
|
|
|
|
<Card className="bg-white dark:bg-slate-900 shadow-lg dark:text-white">
|
|
<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}
|
|
/>
|
|
</div>
|
|
</CardContent>
|
|
</Card>
|
|
|
|
{selectedYear === "all" ? (
|
|
<div className="grid grid-cols-1 md:grid-cols-2 gap-4">
|
|
<StatistikMahasiswaChart />
|
|
<JenisPendaftaranChart />
|
|
<StatusMahasiswaChart />
|
|
<IPKChart />
|
|
<AsalDaerahChart />
|
|
</div>
|
|
) : (
|
|
<div className="grid grid-cols-1 md:grid-cols-2 gap-4">
|
|
<StatistikPerAngkatanChart tahunAngkatan={selectedYear} />
|
|
<JenisPendaftaranPerAngkatanChart tahunAngkatan={selectedYear} />
|
|
<AsalDaerahPerAngkatanChart tahunAngkatan={selectedYear} />
|
|
</div>
|
|
)}
|
|
</div>
|
|
);
|
|
}
|