Skip to content

Latest commit

Β 

History

History
151 lines (96 loc) Β· 5.37 KB

README.md

File metadata and controls

151 lines (96 loc) Β· 5.37 KB

alt text React MongoDB Vite TailwindCSS NodeJS Express.js MongoDB Nodemon JWT Socket.io

Inroduction

WebChatApp is a full-stack, real-time messaging application designed for seamless communication. It offers features such as real-time messaging, online status indicators, user authentication, and a modern user interface with a glassmorphism effect.

🌟 Features

  • Real-Time Messaging: Instantly send and receive messages with live updates.
  • User Authentication: Secure sign-up and login using JWT.
  • Online Status Indicators: Know who's online with real-time status updates.
  • User-Friendly Interface: Beautiful, modern design with glassmorphism effects.
  • Error Handling: API handles errors gracefully and provides clear feedback.
  • Conversation History: Access to past messages in a conversation.

πŸš€ Tech Stack

Backend

  • Express.js: Server-side framework.
  • MongoDB with Mongoose: Database management and schema modeling.
  • JSON Web Tokens (JWT): Authentication and session management.
  • bcrypt: Secure password hashing.
  • Socket.IO: Real-time communication.

Frontend

  • React with Vite: Fast and responsive web applications.
  • Tailwind CSS: Modern styling framework.
  • Shadcn: Sleek and reusable UI components.
  • Zustand: State management library.
  • Lucide and Radix UI: Icons and emojis for a vibrant UI.
  • React Context and Custom Hooks: Manage state and logic cleanly.

πŸ”— Integrating Cloudinary for Photo Storage

This app uses Cloudinary to store and manage user-uploaded images.

πŸ“Έ Setting Up Cloudinary

  1. Create a Cloudinary Account:

  2. Get Your Cloudinary Credentials:

    • After signing up, you’ll receive a Cloud name and Cloud_preset_name, Keep these handy.
  • Note :

    • Setting up CloudinaryCopy link to this heading As we are going to upload images to Cloudinary, we need to create an upload preset and set the upload mode to unsigned. To do that, log into your Cloudinary account and click on Settings > Upload.

alt text

Now, scroll down to upload presets and click on Add upload presets. Then:

Provide an upload preset name. Set Signing Mode to unsigned, and Set a desired folder to hold the image uploads (optional).

alt text

  • create .env file in frontend folder and paste.

    VITE_CLOUD_NAME=your_cloud_name 
    VITE_UPLOAD_PRESET_NAME=cloud_preset_name
  1. Install Cloudinary SDK:

    • In your frontend, install the Cloudinary package using npm:
    npm install cloudinary

πŸ’» Getting Started

1 .Cloning the Repository

cd https://github.com/himanshu-tyd/WebChatApp.git
cd WebChatApp

2. Install Dependencies:

Install packeges

# Install backend dependencies
cd backend
npm install

# Install frontend dependencies
cd frontend
npm install

3. Set Up Environment Variables :

Create a .env file in the root directory of your project and add the necessary environment variables, including your Cloudinary credentials.

PORT=your_port
MONGO_URI=your_mongodb_uri
NODE_ENV=devlopment

4. Run the Application:

# Run backend
cd backend
npm start

# Run frontend
cd frontend
npm run dev

5. Open in Browser:

Open http://localhost:3000 in your browser to start using WebChatApp.

πŸ“œ License

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

πŸ›  Contributing

Contributions are welcome! Please fork the repository and create a pull request for any features, bug fixes, or improvements.

🌐 Deployments

  • frontend and backend render.com

πŸ’¬ Contact

For any questions or suggestions, feel free to reach out to me at code.himanshu93@gmail.com.

Happy coding! πŸŽ‰