/Devspace

๐Ÿ† Best Use of Twilio

Primary LanguageJavaScriptMIT LicenseMIT

Contributors Issues MIT License


Logo

Virtual Classroom!

A Virtual Classroom Designed To Optimize Learning Approaches!

Explore the docs ยป

Table of Contents

  1. About The Project
  2. Getting Started
  3. Usage
  4. Roadmap
  5. Contributing
  6. License
  7. Contact
  8. Acknowledgments

HeroHacks II Winner (Most Creative Use Of Twilio) image

Domain Name

Our project's domain name is "studywith.tech"

Inspiration

The inspiration for our project came from the fact that due to the implementation of remote learning, teachers all over the world have to interact with their students virtually. Today, two major platforms namely Google Meet and Zoom dominate the virtual learning industry. However, both platforms have shortcomings. Google Meet for example lacks the functionality of a built in collaborative whiteboard or annotation while a teacher is presenting. Zoom on the other hand has these functionalities but lacks the ease of access of google meet via a web browser. Our app aims to strike a combination of the features of Zoom and ease of access of Google Meet.

What it does

Virtual-Classroom is a web conferencing app that allows teachers to connect with their students and share their learning materials via either screen-sharing or using a collaborative whiteboard. The use of a collaborative whiteboard makes it easier for teachers to supplement their learning material and for students to better explain their difficulties and interact with teachers.

How We built it

Virtual-Classroom is a React app built using Twilio's programmable video and conversations SDK. The collaborative whiteboard functionality is implemented using the Data Track API.

Most Creative use of Twilio

We use Twilio's Video SDK for JavaScript to enable users to stream data from their mic and camera via "tracks", these tracks can then be subscribed to by other users thus enabling sharing of video and audio. For low latency sharing of data between users required in the chat and reactions menu, we used Twilio's DataTrack API which is used to share reactions, chat messages as well as whiteboard pointer data. This allows for the users to react to other users, send them messages as well as work on a collaborative whiteboard.

Features:

  • Interactive environment to learn (video calling and microphone option)
  • Whitebord (learning + collaborative tool)
  • Reactions (emojis)
  • Screenshare ability
  • Chatbox
  • Multiple Individuals can join at once

Built With

  • React.js
  • HTML
  • CSS
  • JavaScript
  • Twilio
  • Firebase

Demo

Studywith.tech.demo.video.mp4

Getting Started

Prerequisites

  • Install Desktop development with c++ workload on Visual studio
  • Git CLI

Installation

  • git clone https://github.com/hussaino03/Devspace
  • In project directory run npm install
  • Run npm start

Available Scripts

In the project directory, you can run:

npm install

This will install all the required modules

npm start

This will start the server

Runs the app in the development mode.

Open http://localhost:1234 to view it in your browser.

Roadmap

  • [โœ…] Integrate camera/mic option
  • [โœ…] Integrate a whiteboard
  • [โœ…] Integrate emojis
  • [โœ…] Integrate disable/enable option for both the video and microphone

License

Distributed under the MIT License. See LICENSE.txt for more information.

Acknowledgments