DailyForge is an open-source fullstack MERN productivity app that lets you design, manage, and visualize your weekly routines — with drag-and-drop scheduling, a smart task library, and overlap protection built right in.
- 🚀 Project Overview
- 🌐 Live Demo
- ✨ Features
- 🏗 Tech Stack
- 📂 Project Structure
- ⚡ Quick Start
- 🔐 Environment Variables
- 🌐 Google Authentication Setup
- ❓ FAQ
- 🛠 Troubleshooting
- 🤝 Contribution Guidelines
- 🏷 Issue Guidelines
- 📸 Screenshots
- 📬 Getting Help
- 📬 Contact & Community
Most productivity tools are either too bloated or too simple. DailyForge is a no-nonsense weekly planner that gives you total control over your schedule — built by students, for students and professionals alike.
What it does:
- Build a reusable task library with custom durations, colors, and categories
- Design weekly routines by dragging tasks into a visual time grid
- Save, update, and delete routines with one click
- Automatically detects and prevents scheduling conflicts for the same day
Why it matters:
Most people don't fail to plan — they fail to stick to a plan. DailyForge makes routines feel visual and deliberate, making habits easier to build and track.
Key highlights:
- ⚡ Drag-and-drop weekly planner powered by
@dnd-kit - 🔒 Secure JWT authentication with bcrypt password hashing
- 🗂️ Reusable routine templates to clone and reuse schedules
- 🚫 Conflict detection — no overlapping tasks on the same day
- 📱 Clean, responsive UI built with React 19 + Tailwind CSS v4
| Service | URL |
|---|---|
| 🖥️ Frontend | https://dailyforge-frontend-lhjq.onrender.com |
| ⚙️ Backend API | https://dailyforge-backend.onrender.com |
⚠️ Deployed on Render's free tier — first load may take 30–60 seconds to spin up.
- Signup / Login with JWT-based session management
- Protected routes — unauthenticated users are redirected to login
- Passwords hashed with bcrypt
- Create tasks with: title, duration, color, and category
- Edit and delete tasks from your personal task library
- Tasks persist across sessions
- Drag tasks from your library onto a 7-day weekly grid
- Time-slot-based placement with visual feedback
- Overlap detection prevents conflicting task placement on the same day
- View all saved routines at a glance
- Quick access to edit or delete any routine
- Summary stats for your weekly schedule
- Save any routine as a reusable template
- Re-apply templates to any week in seconds
| Technology | Purpose |
|---|---|
| React 19 | UI framework |
| Vite | Build tool & dev server |
| Tailwind CSS v4 | Utility-first styling |
@dnd-kit/core |
Drag-and-drop interactions |
| Axios | HTTP client for API calls |
| React Router DOM v7 | Client-side routing |
| Lucide React | Icon library |
| Context API | Global auth state management |
| Technology | Purpose |
|---|---|
| Node.js | Runtime environment |
| Express.js v5 | REST API framework |
| MongoDB Atlas | Cloud database |
| Mongoose v9 | ODM for MongoDB |
| JSON Web Token (JWT) | Stateless authentication |
| Bcrypt | Password hashing |
| dotenv | Environment variable management |
| Nodemon | Dev server with hot-reload |
DailyForge/
│
├── backend/
│ ├── config/ # DB connection config
│ ├── controllers/
│ │ ├── authController.js # Signup, login logic
│ │ ├── routineController.js
│ │ └── taskController.js
│ ├── middlewares/
│ │ └── authMiddleware.js # JWT verification
│ ├── routes/
│ │ ├── authRoutes.js
│ │ ├── routineRoutes.js
│ │ └── taskRoutes.js
│ ├── src/
│ │ ├── models/ # Mongoose schemas
│ │ │ ├── User.model.js
│ │ │ ├── Task.model.js
│ │ │ └── Routine.model.js
│ │ └── server.js # Express app entry point
│ ├── .env # ← You create this (see below)
│ └── package.json
│
└── frontend/
├── public/
├── src/
│ ├── api/
│ │ └── axiosConfig.js # Axios base URL config
│ ├── components/
│ │ ├── Dashboard/
│ │ ├── Routine/
│ │ ├── Task/
│ │ ├── Navbar.jsx
│ │ └── ProtectedRoutes.jsx
│ ├── context/
│ │ └── AuthContext.jsx
│ ├── hooks/
│ │ └── useTasks.js
│ ├── pages/
│ │ ├── Dashboard.jsx
│ │ ├── RoutineBuilder.jsx
│ │ ├── Tasks.jsx
│ │ ├── Login.jsx
│ │ └── Signup.jsx
│ ├── utils/
│ ├── App.jsx
│ └── main.jsx
├── index.html
├── vite.config.js
└── package.json
Prerequisites: Node.js v18+, npm v9+, a free MongoDB Atlas account
git clone https://github.com/aryandas2911/DailyForge.git
cd DailyForgecd backend
npm installCreate your .env file from the given template (see the Environment Variables section below):
# Inside the /backend directory
cp .env.example .env Then fill in your values (see the next section for what each variable means).
⚠️ Local dev note: The backend CORS origin is already configured for both the deployed frontend (https://dailyforge-frontend-lhjq.onrender.com) and local development (http://localhost:5173) inbackend/src/server.js. No changes are needed for local development.
Start the backend dev server:
npm run dev✅ Server should start at
http://localhost:5000
Open a new terminal, then:
cd frontend
npm install💡 Local dev note: To point the frontend to your local backend, copy
frontend/.env.exampletofrontend/.envand ensureVITE_API_URLis set tohttp://localhost:5000/api.
Start the frontend dev server:
npm run dev✅ App should open at
http://localhost:5173
Open http://localhost:5173, sign up for an account, and start building your routines.
Copy the provided template to get started. Never commit the .env to git.
PORT=5000
MONGO_URI=your_mongodb_atlas_connection_string
JWT_SECRET=your_super_secret_key_here
#CLIENT_ORIGIN=your_deployed_frontend_url| Variable | Required | Description |
|---|---|---|
PORT |
✅ | Port on which the Express server runs (default: 5000) |
MONGO_URI |
✅ | Full MongoDB Atlas connection string — get it from your Atlas cluster's "Connect" menu |
JWT_SECRET |
✅ | Secret key for signing JWTs — use any long, random string (e.g., openssl rand -hex 32) |
CLIENT_ORIGIN |
⬜ | (Optional) Allowed CORS origin for API requests. Set this to your production frontend URL (e.g., https://dailyforge-frontend-lhjq.onrender.com). If not set, it defaults to http://localhost:5173 for local development. |
How to get MONGO_URI:
- Log into MongoDB Atlas
- Create a free M0 cluster (if you haven't)
- Click Connect → Connect your application → Copy the connection string
- Replace
<password>with your DB user's password
Copy the provided .env.example to a new file named .env.
Running locally? Update VITE_API_URL in your local .env file to http://localhost:5000/api/.
| Issue | Common Cause | Quick Fix |
|---|---|---|
| CORS Errors | FRONTEND_URL mismatch in backend .env. |
Match it to your local frontend URL exactly (e.g., http://localhost:5173). Restart server. |
| Database Failures | Incorrect credentials or IP restriction. | Replace <password> with your database user password. Whitelist 0.0.0.0/0 in Atlas Network Access. |
| Dependency Conflicts | React 19 / Tailwind v4 version strictness. | Run npm install --legacy-peer-deps in both directories. |
| Glitchy Drag-and-Drop | DOM-altering browser extensions. | Test the application in an Incognito window. |
DailyForge supports Google Authentication via Firebase. Follow these steps to configure and enable Google Sign-In:
- Go to the Firebase Console and click Add project to create a new project.
- Once the project is created, click the Web icon (
</>) on the Project Overview page to register a new Web App. - Copy the
firebaseConfigobject containing the API key, app ID, etc. - Go to Build → Authentication in the left sidebar and click Get Started.
- Under the Sign-in method tab, click Add new provider and select Google.
- Enable the provider, configure your support email, and click Save.
To enable the frontend and backend integration, copy the configuration values into your respective .env files:
Append your Firebase client configuration to your local .env file:
# Firebase Client configuration
VITE_FIREBASE_API_KEY=your_api_key
VITE_FIREBASE_AUTH_DOMAIN=your_auth_domain
VITE_FIREBASE_PROJECT_ID=your_project_id
VITE_FIREBASE_STORAGE_BUCKET=your_storage_bucket
VITE_FIREBASE_MESSAGING_SENDER_ID=your_messaging_sender_id
VITE_FIREBASE_APP_ID=your_app_idAdd your Firebase Project ID to secure RS256 token verification:
# Firebase verification configuration
FIREBASE_PROJECT_ID=your_project_idThe project is deployed on Render’s free tier. Services may go to sleep after inactivity, so the first request can take around 30–60 seconds to respond.
Recommended versions:
- Node.js
v18+ - npm
v9+
Check your installed versions:
node -v
npm -vNo. DailyForge uses MongoDB Atlas, so you only need a free Atlas account and a valid connection string.
Make sure:
- Backend CORS origin is set to:
origin: "http://localhost:5173"- Frontend
.envcontains:
VITE_API_URL=http://localhost:5000/apiBackend variables go inside:
/backend/.envFrontend variables go inside:
/frontend/.env| Issue | Common Cause | Quick Fix |
|---|---|---|
| CORS Errors | CLIENT_ORIGIN or FRONTEND_URL mismatch in backend .env. |
Ensure backend .env has correct origin (e.g., http://localhost:5173). Restart the server after changes. |
| MongoDB Connection Error | Incorrect MONGO_URI, wrong credentials, or IP not whitelisted. |
Verify MONGO_URI, replace <password> with correct DB password, and whitelist 0.0.0.0/0 in MongoDB Atlas Network Access. |
| Frontend Cannot Connect to Backend | Backend not running, wrong API URL, or port mismatch. | Set VITE_API_URL=http://localhost:5000/api and ensure backend is running on http://localhost:5000. |
| JWT Authentication Errors | Missing or incorrect JWT_SECRET. |
Add JWT_SECRET in backend/.env and restart the backend server. |
| Dependency Conflicts | React 19 / Tailwind v4 strict peer dependency issues. | Run npm install --legacy-peer-deps in both frontend and backend directories. |
| Glitchy Drag-and-Drop | Browser extensions interfering with DOM events. | Test the app in Incognito mode or disable extensions. |
| Port Already in Use | Another process is using the same port. | Stop the running process or change PORT in .env (e.g., PORT=5001). |
| Dependency Installation Issues | Corrupted node_modules or lock file conflicts. |
Run rm -rf node_modules package-lock.json && npm install. |
We love contributions! DailyForge is actively participating in GSSoC 2026 and welcomes contributors of all experience levels.
📄 Read the full guidelines: CONTRIBUTING.md
1. Pick an issue
- Browse open issues
- Look for
good first issueif you're new - Comment on the issue to get it assigned before starting work
2. Fork & branch
git clone https://github.com/<your-username>/DailyForge.git
cd DailyForge
git checkout -b <type>/<short-description>Branch naming convention:
| Type | Example |
|---|---|
| New feature | feature/add-dark-mode |
| Bug fix | fix/login-redirect-loop |
| Documentation | docs/update-readme |
| Refactor | refactor/task-hook-cleanup |
3. Make your changes
- Keep changes focused — one issue per PR
- Follow the existing code style
- Test your changes locally before pushing
4. Open a Pull Request
- Fill out the PR template completely
- Link the issue it resolves using
Closes #<issue-number> - Request a review from a maintainer
⚠️ PRs without a linked issue or description will not be reviewed.
We use labels to organize work. Here's what they mean:
| Label | Meaning |
|---|---|
good first issue |
Small, well-scoped tasks — perfect for first-time contributors |
bug |
Something is broken or behaving incorrectly |
feature |
New functionality to be added |
documentation |
Improvements to README, guides, or inline comments |
help wanted |
Maintainers need external input or assistance |
testing |
Adding or improving test coverage |
Tips for new contributors:
- Start with
good first issue— they're designed to be approachable - Don't hesitate to ask questions in the issue comments
- One issue at a time — don't take on multiple issues until your first PR is merged
Need help with setup or contributing?
- Open a GitHub Issue
- Comment on an existing issue for clarification
- Contact the maintainer through the email provided below
- Read the setup instructions carefully
- Check the FAQ and Troubleshooting sections
- Search existing GitHub issues first
We welcome contributors of all experience levels 🚀
Have questions, ideas, or want to connect with other contributors?
| Channel | Link |
|---|---|
| aryandas2911@gmail.com | |
| 🐛 Issues | GitHub Issues |
Built with ❤️ for GSSoC 2026
If DailyForge helped you, consider giving it a ⭐ — it helps more contributors find the project!



