Skip to content
This repository has been archived by the owner on May 31, 2021. It is now read-only.

A small library that allows React components to share state with an easy to use Hook.

License

Notifications You must be signed in to change notification settings

pmk1c/react-connected-reducers

Repository files navigation

react-connected-reducers

Version Downloads Build Status

react-connected-reducers extends the useReducer Hook to allow for components to share their reducer state with each other. If your are not familiar with Hooks or the useReducer Hook you should take a look at their introduction and the documentation for state hooks. For now this library is an experiment, that tries to enable React developers to connect components more easily, without having to rely on Redux or other state management frameworks.

Getting started

Install

$ npm install --save react-connected-reducers

Usage Example

import { ConnectedProvider, useConnectedReducer } from 'react-connected-reducer'

function useTodosReducer () {
  return useConnectedReducer('todos', (state, action) => {
    const { type, payload } = action;

    if (type === 'add') {
      return [...state, payload]
    }

    return state;
  }, [])
}

function TodoList () {
  const [todos] = useTodosReducer()

  return (
    <ul>
      {todos.map(todo => (
        <li>{todo}</li>
      ))}
    </ul>
  )
}

function TodoForm () {
  const [, dispatch] = useTodosReducer()

  let todoEl = useRef(null)

  const addTodo = e => {
    e.preventDefault()
    if (todoEl.current) {
      dispatch({ type: 'add', payload: todoEl.current.value })
      todoEl.current.value = ''
    }
  }

  return (
    <form onSubmit={addTodo}>
      <input ref={todoEl} type="text" />
      <button type="submit">Add todo</button>
    </form>
  )

  function App () {
    return (
      <ConnectedProvider>
        <TodoList />
        <TodoForm />
      </ConnectedProvider>
    )
  }
}

This example shows that useConnectedReducer works almost exactly like useReducer, with two differences:

  1. useConnectedReducer takes three arguments instead of two. The first one is the namespace, which is just a string. This namespace has to be unique through your whole application.

  2. We wrapped all elements in a ConnectedProvider. This component provides the state for all of our namespaces. Components using connected reducers need to be ancestors (not direct children) of a ConnectedProvider. To debug the state of your namespaces you can find them in this component i.e. using React Dev Tools.

That's all. Your are now ready to connect your components at ease!

API

useConnectedReducer(namespace, reducer, initialState) : [state, dispatch]

Parameters

namespace : string

Namespace for this reducer, unique through your whole application.

reducer : (state, action) => state

Function that takes a state and an action and returns a new state.

initialState : state

The inital state for the reducer.

Returns

state : state

The current state of the reducer.

dispatch : action => void

Use this function to run an action through this reducer.

Alternatives

  • Hookleton takes a more generalistic approach by providing a way to create hooks and store their logic and return values in memory to share it between components.

About

A small library that allows React components to share state with an easy to use Hook.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published