Yet another attempt to a game with many names but the same goal
- Presents as a ReactJS application that will have an initial page to input players' names and a button to start the game
- Presents the game board UI with some simple, CSS/sass layout (X - red, O - blue)
- Stores current positions in the local state, making use of useState()
- Stores history of all games using global state useContext()
- Uses React Router to create navigation from game board to scoreboard and vice-versa
- Checks history when playing a new game. If the same players have played before, defines the previous winner as Player 1 (as convention X - should start the game) for the next round.
- Provides README.md file with the steps to run the app (present document).
Some combination of both research on theory of the game and general technical documentation lookup for setting up an environment was done or was ongoing during the development of this application
npm install
npm run start
npm run build
Create .env
file and define deploy path for an environment in case you deploy in server's subdirectory
DEPLOY=TRUE
NEXT_PUBLIC_INSTALL_PATH=/tictactoe
To enable remote play a server must be running. Refer to https://github.com/iljakumlander/tictactoe-remote for server code.
Modyfy .env
to set server configuration:
NEXT_PUBLIC_REMOTE=http://localhost:5000/
NEXT_PUBLIC_REMOTE_SECURE=TRUE
NEXT_PUBLIC_REMOTE_TRANSPORTS=websocket
Remote module upgraded and if remote server is available, game mode present.
Remote mode! Experimental multiplayer is on production testing stage
Game modes for 1 or 2 players
Artificial intelligence for single player game, style tweaks
Scoreboard and visal tweaking
Game input and styling tweaks, installation instructions
Prompting names, keeping scores and game logic set
Game components set, winning conditions installed, data persist configured
Development environment with deployable build set on Next 13 and React 18