Skip to content

Latest commit

 

History

History
127 lines (100 loc) · 5.75 KB

README.md

File metadata and controls

127 lines (100 loc) · 5.75 KB

CoupOnline

Index

Description

Screenshot3
CoupOnline is a web application version of the popular card game Coup. It has been developed using Vite React for the frontend, Express Node.js for the backend, and MongoDB for the database. Utilizes socket.io to facilitate communication between users and frontend. Uses cookies to remember user information.

Link to Deployment

Coup Online The backend spins down when not in use, and takes about a minute to spin up before login or create account button presses are processed.

Gameplay

CoupOnline follows the rules of the original card game Coup.

Rules

Features

  • Rooms: Players can enter a room code and connect with others.
  • Usernames: Players can select custom usernames when they enter the game.
  • Global Leaderboard Players can see a global statistics.
  • Player Accounts/Profiles Players can access their own records.
  • Gameplay Log Players can see logs of each users turn.

Technologies Used

  • Express Node.js
  • React Vite
  • MongoDB
  • Socket.IO

Additional Features (Future Implementations)

  • Publishing Games: After a game is completed, the results are published to the database.
  • Game Chat
  • Public Lobbies
  • Matchmaking
  • Custom Visuals: Including animations, card images, profile pictures, and room aesthetics.
  • Suspend/Resume Game: Ability to pause and resume ongoing games.
  • Stepwise Replay: Replay previous games step by step.
  • Ready Status: Indication of player readiness for the next phase or game.

Interface


ScreenshotLogin
Users will begin at the login page, where they can enter a registered username to login to their account. At this time, there is no password or verification system, accounts can be accessed by entering a valid username. Once logged in, a cookie will be saved into the browser session which will remember the logged in account.

ScreenshotCreation
If you do not have an account, you can click the "Create an Account" button to navigate to the account creation page. Please note that we do not utilize or require personal information, and recommend you do not use your real name or email address when creating an account. Emails must be in a valid email format (nut do not need to be a valid email) and usernames must be unique (duplicate usernames are not permitted).

ScreenshotJoin ScreenshotLobby
Once logged in to an account, the user is brought to the join room page. From here, the user can join a lobby by entering a lobby name in the text field. When the join room button is clicked, the user will be placed in either a new or existing lobby. Once in a lobby, the user can see all players currently in the lobby. Once two or more players are in a lobby, any player can start the game by clicking the "Start Game" button.

Screenshot3
Once a game begins, players will be brought to the main game screen. There are six elements on the UI screen.
  1. Player Cards Remaining: A list of all players in the game showing the number of cards they have remaining.
  2. Current Turn Info: a summary of actions taken during the current turn
  3. Discarded Cards: A list showing all cards discarded during the course of the game
  4. Recent Turn History: Complete history of past actions
  5. Player Info: The main section a player interacts with during their turn. It shows the number of coins a player has, the cards they are holding, and actions that can be taken at the current point in the game.
  6. References: Includes a table listing all cards and actions, and a set of complete game rules.


ScreenshotProfile ScreenshotProfile The hamburger menu from the top allows access to a user profile page and past game statistics page.

Installation on local machine

  1. Clone the repository:
git clone https://github.com/batec2/CoupOnline
  1. Navigate to the project frontend and install dependencies and start the frontend:
  • Create a .env file for the frontend with these entries
VITE_SERVER_URL="http://localhost:8080"
cd frontend
npm i
npm run dev
  1. Navigate to the project backend, install dependencies and start the backend:
cd backend
npm i
nodemon server.js
  1. Open your web browser and navigate to http://localhost:5173.