Skip to content

Example of application with state management using Context API, Multiples Providers, Immer and embedded cache.

Notifications You must be signed in to change notification settings

wagnercsfilho/react-context-api-store

Folders and files

NameName
Last commit message
Last commit date

Latest commit

52b84a0 · Jul 13, 2020

History

15 Commits
Jul 13, 2020
Jul 13, 2020
Jul 13, 2020
Jul 13, 2020
Jul 13, 2020

Repository files navigation

Example of application with state management using Context API, Multiples Providers, Immer and embedded cache.

You can view a live demo over at https://codesandbox.io/s/github/wagnercsfilho/react-context-api-store

Create a Store

const TodoStore = Store(() => ({
  todos: [],
  add(description) {
    this.todos.push({
      id: new Date().getTime(),
      description,
      done: false,
    });
  },
  toogle(id) {
    const index = this.todos.findIndex((t) => t.id === id);
    this.todos[index].done = !this.todos[index].done;
  },
}));

Pass the Store to Provider

function App() {
  return (
    <StoreProvider stores={{ TodoStore }}>
      <TodoList />
    </StoreProvider>
  );
}

Get store using useStore hook

const TodoList = () => {
  const store = useStore("TodoStore");

  const toogle = useCallback((id) => {
    store.toogle(id);
  }, []);

  return store.todos.map((todo) => (
    <TodoItem key={todo.id} todo={todo} toogle={toogle} />
  ));
};

Use react.memo to prevent unnecessary rendering

const TodoItem = React.memo(({ todo, toogle }) => {
  return (
    <div
      style={{ textDecoration: todo.done ? "line-through" : "none" }}
      onClick={() => toogle(todo.id)}
      key={todo.id}
    >
      {todo.description}
    </div>
  );
});

Add a new item

export const TodoForm = () => {
  const store = useStore("TodoStore");
  const [description, setDescription] = useState("");

  const addTodo = () => {
    store.add(description);
    setDescription("");
  };

  return (
    <>
      <input
        value={description}
        onChange={(e) => setDescription(e.target.value)}
        placeholder="Write a description..."
      />
      <button disabled={!description} onClick={addTodo}>
        ADD TODO
      </button>
    </>
  );
};

Running locally:

Clone this repo npm install to install all req'd dependencies npm start to start the local server (this project uses create-react-app)

About

Example of application with state management using Context API, Multiples Providers, Immer and embedded cache.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published