useToggleTodo Hook
In this lesson, we create a hook to toggle a ToDo item.
We'll cover the following
useToggleTodo
This hook is to toggle the completed
flag of an item.
// ./hooks/useToggleTodo.js
import { useCallback } from 'react';
import { useSetDraft } from '../store';
export const useToggleTodo = () => {
const setDraft = useSetDraft();
return useCallback(
id => {
setDraft(draft => {
const todo = draft.todos.find(todo => todo.id === id);
if (todo) todo.completed = !todo.completed;
});
},
[setDraft],
);
};
Initially todo.completed
is undefined
, but once it’s toggled it will be true
, and false
/ true
thereafter.
This hook can also be implemented without mutations. The immutable version is the following:
setDraft(draft => ({ ...draft, todos: draft.todos.map(todo => (todo.id === id ? { ...todo, completed: !todo.completed } : todo)) }));
This might be a bit tricky if you aren’t used to immutable updates.
Next
In the next lesson, we learn about another hook useQuery
.
Get hands-on with 1400+ tech skills courses.