diff --git a/src/ui/src/Apps/Casino/index.tsx b/src/ui/src/Apps/Casino/index.tsx index 1b3aa28d2..569036fae 100644 --- a/src/ui/src/Apps/Casino/index.tsx +++ b/src/ui/src/Apps/Casino/index.tsx @@ -1,15 +1,72 @@ -import { useEffect } from 'react'; +import { useEffect, useState } from 'react'; import { TopNavigation } from '../../components/Navigation/TopNavigation'; +/** + * Add jackpot icon, and bar to the symbols array + */ +const symbols = ['🍒', '🍋', '🍊', '🍉', '🍇', '⭐', '🔔', '🎰', '🍀']; + +const getRandomSymbol = () => symbols[Math.floor(Math.random() * symbols.length)]; + +const useInterval = (callback: () => void, delay: number) => { + useEffect(() => { + const id = setInterval(callback, delay); + return () => clearInterval(id); + }, [callback, delay]); +}; + export const CasinoApp = () => { + const [reels, setReels] = useState([getRandomSymbol(), getRandomSymbol(), getRandomSymbol()]); + const [spinning, setSpinning] = useState(false); + const [winner, setWinner] = useState(false); + useEffect(() => { document.title = 'Casino'; }, []); + const spinReels = () => { + setSpinning(true); + setWinner(false); + setTimeout(() => { + const newReels = [getRandomSymbol(), getRandomSymbol(), getRandomSymbol()]; + setReels(newReels); + setSpinning(false); + checkWinner(newReels); + }, 1000); + }; + + useInterval(() => { + if (spinning) { + setReels([getRandomSymbol(), getRandomSymbol(), getRandomSymbol()]); + } + }, 100); + + const checkWinner = (reels: string[]) => { + if (reels[0] === reels[1] && reels[1] === reels[2]) { + setWinner(true); + } + }; + return (
- hello I am casino app +
+
+ {reels.map((symbol, index) => ( +
+ {symbol} +
+ ))} +
+ + {winner &&
You Win!
} +
); }; diff --git a/src/ui/src/index.css b/src/ui/src/index.css index 0f2afca4a..531f39ea1 100644 --- a/src/ui/src/index.css +++ b/src/ui/src/index.css @@ -2,6 +2,28 @@ @tailwind components; @tailwind utilities; +@keyframes spinAnimation { + 0% { + transform: translateY(0); + } + 25% { + transform: rotate(45deg); + } + 50% { + transform: translateY(0); + } + 75% { + transform: rotate(-45deg); + } + 100% { + transform: translateY(0); + } +} + +.spin { + animation: spinAnimation 1s ease-in-out; +} + #root { --geist-foreground: #ffffff; --geist-background: #000000;