This is the frontend component of the Racing Linear Algebra project. It is a web application built with React that provides the user interface for the game.
- Engaging and interactive racing gameplay.
- Real-time updates and synchronization with the server.
- Responsive user interface optimized for laptop screen sizes.
- Intuitive controls for easy gameplay.
- Multiple difficulty levels of questions to choose from.
- Support for answer input in multiple formats, including LaTeX.
- Track simulation with train/boat that moves based on the player's score.
- Ghost train simulation representing other teams for competitive gameplay.
- Checkpoint leaderboard that displays when a certain score threshold is reached.
- Final leaderboard at the end of each round to showcase the top teams.
- Statistics screen displaying the questions answered by players with accuracy metrics.
- React.js - JavaScript library for building user interfaces.
- CSS - Styling and layout of the user interface.
- WebSocket - Real-time communication with the backend server.
- React Testing Library: Testing utilities for testing React components.
- Jest: Testing framework for unit and integration testing.
- React Router: Library for handling routing in a React application.
- Axios: Promise-based HTTP client for making API requests.
To get started with the frontend of Racing Linear Algebra, follow these steps:
- Node.js (version 12 or higher)
- npm (Node Package Manager)
Follow these steps to get the game up and running on your local machine:
- Clone the repository
- Navigate to the project directory:
cd client
- Install the dependencies:
npm install
To start the game, run the following command: npm start
Runs the app in the development mode.
Open http://localhost:3000 to view it in the browser.
The page will reload if you make edits.
You will also see any lint errors in the console.
To run the tests, run the following command: npm run test
.
Press a
to run all tests.
To see test coverage, run the following command: npm run test:ci
You can learn more in the Create React App documentation.
To learn React, check out the React documentation.