Deployed Link: https://notion-clone-hazel.vercel.app/
deploy commands:
deploy DB(Convex):
> npx convex dev
deploy App (dev):
> vercel
deploy App (prod):
>vercel --prod
Uses @BlockNote see https://www.blocknotejs.org/pricing
Forked from: https://github.com/JyotiranjanGhibila/notion-clone
Welcome to the Notion Clone project, a connected workspace where your ideas, documents, and plans come together for better, faster work. This project aims to replicate the functionalities of Notion using a modern tech stack.
- Unified Workspace: Manage your ideas, documents, and plans all in one place.
- Rich Text Editing: Create content with a variety of formatting options.
- Flexible Organization: Customize and organize your workspace to suit your needs.
- GitHub and Google Login: Securely log in using your GitHub or Google account.
- User Avatar: Display the user's avatar in the navbar upon successful login.
- Private Route: Access the
enterNotion
route for a private workspace after login. - Search: Easily find notes and documents using the search functionality.
- Add Note: Create new notes with dynamic nested structures.
- User Settings: Customize your workspace settings as needed.
- Trash Page: Safely delete and restore notes from the trash.
- Dynamic Notes: Create dynamic notes with nested structures.
- Icon and Banner: Add icons and banners to notes with advanced file storage using Edge Store.
- Advanced File Storage: Efficiently manage file storage for icons and banners.
The Publish
component is a powerful feature that enhances collaboration by allowing users to share specific notes with others while providing control over their visibility. It seamlessly integrates into your note components, providing a straightforward way to make your content accessible on the web.
-
Publish: Share your notes with a wider audience by making them live on the web. This feature is perfect for showcasing your work, collaborating with team members, or sharing information with others.
-
Unpublish: Maintain control over your content accessibility. When you no longer want a note to be public, simply use the "Unpublish" feature to disable access. This is useful for maintaining privacy or restricting access after sharing.
-
Copy URL: Share your live note effortlessly by copying its URL. The "Copy URL" feature streamlines the process of sharing your content with others, ensuring quick and easy dissemination.
-
Status Indicator: Stay informed about the publication status of your notes through a visual indicator. Whether a note is published or unpublished, the
Publish
component provides a clear status indicator for at-a-glance awareness.
- UseHooks-ts: Leverage a collection of custom React hooks written in TypeScript for enhanced functionality.
First, run the development server:
npm run dev
# or
yarn dev
# or
pnpm dev
# or
bun dev
# backend for local
npx convex dev
Open http://localhost:3000 with your browser to see the result.
You can start editing the page by modifying app/page.tsx
. The page auto-updates as you edit the file.
This project uses next/font
to automatically optimize and load Inter, a custom Google Font.
To learn more about Next.js, take a look at the following resources:
- Next.js Documentation - learn about Next.js features and API.
- Learn Next.js - an interactive Next.js tutorial.
You can check out the Next.js GitHub repository - your feedback and contributions are welcome!
The easiest way to deploy your Next.js app is to use the Vercel Platform from the creators of Next.js.
Check out our Next.js deployment documentation for more details.