'use client' import { useState, useEffect } from 'react'; import { FilamentTable } from '../src/components/FilamentTable'; import { Filament } from '../src/types/filament'; import axios from 'axios'; export default function Home() { const [filaments, setFilaments] = useState([]); const [loading, setLoading] = useState(true); const [error, setError] = useState(null); const [lastUpdate, setLastUpdate] = useState(null); const [darkMode, setDarkMode] = useState(false); const [mounted, setMounted] = useState(false); // Initialize dark mode from localStorage after mounting useEffect(() => { setMounted(true); const saved = localStorage.getItem('darkMode'); if (saved) { setDarkMode(JSON.parse(saved)); } }, []); // Update dark mode useEffect(() => { if (!mounted) return; localStorage.setItem('darkMode', JSON.stringify(darkMode)); if (darkMode) { document.documentElement.classList.add('dark'); } else { document.documentElement.classList.remove('dark'); } }, [darkMode, mounted]); const fetchFilaments = async () => { try { setLoading(true); setError(null); // Use API if available, fallback to static JSON const apiUrl = process.env.NEXT_PUBLIC_API_URL; const url = apiUrl ? `${apiUrl}/filaments` : '/data.json'; console.log('Fetching from:', url); console.log('API URL configured:', apiUrl); const response = await axios.get(url); console.log('Response data:', response.data); setFilaments(response.data); setLastUpdate(new Date()); } catch (err) { setError(err instanceof Error ? err.message : 'Greška pri učitavanju filamenata'); } finally { setLoading(false); } }; useEffect(() => { fetchFilaments(); // Refresh every 5 minutes const interval = setInterval(fetchFilaments, 5 * 60 * 1000); return () => clearInterval(interval); }, []); return (

Filamenteka

{lastUpdate && ( Poslednje ažuriranje: {lastUpdate.toLocaleTimeString('sr-RS')} )} {mounted && ( )}
); }