import { useState, useEffect } from 'react';
export default function DemoSelector({ onDemoSelect, currentDemo }) {
const [demos, setDemos] = useState([]);
const [categories, setCategories] = useState([]);
const [loading, setLoading] = useState(true);
const [selectedCategory, setSelectedCategory] = useState('all');
useEffect(() => {
fetch('/demos.json')
.then(res => res.json())
.then(data => {
setDemos(data.demos);
setCategories(data.categories);
setLoading(false);
})
.catch(err => {
console.error('Failed to load demos:', err);
setLoading(false);
});
}, []);
const filteredDemos = selectedCategory === 'all'
? demos
: demos.filter(demo => demo.category === selectedCategory);
if (loading) {
return (
);
}
return (
Choose a Demo
{/* Category Filter */}
{categories.map(category => (
))}
{/* Demo Grid */}
{filteredDemos.map(demo => (
onDemoSelect(demo)}
>

{
e.target.src = '';
}}
/>
{demo.name}
{demo.description}
⏱️ {demo.estimatedTime}
📋 {demo.steps} steps
))}
{filteredDemos.length === 0 && (
No demos found in this category
)}
);
}