Running on: https://rock-paper-scissors-d43zz6zsz-trimatech-projects.vercel.app/
- Set up React + TypeScript + Vite project
- Add Chakra UI
- Implement game core mechanics:
- Player balance system (starting 5000)
- Betting mechanism (500 increments, max 2 positions)
- Win/loss calculation:
- Single position win (14x return)
- Two positions win (3x return)
- Tie handling (return bet amount)
- Create UI components:
- Betting position buttons (Rock/Paper/Scissors)
- Blance / Bet amount / Win counter display
- Computer choice display VS best of player choice
- Game result screen with Winner and win amount
- Implement game flow:
- Bet placement phase
- Computer choice randomization
- Result comparison logic
- Balance update system
- Prevent invalid game states
- Add animation for computer choice
- Add animation for balance update
- [z] Fix layout shift if values changes in header
- Add animation for win
- Add unit tests
- Make it playable on mobile
- Check for rerenders
- Add Cypress tests
- Add sound effects
- Add background music
- Make it possible to add different value chips (premature refactoring?)
This template provides a minimal setup to get React working in Vite with HMR and some ESLint rules.
Currently, two official plugins are available:
- @vitejs/plugin-react uses Babel for Fast Refresh
- @vitejs/plugin-react-swc uses SWC for Fast Refresh
If you are developing a production application, we recommend updating the configuration to enable type aware lint rules:
- Configure the top-level
parserOptions
property like this:
export default tseslint.config({
languageOptions: {
// other options...
parserOptions: {
project: ['./tsconfig.node.json', './tsconfig.app.json'],
tsconfigRootDir: import.meta.dirname
}
}
});
- Replace
tseslint.configs.recommended
totseslint.configs.recommendedTypeChecked
ortseslint.configs.strictTypeChecked
- Optionally add
...tseslint.configs.stylisticTypeChecked
- Install eslint-plugin-react and update the config:
// eslint.config.js
import react from 'eslint-plugin-react';
export default tseslint.config({
// Set the react version
settings: { react: { version: '18.3' } },
plugins: {
// Add the react plugin
react
},
rules: {
// other rules...
// Enable its recommended rules
...react.configs.recommended.rules,
...react.configs['jsx-runtime'].rules
}
});