Skip to content

Instantly share code, notes, and snippets.

@kaineer
Created March 4, 2025 10:58
Show Gist options
  • Save kaineer/dbc5f18d9b49a6b57352923c7d28a13f to your computer and use it in GitHub Desktop.
Save kaineer/dbc5f18d9b49a6b57352923c7d28a13f to your computer and use it in GitHub Desktop.
main-component
//
import { useState, useEffect } from 'react';
import { useSelector, useDispatch } from 'react-redux';
import { NewTask } from './NewTask'
import { TaskList } from './TaskList'
import { TodosSlice } from '../../slices/todo';
export const Todos = () => {
const {
selectors: { getTasks },
actions: { setTasks },
} = TodosSlice;
const dispatch = useDispatch();
const tasks = useSelector(getTasks);
useEffect(() => {
if (!tasks || tasks.length < 1) {
fetch('http://localhost:3000/tasks').
then((resp) => resp.json()).
then((data) => dispatch(setTasks(tasks)));
}
}, []);
return (
<>
<NewTask />
<TaskList />
</>
)
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment