MyCampusHome is a comprehensive web application designed to assist students in finding the perfect student accommodations. The platform offers an intuitive interface, responsive design, and integration with modern authentication and payment systems.
- User Authentication: Secure login and registration functionality with JWT.
- Responsive Design: Fully responsive UI built with Tailwind CSS, ensuring usability across devices.
- Google Authentication: One-click sign-in with Google.
- Dynamic Search: Explore student accommodations by location, price, and preferences.
- Booking System: Reserve and manage bookings easily.
- Admin Panel: Admin dashboard for managing properties, users, and bookings.
Here are some screenshots of the MyCampusHome application:
- React.js: Framework for building the user interface.
- Tailwind CSS: For styling the application.
- React Router: To handle navigation.
- Axios: For API requests.
- Node.js: Server-side runtime.
- Express.js: Web application framework.
- MongoDB: Database for storing application data.
- Mongoose: MongoDB object modeling for Node.js.
- JWT: Secure JSON Web Tokens for user authentication.
- Google OAuth: Login using Google accounts.
- Stripe (Planned): Seamless payment integration for bookings.
- Node.js and npm installed
- MongoDB Atlas account or local MongoDB instance
- A Google Cloud Project for OAuth setup
-
Clone the repository:
git clone https://github.com/De-Silva-Madhushankha/MyCampusHome.git
-
Navigate to the client directory:
cd mycampushome/client
-
Install dependencies:
npm install
-
Create an env file in the client directory: include the following key-value pairs
VITE_BASE_URL=" your server URL" VITE_FIREBASE_API_KEY=" your firebase API key" VITE_FIREBASE_AUTH_DOMAIN="example.firebaseapp.com" VITE_FIREBASE_PROJECT_ID="example-760a0" VITE_FIREBASE_STORAGE_BUCKET="example.firebasestorage.app" VITE_FIREBASE_MESSAGING_SENDER_ID="" VITE_FIREBASE_APP_ID="" VITE_FIREBASE_MEASUREMENT_ID="" VITE_OPENCAGE_API_KEY="" VITE_MAPTILER_API_KEY=""
-
Start the development server:
npm start
- Navigate to the backend directory:
cd mycampushome/server
- Install dependencies:
npm install
- Configure environment variables:
Create a
.env
file in the server directory with the following:HOST= "" PORT= 4000 NODE_ENV= production COOKIE_KEY="your cookie key" JWT_SECRET="your jwt secret" CLOUDINARY_CLOUD_NAME="" CLOUDINARY_API_KEY="your Cloudinary API key" CLOUDINARY_API_SECRET="your Cloudinary API secret" MONGO_URI="your mongo uri" GOOGLE_CLIENT_ID="" GOOGLE_CLIENT_SECRET="" SMTP_HOST="smtp.gmail.com" SMTP_PORT=587 SMTP_USER= SMTP_PASSWORD='' TWILIO_ACCOUNT_SID= TWILIO_AUTH_TOKEN= TWILIO_PHONE_NUMBER=
- Start the server:
npm start
- Navigate to the root directory mycampushome:
above script will run your client and server in development mode using nodemon. suitable for development.
npm run start
- Payment Integration: Implement Stripe for handling payments.
- User Notifications: Notify users about booking updates and offers.
- Enhanced Search: Add filters for more specific accommodation searches.
Contributions are welcome! Please fork the repository and submit a pull request for any features, bug fixes, or enhancements.
This project is licensed under the MIT License.