This project is a real-time chat application where users can log in, register, and chat with online users. The application is developed using Node.js, Express, MongoDB, and WebSocket.
Live Demo (First login or registration may take up to 1 minute)
-
Login and Registration
- Users can log in or register.
- Login and registration controls are in place.
-
Chat Page
- Users can see online and offline users.
- Sending and receiving messages is possible.
-
WebSockets
- WebSocket is used for real-time messaging.
- Online status of users is updated instantly.
-
Show Who's Online
- Online users are shown in green.
- Offline users are listed as well.
-
Selecting a Conversation
- Users can select the person they want to chat with.
-
Sending Messages
- Users can send messages and receive incoming messages.
-
Automatically Scroll Chat Window
- The chat window is automatically scrolled when a new message is sent or received.
-
Fetching Historical Messages from Database
- Users can view their past messages with the selected user.
-
Online Indicator and Showing Offline Users
- Online users are displayed in green, and offline users are displayed in gray.
-
Login and Registration:
- You can log in with a username and password or create a new account on the homepage.
-
Chat:
- Select a user from the online users list.
- Send messages and see incoming messages.
- Frontend: React, Tailwind CSS
- Backend: Express.js
- Database: MongoDB
- Real-Time Communication: WebSocket