This project is a Content Management System for signage displays built with Next.js, Fabric.js, Cloudinary, MongoDB, and Electron. The application supports real-time collaboration using WebSockets, offline functionalities, and cloud-based image uploads for efficient content management.
- Next.js: Framework for React with built-in SSR (Server-Side Rendering) and API routes.
- Fabric.js: Canvas library for managing and manipulating visual elements.
- Cloudinary: Cloud storage for image uploads and hosting.
- WebSockets: Real-time server communication for live updates.
- Electron: Desktop application wrapper for offline features.
- MongoDB: Database for storing canvas JSON data and metadata.
- Vercel: Deployment platform for the Next.js application.
The web app is deployed on Vercel: https://signage-content-web-app.vercel.app/
- Build a new canvas using Fabric.js.
- Add basic shapes, text, and images to the canvas.
- Save the canvas to the database.
- Displays the list of existing canvases.
- Features:
- Edit: Open a canvas for editing.
- Delete: Remove a canvas.
- Post: Publish a draft canvas.
- Renders an existing canvas for editing.
- Features:
- Modify shapes, text, and images.
- Save changes back to the database.
-
Clone the Repository:
git clone <repository-url> cd <repository-folder>
-
Install Dependencies: Ensure Node.js is installed (version 16+ recommended).
npm install
-
Set Up Environment Variables: Create a
.env.local
file in the root directory:MONGODB_URI=<Your MongoDB Connection String> CLOUDINARY_CLOUD_NAME=<Your Cloudinary Cloud Name> CLOUDINARY_API_KEY=<Your Cloudinary API Key> CLOUDINARY_API_SECRET=<Your Cloudinary API Secret>
-
Run the Next.js App: Start the development server for offline features:
npm run dev
The app will be available at http://localhost:3000.
- Ensure you have Node.js installed.
- Run the WebSocket server script:
By default, the WebSocket server listens on port
node ws-server.js
8080
. Make sure the port is open and available.
-
Install Electron: Ensure Electron is installed globally:
npm install -g electron
-
Build and Run the Electron App:
npm run electron
This command runs the Electron app locally, providing offline support for managing signage content.
To enable offline functionalities:
- The Electron app acts as a wrapper for the Next.js application.
- Canvas data can be saved locally and synchronized to MongoDB when online.
This project combines modern web technologies with offline desktop support, enabling dynamic content management for signage displays. Use the Vercel deployment for live production or the Electron app for offline use.
For any further questions, feel free to reach out or explore the deployed app: https://signage-content-web-app.vercel.app/. 🚀