Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gunjankadu/code-together
Code Together is an interactive, real-time code editor that enables users to collaboratively code. It offers a space for multiple individuals to join a room, exchange a distinct room ID, and work together on code in real-time.
https://github.com/gunjankadu/code-together
Last synced: about 1 month ago
JSON representation
Code Together is an interactive, real-time code editor that enables users to collaboratively code. It offers a space for multiple individuals to join a room, exchange a distinct room ID, and work together on code in real-time.
- Host: GitHub
- URL: https://github.com/gunjankadu/code-together
- Owner: GunjanKadu
- Created: 2024-03-11T11:03:13.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2024-04-15T19:06:38.000Z (10 months ago)
- Last Synced: 2024-11-09T22:07:24.374Z (3 months ago)
- Language: JavaScript
- Homepage: https://code-together-client-rho.vercel.app
- Size: 2.06 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Code Together - A Realtime Code Editor
data:image/s3,"s3://crabby-images/b6e1e/b6e1ec6d1abd8ff3e6a8f887fba3cdcceb0defca" alt="screenshot"
data:image/s3,"s3://crabby-images/9969d/9969df2df6bb753e8eaf9973b448cd4a41305f87" alt="screenshot"
Code Together is an interactive, real-time code editor that enables users to collaboratively code. It offers a space for multiple individuals to join a room, exchange a distinct room ID, and work together on code in real-time.
## 🔮 Features
- 💻 Real-time collaboration on code editing across multiple files
- 🚀 Unique room generation with room ID for collaboration
- 🌈 Syntax highlighting for various file types with auto-language detection
- 💡 Auto suggestion based on programming language
- ⏱️ Instant updates and synchronization of code changes across all files
- 📣 Notifications for user join and leave events
- 🎨 Multiple themes for personalized coding experience
- 🌍 Comprehensive language support for versatile programming
- 🔠 Option to change font size and font family
- 👥 User presence list of users currently in the collaboration session, including online/offline status indicators
- 📁 Open, edit, save, and delete file functionalities
- 💾 Option to download files edited within the collaboration session
- 💬 **Group chatting** allows users to communicate in real-time while working on code.## 🚀 Live Preview
You can view the live preview of the project [here](https://code-together-client-rho.vercel.app/).
## 💻 Tech Stack
data:image/s3,"s3://crabby-images/136e3/136e384f53aef9cb838dae4e6ae5a1c2a683c922" alt="JavaScript"
data:image/s3,"s3://crabby-images/c8d86/c8d8633de7e773ad25f7358c87ae64bd83ccd1b9" alt="React"
data:image/s3,"s3://crabby-images/d5591/d559129e9b7b82d458dd0b63ad5e4b9e7fac8611" alt="React Router"
data:image/s3,"s3://crabby-images/8337a/8337a06f4214fd48944459f2bb610565ab555e75" alt="Tailwind CSS"
data:image/s3,"s3://crabby-images/3d4e9/3d4e94ce8258bca7a8f9c64eadb41e94e7774f97" alt="NodeJS"
data:image/s3,"s3://crabby-images/e6ba1/e6ba129d0aaee865fe1bfe54b90e14f4cac530ba" alt="ExpressJS"
data:image/s3,"s3://crabby-images/4121d/4121d2a7fbf70465785916a68bfca3ae68ebaa19" alt="Socket io"
data:image/s3,"s3://crabby-images/2397f/2397f2f5f0ed6ce8278725a89380571612802ccb" alt="Git"
data:image/s3,"s3://crabby-images/88823/88823ce0fa7ba4353317aa4e5949b21ed298c57e" alt="GitHub"
data:image/s3,"s3://crabby-images/f2e8b/f2e8ba4d5b9fb47a3bd0823d283c26db9fcdc79e" alt="Vercel"## 📂 Folder Structure
```
client/
├── public/
│ ├── favicon/
│ │ └── ...
│ └── style.css # Tailwind output
├── src/
│ ├── assets/
│ │ └── ...
│ ├── components/
│ │ ├── chats/
│ │ │ ├── ChatInput.jsx
│ │ │ └── ChatList.jsx
│ │ ├── common/
│ │ │ ├── Clients.jsx
│ │ │ ├── Footer.jsx
│ │ │ └── Select.jsx
│ │ ├── editor/
│ │ │ ├── Editor.jsx
│ │ │ └── EditorComponent.jsx
│ │ ├── files/
│ │ │ ├── FileEditor.jsx
│ │ │ └── FileSystem.jsx
│ │ ├── forms/
│ │ │ └── FormComponent.jsx
│ │ ├── loading/
│ │ │ └── Loading.jsx
│ │ ├── sidebar/
│ │ │ └── Sidebar.jsx
│ │ ├── tabs/
│ │ │ ├── ChatsTab.jsx
│ │ │ ├── ClientsTab.jsx
│ │ │ ├── FileTab.jsx
│ │ │ ├── SettingsTab.jsx
│ │ │ └── TabButton.jsx
│ │ ├── toast/
│ │ │ └── Toast.jsx
│ │ ├── GitHubCorner.jsx
│ │ └── SplitterComponent.jsx
│ ├── context/
│ │ ├── AppContext.jsx
│ │ ├── AppProvider.jsx
│ │ ├── ChatContext.jsx
│ │ ├── FileContext.jsx
│ │ └── TabContext.jsx
│ ├── hooks/
│ │ ├── useChatRoom.jsx
│ │ ├── useFileSystem.jsx
│ │ ├── useLocalStorage.jsx
│ │ ├── usePageEvents.jsx
│ │ ├── useClientActivity.jsx
│ │ └── useWindowDimensions.jsx
│ ├── layouts/
│ │ └── EditorLayout.jsx
│ ├── pages/
│ │ ├── EditorPage.jsx
│ │ └── HomePage.jsx
│ ├── resources/
│ │ ├── Font.js
│ │ ├── Languages.js
│ │ └── Themes.js
│ ├── socket/
│ │ ├── useSocket.jsx
│ │ └── socket.js
│ ├── utils/
│ │ ├── actions.js
│ │ ├── editorPlaceholder.js
│ │ ├── formateDate.js
│ │ ├── initialFile.js
│ │ ├── socketStatus.js
│ │ └── tabs.js
│ ├── App.jsx
│ ├── index.css
│ └── main.jsx
├── .env
├── .eslintrc.cjs
├── .gitignore
├── index.html
├── package-lock.json
├── package.json
├── postcss.config.js
├── tailwind.config.js
└── vercel.json
└── vite.config.jsserver/
├── utils/
│ └── actions.js
├── .env
├── .gitignore
├── package-lock.json
├── package.json
└── server.jsscreenshots/
CONTRIBUTING.md
LICENSE
README.md
```## ⚙️ Installation
1. **Fork this repository:** Click the Fork button located in the top-right corner of this page to fork the repository.
2. **Clone the repository:**
```bash
git clone https://github.com//Code-Together.git
```
3. **Set .env file:**
Inside the client and server directory, create or edit the .env file and add the following line:
Frontend:```bash
VITE_BACKEND_URL=
```Backend:
```bash
PORT=3000
```4. **Install dependencies:**
Navigate to the frontend and backend directories separately and run:
```bash
npm install
```
5. **Start the frontend and backend servers:**
Frontend:
```bash
cd client
npm run dev
```
Backend:
```bash
cd server
npm run dev
```
6. **Access the application:**
Open a browser and enter the following URL:
```bash
http://localhost:5173/
```