Files
shakethefrog/app/components/ParentComponent.tsx
HugeFrog24 52ddcd3db9 bugfix
2025-01-15 03:40:11 +01:00

25 lines
756 B
TypeScript

import { useState, useEffect } from 'react';
import { SpeechBubble } from './SpeechBubble';
import FrogImage from '../public/images/frog-ai.ai'; // Assuming this is the frog image
export function ParentComponent() {
const [isShaken, setIsShaken] = useState(false);
const [triggerCount, setTriggerCount] = useState(0);
const handleShake = () => {
setTriggerCount(prev => prev + 1);
setIsShaken(true);
// Shake the frog for 1 second
setTimeout(() => {
setIsShaken(false);
}, 1000);
};
return (
<div>
<FrogImage className={isShaken ? 'shake-animation' : ''} />
<SpeechBubble isShaken={isShaken} triggerCount={triggerCount} />
<button onClick={handleShake}>Shake the Frog</button>
</div>
);
}