Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/adarshaacharya/codetreats

In-browser IDE for running, collaborating, saving and sharing code snippets.
https://github.com/adarshaacharya/codetreats

codeeditor codetreats express hacktoberfest hacktoberfest-accepted hacktoberfest2021 heroku ide monaco-editor mongodb nodejs reactjs snippets socket-io typescript

Last synced: 3 months ago
JSON representation

In-browser IDE for running, collaborating, saving and sharing code snippets.

Awesome Lists containing this project

README

        



Logo




License: MIT

Travis (.com)
Heroku


In-browser IDE for running, collaborating, saving and sharing code snippets.

## ⭐ Features

- In-browser IDE with VS Code like text editor having features like auto-completion, code-formatting
- 8+ Programming Languages support
- 15+ Themes Support 🀯
- Save snippets publicly with shareable link
- Search snippets with title
- Realtime Collaboration _(unlimited users)_ πŸ”₯
- Realtime Chat πŸ’₯

> ⚠️ *Website isn't mobile friendly and for best experience use Google Chrome.*

## πŸ“Ί Prerequisites

Before running app locally make sure that you install following things:

- Nodejs with npm or yarn installed
- [Mongodb](https://www.mongodb.com/) as database.
- Strongly recommended to use [Robot 3T](https://robomongo.org/) as MongoDB GUI for local database setup or simply use [MongoDB Atlas](https://docs.atlas.mongodb.com/getting-started/) and paste token in `DATABASE_URI`

## πŸš€ Local Development

### Step 1: Clone the repo

```bash
https://github.com/adarshaacharya/CodeTreats.git
```

## Step 2: Install dependencies

Install both client and server dependencies

```bash

# Install dependencies for server
$ npm install

# Install dependencies for client
$ npm run client:install

```

### Step 3: Configuration

1. Create `.env` file in project root dir

```bash
$ touch .env
```

2. Copy everything from `.env.example` as paste it in `.env`

3. Go to [Glot signup page](https://glot.io/auth/page/simple/register) and create new account.

4. Then [go to this page](https://glot.io/account/token) and copy & paste token in `GLOT_TOKEN = ` in `.env` file.

### Step 4: Usage

Now you can run the application by :

```bash

# Run the client & server with concurrently (for running full application)
$ npm run dev

# Run the Express server only
$ npm run server

# Run the React client only
$ npm run client

# Server runs on http://localhost:5000 and client on http://localhost:3000

```

## β›΅ Production Deployment

There is a Heroku post build script so that you do not have to compile your React frontend manually, it is done on the server. Simply push to Heroku and it will build and load the client index.html page

## 🀝 Contributing

Contributions, issues and feature requests are welcome. After cloning & setting up project locally, you can just submit a PR to this repo and it will be deployed once it's accepted.

**⚠️ Note - Commit & PR Title :**

It’s good to have descriptive commit messages so that other folks can make sense of what your commit is doing.
This project uses [Husky](https://github.com/typicode/husky/blob/master/README.md) prevent bad `git commit`, `git push` and more 🐢 \_woof!

Read [conventional commits](https://www.conventionalcommits.org/en/v1.0.0-beta.3/) before making the commit message.

## πŸ‘πŸ» Show your support

Give a ⭐️ if you like the project!

## πŸ‘€ Author

- Website:
- Twitter: [@adarshatweets](https://twitter.com/adarshatweets)
- Github: [@adarshaacharya](https://github.com/adarshaacharya)
- LinkedIn: [@adarshaacharya](https://linkedin.com/in/adarshaacharya)

## πŸ“ License

Copyright Β© 2020 [Aadarsha Acharya](https://github.com/adarshaacharya).

This project is [MIT](https://github.com/adarshaacharya/CodeTreats/blob/master/LICENSE) licensed.