import React, { useMemo } from 'react'; // --- Data Generation Logic (Keeps the component clean) --- const generateData = () => { const dates = ['20 June', '21 June', '22 June', '23 June', '24 June', '25 June']; return dates.map(date => { // Generate 1 to 10 messages per day (replicating Pug "Math.random() * 10") const msgCount = Math.floor(Math.random() * 10) + 1; const messages = Array.from({ length: msgCount }).map((_, i) => ({ id: `${date}-${i}`, // Random height between 50px and 250px height: Math.floor(Math.random() * 200) + 50 })); return { date, messages }; }); }; const TestMessages = () => { // Memoize data so it doesn't regenerate on re-renders const groups = useMemo(() => generateData(), []); return (
Scroll to see focus effect