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.
π Live Demo Β· β‘ Quick Start Β· π€ Contribute Β· πΈ Screenshots
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 currently configured for the deployed frontend inbackend/src/server.js.
When running the frontend locally onhttp://localhost:5173, update the CORS origin temporarily for local development.Change this:
origin: "https://dailyforge-frontend-lhjq.onrender.com"to:
origin: "http://localhost:5173"before starting the backend server.
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, copyfrontend/.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 .env
Running locally? Update VITE_API_URL in your local .env file to http://localhost:5000/api/.
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 hands |
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
Have questions, ideas, or want to connect with other contributors?
| Channel | Link |
|---|---|
| π§ Email | 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!



