Skip to content

Latest commit

 

History

History
71 lines (51 loc) · 3.92 KB

README.md

File metadata and controls

71 lines (51 loc) · 3.92 KB

Scribble Sync

Scribble Sync is a real-time whiteboarding application that enables collaborative drawing and diagramming. With Scribble Sync, users can create shapes, diagrams, and freeform drawings together in real-time, making it ideal for brainstorming sessions, planning meetings, and collaborative presentations.

Here is the link of the video of how the application works

Link - By loom.com

Features

  • Real-time Collaboration: Multiple users can collaborate on a single canvas simultaneously, allowing for seamless teamwork.
  • Drawing Tools: Scribble Sync provides a variety of drawing tools, including shapes, pens, and text, to enable users to express their ideas creatively.
  • Intuitive Interface: The interface is designed to be user-friendly and intuitive, making it easy for users to navigate and use the drawing tools effectively.
  • Liveblocks Integration: Scribble Sync leverages Liveblocks for real-time synchronization of drawing actions across all connected users.
  • Fabric.js: Fabric.js is used as the rendering engine for the drawing canvas, providing powerful features for handling shapes, layers, and interactions.
  • SHADCN: The application is styled using SHADCN, a lightweight CSS framework that provides modern and customizable styling.

Technologies Used

  • Liveblocks: Liveblocks is a real-time collaboration platform that provides synchronization primitives for building collaborative applications.
  • Fabric.js: Fabric.js is a JavaScript library that provides interactive object model on top of HTML5 canvas elements.
  • SHADCN: SHADCN was used for the component styling as it is a lightweight CSS framework that provides modern and customizable styling.
  • Tailwind CSS: I planned to use Tailwind CSS for utility-first CSS styling as it is highly customizable and easy to use.
  • TypeScript: TypeScript was used for writing the application code, providing type safety and enhanced developer productivity.
  • Convex DB: Convex DB was used as it is a real-time database that provides seamless synchronization of data across clients. And all the things were done in a monorepo.
  • Clerk: Clerk is an authentication and user management platform which was used for secure and scalable authentication for out applications.

Thanks to

Future Plans

(This is a v2 release of the application)

  • I plan to intergrate different rooms for the users for accessing the whiteboard.
  • Also plan to deploy it on a server and make it live for the users to use.

Getting Started

To run Scribble Sync locally, follow these steps:

  1. Clone the repository:
git clone https://github.com/MonalBarse/Scribble-Sync.git
  1. Run the development server:
npm run dev
# or
yarn dev
# or
pnpm dev
# or
bun dev
  1. Spin up a convex backend :
npx convex dev

Open http://localhost:3000 with your browser to see the website