Welcome to the easebnb! This repository houses a web application inspired by Airbnb, built with a modern tech stack to demonstrate a high level of proficiency in full-stack development. This project combines the power of React (with TypeScript), Tailwind CSS (with Shadcn UI), Django (with Django REST Framework), and PostgreSQL.
Easebnb aims to replicate the core functionalities of the popular accommodation rental platform, Airbnb. The project serves as a comprehensive example of a full-stack application, showcasing the integration of a front-end built with React and TypeScript and a back-end developed with Django REST Framework, all powered by a robust PostgreSQL database.
Easebnb comes packed with a variety of features to provide a seamless user experience:
- User Authentication: Secure login and registration system, including authentication with Google accounts via Kinde.
- Property Listings: Users can list, browse, search, and view property listings.
- Booking System: Users can book properties, specifying dates and number of guests.
- Responsive Design: A fully responsive design ensuring compatibility across various devices.
This project leverages a modern tech stack to deliver a robust and efficient application:
-
Frontend:
- React: A powerful JavaScript library for building user interfaces.
- TypeScript: A statically typed superset of JavaScript to enhance code quality and maintainability.
- Tailwind CSS: A utility-first CSS framework for rapid UI development.
- Shadcn UI: A highly customizable component library that complements Tailwind CSS for a consistent design system and extensible library
-
Backend:
- Django: A high-level Python web framework that encourages rapid development.
- Django REST Framework: A powerful and flexible toolkit for building Web APIs.
-
Database:
- PostgreSQL: A powerful, open-source object-relational database system.
-
Authentication:
- Kinde: A secure and easy-to-integrate authentication service used for Google account authentication.
Ensure you have the following installed on your system:
- Node.js (v14 or later)
- Python (v3.8 or later)
- PostgreSQL
-
Clone the repository:
git clone https://github.com/Nathaniel81/easebnb.git; cd easebnb
-
Install frontend dependencies::
cd frontend; npm install
-
Install backend dependencies:
cd ../backend; pip install -r requirements.txt
-
Set up PostgreSQL database:
Create a database and update the DATABASES settings in backend/settings.py with your database credentials.
-
Run database migrations:
python manage.py migrate
-
Configure Kinde for Google authentication:
Follow Kinde's documentation to set up your Google OAuth credentials and configure the settings in your application.
-
Start the development server:
-
Backend:
python manage.py runserver
-
Frontend:
cd ../frontend; npm run dev
-
Once the servers are running, you can access the application by navigating to http://localhost:5173
in your web browser. Register a new user, browse listings, make bookings, and explore the features of Easebnb. You can also use your Google account to log in via Kinde.
I welcome contributions to enhance this project. To contribute:
- Fork the repository.
- Create a new branch (git checkout -b feature-branch).
- Make your changes.
- Commit your changes (git commit -m 'Add new feature').
- Push to the branch (git push origin feature-branch).
- Open a Pull Request.
This project represents a significant learning journey in full-stack development, encompassing the integration of frontend and backend technologies. It demonstrates proficiency in building responsive and dynamic user interfaces using React and TypeScript, styling with Tailwind CSS, and managing data persistence and API services with Django and PostgreSQL. Additionally, it includes implementing secure authentication using Kinde for Google OAuth, showcasing a comprehensive approach to modern web application development.
Explore the live version of this project on https://easebnb.onrender.com.