GitXplorerGitXplorer
v

Microsoft-Teams-Clone

public
17 stars
10 forks
0 issues

Commits

List of commits on branch main.
Verified
c9901d641bc737d2ccfbbee6917cd17dc02b475e

Update README.md

vvanichitkara committed 3 years ago
Verified
f75c0efe3b523e950316fb4d27aea39f07e66469

Update README.md

vvanichitkara committed 3 years ago
Verified
1f94abf545d6d7eebc2d126b91d52fdee90bcda1

Update README.md

vvanichitkara committed 4 years ago
Verified
f8c9d076c83e45adc5df84f18e8c41137bdc9c9e

Update README.md

vvanichitkara committed 4 years ago
Verified
5a2ec3be2633e54b30ac32af88adb8b53bd80368

Update README.md

vvanichitkara committed 4 years ago
Verified
2222698caf6d3583d26eb056e51d689517fb06f0

Update README.md

vvanichitkara committed 4 years ago

README

The README file for this repository.

Microsoft Teams Clone Logo

Link to the App · Video Demo

Table of Contents
  1. About The Project
  2. Agile Methodology
  3. Getting Started
  4. Navigating through the App
  5. Resources Used

About The Project

  • Microsoft Teams clone project built during Microsoft Engage 2021 program.
  • It is a video call and chat application through which we can chat before, during and after a video call.
  • The video call can take place between maximum 2 people at once.

Salient Features

  • User authentication using Firebase and login via Google and Facebook
  • Creating and deleting chat groups, adding and removing people by the group admin, photo sharing, chat text formatting, read receipts, typing status of users
  • One-on-one video call with randomly generated unique link and the ability to mute and unmute audio and video during the call

Compatible Platforms

Laptops, Desktops and Tablet PCs

Built With

Video Call Application:

  • Front-end
  • Back-end
  • Tools

Chat Application:

  • Front-end
  • Back-end
  • Tools

Agile Methodology

What is Agile

Agile is a development methodology adopted today in the software industry. Agile promotes teamwork, flexible procedures, and sle-organizing teams.

How I Incorporated Agile Methodology During The Development Cycle

SCRUM is a subset of Agile, a framework for developing software. SCRUM takes advantage of different techniques to achieve goals in Agile. SCRUM promotes an iterative model where the planning is performed on a very short term. The basic time working unit is the sprint. SCRUM teams always reason in sprints and their planning is limited to sprints.

  • Sprint 1 (June 14): Sprint Planning, Research and Design - Researching about various video call libraries and SDKs that can be used to make a video call app with a minimum functionality to have a call between 2 people. After finalizing webRTC for making the video call app, I searched for tutorials, designed a wireframe including the functionalities I want and designed the UI.

  • Sprint 2 (June 21): Software development and debugging - Started the development process by taking help from YouTube tutorials. Built a web application using React JS and Node JS for the first time. Encountered occasional bugs which I debugged timely. Made required changes in the UI and color scheme to make it more eye pleasing

  • Sprint 3 (July 5): Adapting the surprise feature, debugging and adding additional features - My detailed research made it easy for me to decide how to implement the surprise 'adapt' feature. Decided to build a chat app using React JS and Chat Engine and link my previous video call application to the new chat application. Made changes in pre-loaded styles to complement the color scheme of the video call app and added sign in authentication using Firebase. Also added mute audio and video function in the video call application.

Getting Started

To install and run the project on your local system, following are the requirements:

Prerequisites

Make sure to install the required dependencies via node package manager

  npm install npm@latest -g

Installation

  • Video Call Application

To separately run the video call application on your local host, perform the following steps:

Run the following commands to start the server side.

  npm install && npm start

Run the following commands to start the client side and run it on your local host

  cd client
  npm install && npm start
  • Chat Application

Run the following commands to start the application on your local host

  npm install && npm start

Navigating Through The App

Login

Login to the chat application via Google or Facebook. If an email id is linked with both Google and Facebook, then sign in can be done with wither via Google or Facebook.

login screen

Chat Window

After logging in, a blank chat window appears. Start a new chat by clicking on the + sign. A video call can be placed by clicking the 'Video Call' option in the navigation bar. Adjacent to it is the logout option.

blank chat window

All the users registered with the app can be added to your chat. Photo sharing, read receipts, formatting the text, and many other things are possible in the chat. The shared photos can be viewed in the right pane. The chat can be deleted by expanding the 'Options' menu in the right pane and clicking the 'Delete' option.

new chat

Video Call

The video call welcome screen shows your video and has a form to enter your name. To place a call, click on 'Copy your ID' and send the random generated unique ID to the person you want to call.

video call welcome screen

The person who received the ID needs to copy that in the 'ID to call' input field and click on 'Call' button. You can accept the person's incoming call by clicking on 'Answer' button.

placing call

Once the call is accepted, the users are connected and can video call seamlessly with the option to mute audio and video when required. The call can be stopped by clicking on 'Hang Up' button. The video call screen closes and we are navigated back to the chat window.

video call between 2 people

Resources Used