0.2.0 • Published 5 years ago
@21epub/react-rxjs-store v0.2.0
@21epub/react-rxjs-store
Rxjs store for react state management
Intro
This package only provide an opt for tiny or medium react state management . Not replace the
reduxorcontext reducerecosystem.
For react > 16.8.0
A solution for react state management .
Store state can be acquired anywhere through store.getState() synchronously.
Provide useRxjsStore Hooks for Components State Usage.
Features
- Easy-to-use
- Fully TypeScript
- No contextorreducerrequired
- Immutable by immer
- Async state flow by rxjs
Install
npm install --save @21epub/react-rxjs-storeUsage
// store.ts : Store Definition
import RxjsStore, { RxjsStoreReducerParams } from '@21epub/react-rxjs-store'
interface State {
  count: number
}
//Reducers Types definition (Recommanded)
interface Reducers<S> extends RxjsStoreReducerParams<S> {
  increment: (state: S, payload: number) => S
  decrement: (state: S, payload?: number) => S
}
const initState: State = {
  count: 0
}
const reducers: Reducers<State> = {
  // Sync state management
  increment(state, payload = 1) {
    return { ...state, count: state.count + payload }
  },
  decrement(state, payload = 1) {
    return { ...state, count: state.count - payload }
  }
}
export default new RxjsStore<State, Reducers<State>>(initState, reducers)// Component.tsx : Component Hooks Usage
import React from 'react'
import store from './store'
const Component = () => {
  const [state] = store.useRxjsStore()
  const increment = () => {
    store.reducers.increment(100)
  }
  const decrement = () => {
    store.reducers.decrement(100)
  }
  return (
    <>
      <div>Create React TS Parcel Library Example 😄</div>
      <div>Count: {state.count}</div>
      <button onClick={increment}>increment</button>
      <button onClick={decrement}>decrement</button>
    </>
  )
}
export default Component// otherUtil.ts : subscribe to store state change
import store from './store'
store.observable$.subscribe( nextState => {
  console.log(nextState)
  ...
})For Details: See Example
Developing and running on localhost
First install dependencies and then install peerDeps for parcel dev:
npm install
npm run install-peersTo run Example in hot module reloading mode:
npm startTo create a parcel production build:
npm run build-prodTo create a bundle library module build:
npm run buildRunning
Open the file dist/index.html in your browser
Testing
To run unit tests:
npm testLicense
MIT © garryguzy