Welcome to the WhatsApp Clone Web Application Frontend repository! This repository contains the frontend code for building a feature-rich messaging platform similar to WhatsApp. This project aims to replicate the functionality of WhatsApp, offering real-time messaging, video calls, file sharing, group chats, and various other features. The frontend is built using React.js and Tailwind.
- Real-time Messaging: Communicate with other users in real-time with ease and functionality.
- Video Calls: Enjoy face-to-face communication with the integration of video calls, complete with ringing components and sounds. ( I have used OBS to setup and use a virtual camera, to test videocalls )
- Online Status: Display the online status of friends and colleagues in real-time.
- File Sharing: Send various types of files including images, videos, documents, and more.
- Image/Video Uploads: Utilize Cloudinary to store images and implement image uploading, searching, and filtering.
- Group Chats: Collaborate and share ideas with multiple people simultaneously through group chats.
- Typing Indicator: See when someone is typing a message, enhancing the user experience.
- Emojis: Express yourself with a wide range of emojis to add personality to your conversations.
- Advanced Search: Easily find contacts with email or username.
- Authentication System: Secure login and registration processes with access and refresh tokens.
To get started with Whatsapp Clone, follow the steps:
Frontend:
git clone "https://github.com/MickyG03/Whatsapp-Clone-Frontend.git"
Backend:
git clone "https://github.com/MickyG03/Whatsapp-Clone-Backend.git"
Node Js: Make sure you have Node JS and NPM package manager installed on your system.
While both NPM and Yarn are viable options, I lean towards Yarn due to its parallel installation feature, which ultimately saves time.
npm install --global yarn
See the "Getting started" section of Whatsapp-Backend and get it up and running.
cd "Whatsapp-Clone-Frontend"
yarn install
- Create account on Cloudinary, which is a media API platform.
- Get "Cloud Name" from "Programmable Media > Dashboard > Cloud Name"
- Go to "Settings", scroll down to "Upload Presets", add an upload preset, and get the "Preset Name".
Create .env file in the frontend folder and add these fields:
REACT_APP_API_ENDPOINT = API endpoint for backend eg: {http://backend-url:port/api/v1}
REACT_APP_CLOUD_NAME = Cloud Name from step 6.
REACT_APP_CLOUD_SECRET = Preset Name from step 6.
This project was bootstrapped with Create React App. In the project directory, you can run:
-
yarn start
: Runs the app in the development mode. The page will reload when you make changes.
You may also see any lint errors in the console.
Open http://localhost:3000 to view it in your browser. -
yarn test
: Launches the test runner in the interactive watch mode.
See the section about running tests for more information. -
yarn build
: Builds the app for production to thebuild
folder.
It correctly bundles React in production mode and optimizes the build for the best performance.
The build is minified and the filenames include the hashes.
Your app is ready to be deployed! See the section about deployment for more information. -
yarn eject
: Note: this is a one-way operation. Once youeject
, you can't go back!
If you aren't satisfied with the build tool and configuration choices, you caneject
at any time. This command will remove the single build dependency from your project.
Instead, it will copy all the configuration files and the transitive dependencies (webpack, Babel, ESLint, etc) right into your project so you have full control over them. All of the commands excepteject
will still work, but they will point to the copied scripts so you can tweak them. At this point you're on your own.
You don't have to ever useeject
. The curated feature set is suitable for small and middle deployments, and you shouldn't feel obligated to use this feature. However we understand that this tool wouldn't be useful if you couldn't customize it when you are ready for it.
For this project I have used following libraries:
- Node JS - A JavaScript runtime built on Chrome's JavaScript engine. It allows you to run JavaScript code on the server side.
- Yarn - A fast, reliable, and secure dependency management tool. It's used for managing project dependencies, ensuring consistency across different environments, and improving performance during the installation process.
- React JS - A JavaScript library for building user interfaces.
- Socket IO - A JavaScript library for real-time web applications. It enables bidirectional communication between web clients and servers, allowing for real-time updates and messaging in applications.
- Simple Peer - A simple, easy-to-use library for WebRTC peer-to-peer communication in JavaScript. It provides a wrapper around the WebRTC API, making it easier to create peer connections and exchange data between browsers.
- Axios - A promise-based HTTP client for the browser and Node.js. It simplifies making HTTP requests and handling responses.
- JavaScript - A programming language that enables dynamic content and interactivity on web pages.
- Redux - A predictable state container for JavaScript apps. It helps manage the state of your application in a predictable and efficient manner.
- Yup - A JavaScript schema builder for value parsing and validation. It's often used with forms to ensure data meets certain requirements.
- Tailwind - A utility-first CSS framework for rapidly building custom user interfaces. It provides low-level utility classes that can be composed to build any design.
Want to contribute? Great! Contributions are welcome! If you have ideas for new features, improvements, or bug fixes, feel free to open an issue or submit a pull request.
- https://web.whatsapp.com/
- https://www.geeksforgeeks.org/mern-stack/
- https://www.udemy.com/course/whatsapp-clone-video-calls-mern-stack-socket-io/
- https://cloudinary.com/documentation
- https://cloudinary.com/
- https://www.npmjs.com/
- https://socket.io/docs/v4/
- https://github.com/feross/simple-peer?tab=readme-ov-file#usage
- https://react-redux.js.org/using-react-redux/connect-mapdispatch
- https://legacy.reactjs.org/docs/hooks-effect.html
- https://v2.tailwindcss.com/docs