This project was bootstrapped with Create React App.
A react app that simulates Swvl's ride tracking, live demo here.
- π Draw a route with predefined stations using google maps direction service.
- π Display bus/ drive and trip info.
- π‘ Display real Eta for each station from google maps directions api.
- πΊ The bus mimics the real movement on the map.
- π¨π»βπ» Add booking with pre-filled input form with validation on each input.
- β¨ Ability to fill all 12 seats on the bus with just one click.
- βοΈ Ability to control the time of the simulation.
- ππ» Real time update on bus passengers status upon arrival on every station.
- π΅π»ββοΈ Reloading the browser doesn't affect the ride.
- π€ Ability to reset and start all over again with new passengers.
- π After the ride is completed some stats are shown.
- π¨ App is fully responsive.
- Create React app for scaffolding the app.
- Context API for state management.
- CSS modules for styles and reduce CSS critical path.
- React Google Maps.
- Formik for form validation.
- RequestAnimationFrame for bus animation and maximizing the performance.
- React Chart.js for displaying stats.
- React testing library for UI testing and snapshots.
- Built a simple accessible modal.
- Built a simple caching layer for the app.
- The app uses pre-commit hooks to fix linting issues and optimize image sizes
This app is deployed using Netlify on https://hassan-swvl-challenge.netlify.app/
-
Clone the repo
$ git clone https://github.com/hassanhafezzz/swvl-challange
-
Install dependencies
$ yarn install
-
Add your google API key to the env please check
.env
file to see how. -
Start the server
$ yarn start
In the project directory, you can run:
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.
Launches the test runner in the interactive watch mode.
Builds the app for production to the build
folder.