"use client"; import { useEffect, useState } from "react"; import axios from "axios"; import { Zap, Check, X, Info, Activity } from "lucide-react"; export default function AdminDashboard() { const [pendingBookings, setPendingBookings] = useState([]); const [roomStats, setRoomStats] = useState([]); const [loading, setLoading] = useState(true); // STATE BARU: Khusus menyimpan TOTAL DAYA D101 const [d101TotalPower, setD101TotalPower] = useState(0); useEffect(() => { fetchAdminData(); fetchD101Power(); // Panggil fungsi daya saat pertama kali render // Refresh data admin (ruangan & booking) setiap 10 detik const intervalAdmin = setInterval(fetchAdminData, 10000); // Refresh data konsumsi daya D101 setiap 3 detik (mengikuti halaman monitoring) const intervalPower = setInterval(fetchD101Power, 3000); return () => { clearInterval(intervalAdmin); clearInterval(intervalPower); }; }, []); // ========================================================================= // FUNGSI BARU: Tarik Data Daya (Power / Watt) KHUSUS D101 // ========================================================================= const fetchD101Power = async () => { try { const response = await fetch("http://172.17.172.17:8080/api/hardware/power-status"); if (response.ok) { const data = await response.json(); // Kalkulasi total watt const umum = parseFloat(data.umum) || 0; const ac1 = parseFloat(data.ac1) || 0; const ac2 = parseFloat(data.ac2) || 0; const totalD101 = umum + ac1 + ac2; setD101TotalPower(totalD101); } } catch (err) { console.error("Gagal mengambil data daya D101:", err); } }; const fetchAdminData = async () => { try { const token = localStorage.getItem("token"); // 1. Ambil SEMUA booking pakai endpoint yang sudah ada, lalu filter di Frontend const bookRes = await axios.get("http://172.17.172.17:8080/api/bookings", { headers: { Authorization: `Bearer ${token}` } }); const allBookings = bookRes.data.data || []; // Saring hanya yang statusnya "Pending" atau kosong const pendingOnly = allBookings.filter((b: any) => b.status === "Pending" || !b.status); setPendingBookings(pendingOnly); // 2. Ambil daftar ruangan biasa, lalu kita sisipkan "Dummy Power" untuk UI const roomRes = await axios.get("http://172.17.172.17:8080/api/rooms", { headers: { Authorization: `Bearer ${token}` } }); const roomsWithDummyPower = (roomRes.data.data || []).map((room: any) => ({ ...room, // Simulasi daya acak antara 0 sampai 15 Watt (D101 akan di-override di bagian render) power_consumption: Math.floor(Math.random() * 15) })); setRoomStats(roomsWithDummyPower); } catch (err) { console.error("Gagal ambil data admin", err); } finally { setLoading(false); } }; const handleAction = async (id: string, status: string) => { try { const token = localStorage.getItem("token"); // Mengirim status 'Approved' atau 'Rejected' ke backend await axios.put(`http://172.17.172.17:8080/api/bookings/${id}/status`, { status: status }, { headers: { Authorization: `Bearer ${token}` } } ); alert(`Permintaan berhasil di-${status}`); fetchAdminData(); // Refresh data setelah aksi } catch (err: any) { console.error(err); alert("Gagal memproses pendaftaran."); } }; if (loading) return
Memasuki Mode Admin...
; return (
{/* SECTION 1: POWER MONITORING CARDS */}

Real-time Room Energy

{[...roomStats] .sort((a, b) => a.name.localeCompare(b.name)) .map((room) => { // LOGIKA INJEKSI: Timpa nilai dummy dengan daya asli jika ini Kelas D101 const isD101 = room.name === "Kelas D101"; const displayedPower = isD101 ? d101TotalPower : room.power_consumption; const isPowerActive = displayedPower > 0; return (
{room.name} {isD101 && REAL SENSOR}
{displayedPower.toFixed(1)} Watts

{isD101 ? "Live auto-update via IoT" : "Last updated: Just now"}

); })}
{/* SECTION 2: APPROVAL TABLE */}

Pending Approvals

{pendingBookings.length} Requests
{pendingBookings.map((b) => ( ))} {pendingBookings.length === 0 && ( )}
Peminjam Ruangan Tanggal & Waktu Keperluan Tindakan
{b.user?.full_name || "Tanpa Nama"} {b.room?.name || "Ruangan Tidak Diketahui"}
{new Date(b.start_time).toLocaleTimeString('id-ID', {hour: '2-digit', minute:'2-digit'})} - {new Date(b.end_time).toLocaleTimeString('id-ID', {hour: '2-digit', minute:'2-digit'})}
{new Date(b.start_time).toLocaleDateString('id-ID')}
{b.purpose}
Tidak ada permintaan menunggu.
); }