iamdevvalecha / caucus

Realtime Collaborate Editor with Embedded Compiler

Home Page:https://caucus-app.herokuapp.com/

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Contributors Forks Stargazers Issues MIT License LinkedIn


Logo

caucus

A Real Time Collaborative Editor with an embedded compiler
Explore the project »

View Demo · Report Bug · Request Feature

Table of Contents
  1. About The Project
  2. Getting Started
  3. Roadmap
  4. Contributing
  5. License
  6. Contact
  7. Acknowledgements

About The Project

Demonstration

Product Demonstation


Collaborative Code Editor

Product Name Screen Shot

Login Page Navigate Rooms Page
Product Name Screen Shot Product Name Screen Shot

Built With

Written in TypeScript ♥

Getting Started

Follow the instructions to set up the project on your local machine.

Prerequisites

This is an example of how to list things you need to use the software and how to install them.

  • npm

    npm install npm@latest -g

Installation

  1. Clone the repo

    git clone https://github.com/Rishabh-malhotraa/caucus.git
  2. Install NPM packages

    npm install
  3. Start the react server

    npm run start

Roadmap

See the open issues for a list of proposed features (and known issues).

Things To do

  • Inital Login Page
  • Database hookup with login from oAuth
  • Chat Application
  • Video Chat Application (the main chunk of work)
  • Collaborative Editing (the main chunk of work)
  • Resizable Panes
  • Code Running (Easy need to just hookup with an api)
  • Database with all the leetcode question and sorted based on tags.
  • IMP: Sync code using localstorage or sockets when a new person joins in the room, with defaultvalue prop on the monaco editor instance.
  • Add SSL certificate to the docker container, andd get rid of the current bootleg shenanigans D: (LetsEncrypt or Cloudflare)
  • Add codeforce problem using webscraping thingy
  • Add Vim Keybinds
  • Add intellisense using Language Server Protocal for atleast C++ and JAVA
  • Make a public api to fetch questions, based on scraped data
  • Add a full-screen Zen Mode
  • Change Hosting from Heroku to GCP or Digital Ocean
  • Change Heroku PSQL DB to either MongoDB or Firebase SQLITE.
  • Add Autoformating keybind.
  • Fix the number of users in the room.
  • REACH: Add video call functionality (using WEBRTC or something propieteary like Twilo proprietary)
  • Add ability to add different tabs on the editor instance just like that on VSCODE
  • Integrate the random quote thingy on loading screen from forticodes API
  • Fix why the loader gets frozen on intial render -_-

Contributing

Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.

  1. Fork the Project
  2. Create your Feature Branch (git checkout -b feature/AmazingFeature)
  3. Commit your Changes (git commit -m 'Add some AmazingFeature')
  4. Push to the Branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

Refer to this article if you have any difficulty in making a pull request

License

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


Contact

Rishabh malhotraa - @CaffeinatedRish - rmalhotra_be18@thapar.edu

Project Link: https://caucus-app.herokuapp.com/


Stargazers over time

Stargazers over time


Acknowledgements

About

Realtime Collaborate Editor with Embedded Compiler

https://caucus-app.herokuapp.com/

License:MIT License


Languages

Language:TypeScript 81.9%Language:JavaScript 16.4%Language:HTML 1.6%Language:Shell 0.1%