This is a fullstack collaborative note-taking application designed for real-time note sharing and editing, utilizing Vue.js for the frontend, NestJS for the backend, and PostgreSQL as the database. The application allows users to create, edit, and share notes with others in real time, with changes reflected immediately across shared users. The app includes rich-text editing capabilities using Quill Editor, enabling users to format text (e.g., bold, italic, and colored text). Notes can also be organized, deleted, and shared with other users, and the application ensures smooth real-time collaboration via WebSockets.
Real-Time Note Collaboration : Users can edit notes in real time, with changes reflected for all shared users instantly.
Rich Text Editor : Supports bold, italic, underline, color formatting, and more, using the Quill Editor.
Note Sharing : Users can share notes with others, allowing multiple collaborators to edit and view notes simultaneously.
Real-Time Updates : Notes are updated and shared in real time using WebSockets.
Authentication & Authorization : JWT-based authentication ensures secure login, user sessions, and permission management.
Responsive Design : Fully optimized for desktop and mobile devices.
Database Management : PostgreSQL is used as the main database to store users, notes, and shared note relationships, with optional PgAdmin support for database management.
link to demo https://main--celadon-creponne-5a20ab.netlify.app/ (ps:Backend deployed on Render Free Trial , Keep Shuting Down after 50min , with no request)
- Technologies Used
- Getting Started
- Project Structure
- Available Scripts
- Environment Variables
- Docker Services
- Managing PostgreSQL with PgAdmin
- Frontend: Vue.js
- Backend: NestJS
- Database: PostgreSQL
- Database Management: PgAdmin
- ORM: Prisma
- Docker: For containerizing services
You can run this project either in a traditional way by cloning the repository and installing the dependencies or by using Docker for containerized development.
git clone <repository-url>
cd <project-directory>
git submodule update --init --recursive
Frontend (Vue.js)
cd Client
npm install
Backend (NestJS)
cd Server
npm install
To run the NestJS backend locally (without Docker):
npm run dev
To build and run the backend:
npm run build
npm run start
To run the Vue.js frontend locally:
npm run dev
To build the frontend for production:
npm run build
You can run the entire application stack (frontend, backend, PostgreSQL, PgAdmin) using Docker Compose.
Create a .env file in the root directory for both backend and frontend and define the required variables. Here’s an example for the backend:
POSTGRES_USER=postgres
POSTGRES_PASSWORD=yourpassword
POSTGRES_DB=yourdatabase
DATABASE_URL=postgresql://postgres:yourpassword@db:5432/yourdatabase
PGADMIN_DEFAULT_EMAIL=admin@admin.com
PGADMIN_DEFAULT_PASSWORD=admin
In the root directory of your project, run the following command to start all services:
docker-compose up --build
This will start the following services:
- PostgreSQL database
- PgAdmin (optional, for database management)
- NestJS backend (exposed on port 3000)
- Vue.js frontend (exposed on port 5173)
You can access the frontend by navigating to http://localhost:5173, the backend at http://localhost:3000, and PgAdmin at http://localhost:5050.
To stop the running services, use:
docker-compose down
├── Client # Vue.js frontend
│ ├── src # Frontend source code
│ ├── public # Public files
│ ├── Dockerfile # Frontend Dockerfile
│ └── package.json # Frontend dependencies
├── Server # NestJS backend
│ ├── src # Backend source code
│ ├── prisma # Prisma schema and migrations
│ ├── Dockerfile # Backend Dockerfile
│ └── package.json # Backend dependencies
├── docker-compose.yml # Docker Compose configuration
└── README.md # This file
The following services are included in the docker-compose.yml file:
- db : PostgreSQL database service.
- pgadmin : PgAdmin service for managing the database.
- backend : NestJS backend service.
- frontend : Vue.js frontend service.
PostgreSQL has a built-in health check using pg_isready to ensure the service is running correctly.
If you prefer to manage the PostgreSQL database via a graphical interface, you can use PgAdmin. It is accessible at http://localhost:5050 with the default credentials set in your .env file:
- Email: admin@admin.com
- Password: admin
You can add the PostgreSQL database to PgAdmin using the following credentials:
- Host:db
- Port:5432
- Username:POSTGRES_USER (from .env)
- Password:POSTGRES_PASSWORD (from .env)