Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
49 changes: 49 additions & 0 deletions backend/controllers/todoController.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
const Todo = require("../models/todoModel");

exports.getTodos = (req, res) => {
res.json(Todo.getAll());
};

exports.getTodoById = (req, res) => {
const { id } = req.params;
const todo = Todo.getById(id);

if (!todo) {
return res.status(404).json({ message: "Todo not found" });
}

res.json(todo);
};

exports.createTodo = (req, res) => {
const { title } = req.body;

if (!title) {
return res.status(400).json({ message: "Title is required" });
}

const newTodo = Todo.create(req.body);
res.status(201).json(newTodo);
};

exports.updateTodo = (req, res) => {
const { id } = req.params;
const updated = Todo.update(id, req.body);

if (!updated) {
return res.status(404).json({ message: "Todo not found" });
}

res.json(updated);
};

exports.deleteTodo = (req, res) => {
const { id } = req.params;
const deleted = Todo.remove(id);

if (!deleted) {
return res.status(404).json({ message: "Todo not found" });
}

res.json(deleted);
};
8 changes: 4 additions & 4 deletions backend/index.js
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
const express = require("express");
const app = express();
const PORT = process.env.PORT || 4000;
const todoRoutes = require('./routes/todoRoutes');

// Basic route
app.get("/", (req, res) => {
res.send("Hello from Express!");
});
app.use(express.json());

app.use('/api/todos', todoRoutes);

// Start server
app.listen(PORT, () => {
Expand Down
63 changes: 63 additions & 0 deletions backend/models/todoModel.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
let todos = [
{
id: 1,
title: "Todo Number One",
completed: false,
createdAt: new Date("2026-02-15"),
},
{
id: 2,
title: "Number Two Todo",
completed: true,
createdAt: new Date("2026-02-16"),
},
{
id: 3,
title: "Third Todo",
completed: false,
createdAt: new Date("2026-02-17"),
},
];

let currentId = 1;

const getAll = () => todos;

const getById = (id) => todos.find((t) => t.id === id);

const create = (data) => {
const newTodo = {
id: currentId++,
title: data.title,
completed: data.completed ?? false,
createdAt: new Date(),
};

todos.push(newTodo);
return newTodo;
};

const update = (id, data) => {
const todo = getById(id);
if (!todo) return null;

if (data.title !== undefined) todo.title = data.title;
if (data.completed !== undefined) todo.completed = data.completed;

return todo;
};

const remove = (id) => {
const index = todos.findIndex((t) => t.id === id);
if (index === -1) return null;

return todos.splice(index, 1)[0];
};

module.exports = {
getAll,
getById,
create,
update,
remove,
};
9 changes: 7 additions & 2 deletions backend/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,11 @@
"start": "node index.js"
},
"dependencies": {
"express": "^4.18.2"
}
"express": "^4.22.1"
},
"main": "index.js",
"keywords": [],
"author": "",
"license": "ISC",
"description": ""
}
11 changes: 11 additions & 0 deletions backend/routes/todoRoutes.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
const express = require("express");
const router = express.Router();
const todoController = require("../controllers/todoController");

router.get("/", todoController.getTodos);
router.get("/:id", todoController.getTodoById);
router.post("/", todoController.createTodo);
router.put("/:id", todoController.updateTodo);
router.delete("/:id", todoController.deleteTodo);

module.exports = router;
72 changes: 29 additions & 43 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.