Skip to content

itaysmalia/redux-by-levels

Repository files navigation

redux-by-levels

Manage redux state with levels, based on context API.

NPM JavaScript Style Guide itaysmalia

go to the npm page

Install

npm i redux react-redux redux-by-levels

Quick start

npx create-react-app --template redux-by-levels

Usage

full docs at docs.md

// store.js

import { createStore } from 'redux'
import { getRBLReducer } from 'redux-by-levels'

const initialState = { count: 0, name: 'foo' }

const store = createStore(getRBLReducer(initialState))

export default store
// App.js
import React from 'react'
import { Provider } from 'react-redux'
import { RBLProvider } from 'redux-by-levels'

import store from './store'
import Count from './count'
import Name from './name'

function App(){
  return (
    <Provider store={store}>
        <RBLProvider level="count">
            <Count />
        </RBLProvider>
        <RBLProvider level="name">
            <Name />
        </RBLProvider>
    </Provider>
  )
}

export default App
// count.js
import React from 'react';
import { useRBLState } from 'redux-by-levels'

function Count() {
  const [count, setCount] = useRBLState()
  return <button onClick={() => setCount(count + 1)}>count - {count}</button>
}

export default Count
// name.js
import React from 'react'
import { useRBLState } from 'redux-by-levels'

const Name = () => {
  const [name, setName] = useRBLState()
  return (
    <div>
      <input
        defaultValue={name}
        onChange={({ target: { value } }) => setName(value)}
      />
      <h3>name - {name}</h3>
    </div>
  )
}

export default Name

License

MIT © itaysmalia

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published