Skip to content

Latest commit

 

History

History
132 lines (82 loc) · 5.65 KB

README.md

File metadata and controls

132 lines (82 loc) · 5.65 KB

Watch the Demo Video 🎥

You can watch the demo video by clicking the link below:

Watch Demo Video

##Food Donation and Request System

Project Image Project Image

Project Overview

This is a full-stack web application built to facilitate food donation and requests. The app allows users to post food they want to donate, as well as request food. Users can sign in via Firebase Authentication, and their data is stored in Firestore. The application is designed with an easy-to-use interface, utilizing modern web technologies to provide a seamless experience.

Features:

  • User Authentication using Firebase Auth 🛂
  • Post a Food Request 🍽️: Users can request food with details like quantity, food type, pickup location, and instructions.
  • Post Food Donation 🍔: Users can donate food with details like the name of the food, quantity, and pickup location.
  • Real-Time Updates 📡: The app uses Socket.IO to provide real-time updates for food donations and requests.
  • Dashboard 📊: A dedicated page for users to view their donation history and requests.
  • Profile Management 👤: Users can manage their profile and view their posted content.

Project Link 🚀

https://anna-raksha-bmu9.vercel.app/

Tech Stack 🚀

The following technologies were used to build this project:

  • Frontend:

    • React: For building the user interface.
    • Vite: A fast build tool for modern web projects.
    • Tailwind CSS: For utility-first CSS styling, making the UI highly customizable.
    • TypeScript: For type-safe development, enhancing the maintainability and scalability of the code.
    • Socket.IO: For real-time communication between users (for updates on donations and requests).
    • React Router: For managing routing in the app.
  • Backend:

    • Node.js: Server-side runtime environment.
    • Express.js: Web framework for Node.js to handle routing and HTTP requests.
    • Firebase: Firebase for authentication and Firestore database.
      • Firebase Auth: For handling user authentication and authorization.
      • Firestore: A NoSQL database for storing user data and posts.
    • Socket.IO: For implementing real-time bidirectional communication.


Project Image

Installation 🛠️

To run this project locally, follow the steps below:

Prerequisites 🖥️

  • Node.js installed on your machine.
  • Firebase account (for Firebase Authentication and Firestore setup).
  • A modern browser (Chrome, Firefox, etc.).

Steps 🔄

  1. Clone the repository:

    git clone https://github.com/Hari-hara7/anna-raksha.git
    
    

Firebase Setup 🔑

Firebase Authentication 🛂:

  • Enable Email/Password Authentication or use any other authentication method.

Firestore 📚:

  • Create two collections in Firestore:

    • foodPosts: For storing donated food details.
    • foodRequests: For storing food request details.
  • The documents in these collections will contain information like food name, quantity, pickup location, and user details (email, name, etc.).


Built-in Icons 🖼️

The app uses Font Awesome icons for displaying various actions like adding posts, editing, deleting, and more. You can easily replace them or add new ones as needed.

Example icons:

  • Add Post
  • Edit ✏️
  • Delete

You can refer to the full icon library here: Font Awesome Icons.


Contributing 🤝

We welcome contributions! If you'd like to contribute to the project, feel free to:

  1. Fork the repository.
  2. Create a new branch (git checkout -b feature/your-feature-name).
  3. Make your changes and commit them (git commit -am 'Add your feature').
  4. Push to the branch (git push origin feature/your-feature-name).
  5. Create a new Pull Request.

License 📝

This project is licensed under the MIT License - see the LICENSE file for details.


Links 🔗


Notes:

  • Be sure to replace the placeholder GitHub links, Firebase setup, and demo URL with your actual repository and project details.
  • Use the appropriate icon sizes and styles based on your preference (you can also adjust icon sizes or styling using CSS classes).