diff --git a/src/components/header.tsx b/src/components/header.tsx index f012970f6..143e7d76a 100644 --- a/src/components/header.tsx +++ b/src/components/header.tsx @@ -1,11 +1,9 @@ -import React, { useContext, useEffect, useRef } from 'react'; +import React, { useContext } from 'react'; import { MyContext } from './state'; import { Todo } from '../Types/Todo'; export const Header = () => { - const { todos, setTodos, title, setTitle } = useContext(MyContext); - - const inputRef = useRef(null); + const { todos, setTodos, title, setTitle, inputRef } = useContext(MyContext); const isAllCompleted = todos.every((todo: Todo) => todo.completed); @@ -27,25 +25,6 @@ export const Header = () => { setTitle(''); } - useEffect(() => { - const savedTodos = localStorage.getItem('todos'); - - if (savedTodos) { - setTodos(JSON.parse(savedTodos)); - } - // eslint-disable-next-line react-hooks/exhaustive-deps - }, []); - - useEffect(() => { - localStorage.setItem('todos', JSON.stringify(todos)); - }, [todos]); - - useEffect(() => { - if (inputRef.current) { - inputRef.current.focus(); - } - }, [todos]); - return (
{todos.length > 0 ? ( diff --git a/src/components/state.tsx b/src/components/state.tsx index 0d45ba54e..880f685a2 100644 --- a/src/components/state.tsx +++ b/src/components/state.tsx @@ -1,5 +1,11 @@ /* eslint-disable @typescript-eslint/no-explicit-any */ -import React, { useState, createContext, ReactNode } from 'react'; +import React, { + useState, + createContext, + ReactNode, + useEffect, + useRef, +} from 'react'; import { Todo } from '../Types/Todo'; import { Filter } from '../Types/Filter'; @@ -19,6 +25,27 @@ export const MyProvider = ({ children }: MyProviderProps) => { setTodos(currentTodos => currentTodos.filter(todo => todo.id !== id)); } + useEffect(() => { + const savedTodos = localStorage.getItem('todos'); + + if (savedTodos) { + setTodos(JSON.parse(savedTodos)); + } + // eslint-disable-next-line react-hooks/exhaustive-deps + }, []); + + useEffect(() => { + localStorage.setItem('todos', JSON.stringify(todos)); + }, [todos]); + + const inputRef = useRef(null); + + useEffect(() => { + if (inputRef.current) { + inputRef.current.focus(); + } + }, [todos]); + return ( { editingTodoId, setEditingTodoId, deleteTodo, + inputRef, }} > {children}