A simple flight search application built with React.js. This project is a clone of Google Flights, developed as part of a job assessment with a strict one-day deadline. The challenge was to implement as much functionality as possible within the given time constraint.
You can try out the live demo of this project here: Live Demo Link
- Responsive Design: Optimized for both desktop and mobile devices.
- APIs:
- Current Location Based on IP: Fetches the user's current location using ipapi.co.
- Flight Data: Uses the Sky Scrapper API to get flight data for the current location.
- React.js: Built using React for a fast and interactive UI.
- Material UI: Utilized for styling and pre-built components.
- X-Date-Pickers: Utilized for date picker of departure and return.
- Axios: For handling API requests and fetching flight data.
- Context API: Managed state for search parameters.
- React Router: Handled page navigation and routing.
reactjs-google-flights-app/
├── public/ # Static assets and index.html
├── src/ # Main source code
│ ├── assets/ # Images, icons, and static assets
│ ├── components/ # Reusable UI components
│ ├── contexts/ # React context providers
│ ├── hooks/ # Custom hooks for data fetching and utilities
│ ├── pages/ # Page components
│ ├── theme/ # Theme-related configurations
│ ├── App.jsx # Root component
│ ├── main.jsx # Entry point
│ ├── index.css # Global styles
├── README.md # Project documentation
├── LICENSE # License information
├── package.json # Project dependencies and scripts
├── vite.config.js # Vite configuration
└── eslint.config.js # ESLint configuration
To get started with the project locally using Create React App, follow these steps:
- Clone the repository:
git clone https://github.com/EthanEDev/reactjs-google-flights-app.git
- Navigate to the project directory:
cd reactjs-google-flights-app
- Install dependencies:
npm install
- Start the development server:
npm start
If the project uses Vite instead of Create React App, follow these steps:
- Clone the repository:
git clone https://github.com/EthanEDev/reactjs-google-flights-app.git
- Navigate to the project directory:
cd reactjs-google-flights-app
- Install dependencies:
npm install
- Start the development server:
npm run dev
Contributions are welcome! If you have suggestions for improvements or find any issues, feel free to open an issue or submit a pull request.
- Fork the repository.
- Create a new branch:
git checkout -b feature-branch
- Commit your changes:
git commit -am 'Add new feature'
- Push to the branch:
git push origin feature-branch
- Create a new Pull Request.
This project is licensed under the MIT License - see the LICENSE file for details.
If you have any questions, feel free to reach out via GitHub issues or at ethan.ekhtiyar@gmail.com.