Welcome to the Airbnb Clone project! This project aims to replicate some of the core functionalities of Airbnb, allowing users to create listings, favorite listings, make reservations, and more. It also incorporates user authentication and third-party authentication features.
This project is built using the following technologies and dependencies:
- Next.js - A React framework for building server-rendered applications.
- NextAuth.js - For user authentication, including third-party authentication.
- Prisma - A modern database object relational mapping toolkit for TypeScript and Node.js.
- Redux Toolkit - For state management.
- Leaflet - An open-source JavaScript library for interactive maps.
- React Date Range - A date range picker for React.
- Tailwind CSS - A utility-first CSS framework.
- Cloudinary - For image and video management.
- Axios - A promise-based HTTP client for making API requests.
- React Hook Form - For form management.
- React Leaflet - React components for Leaflet maps.
- React Icons - A set of customizable SVG icons for React.
- And more (see
package.json
for a full list).
This Airbnb Clone project includes the following features:
- User authentication with email and password.
- Third-party authentication using providers like Google, Facebook, etc. (NextAuth.js).
- User profile management.
- Creating, editing, and deleting property listings.
- Searching for properties based on various filters.
- Favoriting properties.
- Making reservations for properties.
- Viewing and managing reservations as a host.
- Viewing trip history.
- Interactive maps for property locations.
To get started with this project, follow these steps:
-
Clone the repository to your local machine:
git clone https://github.com/iandcf/airbnb-clone.git
-
Install project dependencies:
cd airbnb-clone npm install
-
Set up environment variables:
- Create a
.env.local
file in the root directory. - Add environment variables like database connection strings, Cloudinary credentials, and authentication providers. Refer to
.env.example
for guidance.
- Create a
-
Set up your database using Prisma:
npx prisma migrate dev
-
Run the development server:
npm run dev
-
Open your browser and access the application at
http://localhost:3000
.
- Register a user account or sign in.
- Create property listings with details and images.
- Search and filter properties based on your preferences.
- Favorite properties to view them later.
- Make reservations for properties.
- As a host, manage reservations and view trip history.
Feel free to explore and test the application's features!
Contributions to this project are welcome! If you find any issues or want to add new features, please follow these steps:
- Fork the repository.
- Create a new branch for your changes.
- Make your changes and commit them.
- Push your changes to your fork.
- Create a pull request with a clear description of your changes.