Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/konstantinmuenster/notion-clone
Edit Notes like in Notion.so. Full-Stack App using React/Express.
https://github.com/konstantinmuenster/notion-clone
contenteditable expressjs mongoose nextjs notion notion-editor reactjs
Last synced: 2 days ago
JSON representation
Edit Notes like in Notion.so. Full-Stack App using React/Express.
- Host: GitHub
- URL: https://github.com/konstantinmuenster/notion-clone
- Owner: konstantinmuenster
- Created: 2020-09-05T09:28:21.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-10-15T13:27:47.000Z (about 1 year ago)
- Last Synced: 2025-01-03T13:10:21.962Z (9 days ago)
- Topics: contenteditable, expressjs, mongoose, nextjs, notion, notion-editor, reactjs
- Language: JavaScript
- Homepage: https://notion-clone.kmuenster.com
- Size: 1.51 MB
- Stars: 2,944
- Watchers: 51
- Forks: 330
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-github-star - notion-clone - Stack App using React/Express. | konstantinmuenster | 2769 | (JavaScript)
README
# 📓 Notion Clone
#### Create and Edit Notes like in Notion
This clone tries to replicate some of the great note-taking features Notion has. If you don't know [Notion.so](https://notion.so) yet, I highly recommend to check it out!
📌 Live Demo: [notion-clone.kmuenster.com](https://notion-clone.kmuenster.com/)
📌 Medium Article: [How To Build A Text Editor Like Notion](https://medium.com/swlh/how-to-build-a-text-editor-like-notion-c510aedfdfcc)
---
---
## Features
- **Slash Commands** (Type `/` to turn the block into different content types)
- **HTML Support** (Use regular HTML tags like `` in text blocks)
- **Image Support** (Upload images by using the `/image` command)
- **Drag And Drop** (Reorder blocks easily by drag and drop)
- **Guest Editing** (Anyone can create public pages and share them via link)
- **User Management** (Create an account to create private pages)
- **Scheduled Jobs** (Delete inactive pages and accounts automatically)## Tech Stack
The frontend is built with Next.js and fully server-side rendered. On the backend, a REST API handles saving user content and user management.
#### Frontend
Next.js · React.js · SCSS/SASS
#### Backend
Express.js · MongoDB with Mongoose · Nodemailer · JWT (Cookie-based)
## Installation
1. **Clone the project**
```sh
git clone https://github.com/konstantinmuenster/notion-clone.git
cd notion-clone
```
2. **Add environment variables**Backend: Create an `.env` file in the `backend` directory:
```
FRONTEND_URL="http://localhost:3000"
DOMAIN="localhost"
JWT_KEY="yourSecretForTokenGeneration"
PORT=8080
MONGO_URI="mongodb+srv://username:[email protected]/database?retryWrites=true&w=majority"
MAIL_HOST="smtp.sendgrid.net"
MAIL_PORT=465
MAIL_USER="apiKey"
MAIL_SENDER="Your Name "
MAIL_PASSWORD="yourSendGridApiKey"
```Frontend: Create an `.env.local` file in the `frontend` directory:
```
NEXT_PUBLIC_API="http://localhost:8080" // references your Backend API endpoint
```3. **Install and run backend (http://localhost:8080)**
```sh
cd backend
npm install
npm start
```4. **Install and run frontend (http://localhost:3000)**
```sh
cd frontend
npm install
npm run dev
```## Hosting
You can host the application on almost any provider that supports Node applications and custom domains. I decided to host the frontend on [vercel.com](https://vercel.com) and the backend on [heroku.com](https://heroku.com). But you can host both, frontend and backend, on the same provider if you like to.
### MongoDB Atlas
You have to create a new MongoDB cluster upfront. It will store all of your page and block data. You can create one for free on [MongoDB Atlas](https://www.mongodb.com/cloud/atlas).
**Make sure**, you create the following collections:
* pages
* users**Make sure**, you allow network access to everyone (due to Heroku).
### Backend
If you want to deploy the backend on [heroku.com](https://heroku.com), create a new app in your preferred region on heroku.com.
**Make sure**, you add all production environmental variables for the backend. You can see which variables are needed in the Installation part of this readme.
**Make sure**, you add a custom domain for your backend API. Since the application uses a Cookie-based authentication, we have to run backend and frontend on the same domain. I, for example, run the frontend on `www.notion-clone.kmuenster.com` and the backend on `api.notion-clone.kmuenster.com`.
> **Want to run scheduled jobs?** To delete inactive pages and users, I run scheduled jobs frequently. If you want this feature as well, you have to add more dynos to your application and run the job `$ node jobs/index.js` via Heroku Scheduler.
Lastly, you can deploy your app using Heroku Git.
**Make sure**, that when you push the backend to Heroku, you make a Git subtree push since `notion-clone` is a mono-repo containing backend and frontend. So run `git subtree push --prefix backend heroku master` instead of `git push heroku master`. Thus, we only push the backend part.
### Frontend
If you want to deploy the frontend on [vercel.com](https://vercel.com), you can so easily using the Vercel CLI.
With the Vercel CLI, we don't have to make a subtree push, instead we can just switch to the frontend folder and run the `vercel` command to deploy:
```sh
cd frontend
vercel
```This will lead you through the setup guide for your frontend application. Afterwards the app should be successfully deployed.
**Make sure**, you add the Backend API endpoint as a production environmental variable on Vercel.com.
**Make sure**, you add a custom domain for your frontend (that ideally matches the domain which you have specified in your backend environmental variables 😉)
## About
Konstantin Münster – [konstantin.digital](https://konstantin.digital)
Distributed under the [MIT](http://showalicense.com/?fullname=Konstantin+M%C3%BCnster&year=2019#license-mit) license.
See `LICENSE` for more information.[https://github.com/konstantinmuenster](https://github.com/konstantinmuenster)