• Stars
    star
    2,921
  • Rank 15,527 (Top 0.4 %)
  • Language
    JavaScript
  • Created about 4 years ago
  • Updated about 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Edit Notes like in Notion.so. Full-Stack App using React/Express.

📓 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 yet, I highly recommend to check it out!

📌 Live Demo: notion-clone.kmuenster.com

📌 Medium Article: How To Build A Text Editor Like Notion


notion clone screenshot


Features

  • Slash Commands (Type / to turn the block into different content types)
  • HTML Support (Use regular HTML tags like <a> 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

     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 <[email protected]>"
    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)

    cd backend
    npm install
    npm start
  4. Install and run frontend (http://localhost:3000)

    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 and the backend on 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.

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, 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, 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:

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

Buy Me A Coffee

Konstantin Münster – konstantin.digital

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

https://github.com/konstantinmuenster

More Repositories

1

gatsby-starter-portfolio-minimal

A Gatsby Starter to create a clean one-page portfolio with Markdown content.
JavaScript
202
star
2

gatsby-theme-portfolio-minimal

A Gatsby Theme to create modern one-page portfolios with a clean yet expressive design.
TypeScript
157
star
3

gatsby-starter-portfolio-minimal-theme

A Gatsby Starter Project to get started with the Portfolio Minimal Theme.
JavaScript
142
star
4

lexical-rich-text-react-demo

A simple wysiwyg / rich text editor built with Lexical and React.
TypeScript
55
star
5

simple-react-js-weather-app

A simple weather app that allows you to get current weather information, based on the city you enter.
JavaScript
54
star
6

lexical-examples

The missing examples library for lexical.dev
TypeScript
38
star
7

lexical-floating-menu

Designed for @lexical/react. Headless & fully-customizable.
TypeScript
33
star
8

gatsby-portfolio

Portfolio / Personal Website - Built with Gatsby.js and Published at konstantin.digital
JavaScript
32
star
9

graphql-weather-api

A GraphQL wrapper for the Open Weather Map API
JavaScript
31
star
10

portfolio-next

MDX
12
star
11

lexical-react-floating-menu

TypeScript
10
star
12

konstantin.digital

My personal portfolio, built with Next.js App Router.
TypeScript
9
star
13

strapi-plugin-rich-text

A WYSIWYG editor for your rich text fields
TypeScript
7
star
14

a-distraction-free-youtube-clone

A simple YouTube clone, powered by the YouTube Data API v3. Built with React.
JavaScript
5
star
15

service-worker-side-templating-app

Service Worker Rendering with Handlebars.js
JavaScript
4
star
16

how-to-gatsby-portfolio

JavaScript
4
star
17

next-js-blog-with-vercel-og-image

TypeScript
2
star
18

next-12-image-component-demo

TypeScript
1
star