Skip to content
This repository has been archived by the owner on Dec 15, 2019. It is now read-only.

Buffering redux-actions before dispatch them in the batch

License

Notifications You must be signed in to change notification settings

DScheglov/redux-batch-buffer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

redux-batch-buffer

Build Status Coverage Status

Buffering redux-actions before dispatch them in the batch.

redux-batch-buffer is a modular way to implement batching and buffering of redux actions.

Installation

npm install --save redux-batch-buffer
yarn add redux-batch-buffer

Usage

Creating store:

The redux-batch-buffer provides own combineReducers to be used in order to create a redux-store.

import { createStore, applyMiddleware } from 'redux';
import { combineReducers, arrayToBatch, actionsBuffer } from 'redux-batch-buffer/combine-reducers';


export const configureStore = (reducers, initialState = {}, middleweres) => createStore(
  combineReducers(reducers),
  initialState,
  applyMiddleware(arrayToBatch, ...middleweres, actionsBuffer)
);

In case when it is not accaptable to use overrided combineReduceres you could use High Ordered Reducer enableBatching is also provided by redux-batch-buffer:

import { createStore, combineReducers, applyMiddleware } from 'redux';
import { enableBatching, arrayToBatch, actionsBuffer } from 'redux-batch-buffer';


export const configureStore = (reducers, initialState = {}, middlewares) => createStore(
  enableBatching(combineReducers(reducer)),
  initialState,
  applyMiddleware(arrayToBatch, ...middlewares, actionsBuffer)
);

Dispatching actions:

The redux-batch-buffer provides three ways to dispatch actions in a batch:

  • explicitly create a batching-action and then dispatch it
  • call dispatch with an array of actions (such practice could be incompatible with some middlewers)
  • start buffering actions before they will be ready for dispatching and then flush buffer in order to proceed with state changes.

Creating the action batch expicitly:

import { batch } from 'redux-batch-buffer';

dispatch(batch([
  { type: 'FIRST' },
  { type: 'SECOND' },
  { type: 'THIRD' },
]));

or even in this way:

import { batch } from 'redux-batch-buffer';

dispatch(batch(
  { type: 'FIRST' },
  { type: 'SECOND' },
  { type: 'THIRD' },
));

Dispatching an array of actions:

dispatch([
  { type: 'FIRST' },
  { type: 'SECOND' },
  { type: 'THIRD' },
]);

Buffering the actions before batch dispatching:

import { startBuffering, flushBuffer } from 'redux-batch-buffer';

dispatch(startBuffering);

dispatch({ type: 'FIRST' });
dispatch({ type: 'SECOND' });
dispatch({ type: 'THIRD' });

dispatch(flushBuffer);

Some cases could require to not proceed with changes:

import { startBuffering, flushBuffer, destroyBuffer } from 'redux-batch-buffer';

dispatch(startBuffering);

dispatch({ type: 'FIRST' });
dispatch({ type: 'SECOND' });
dispatch({ type: 'THIRD' });

dispatch(isEverythingOk ? flushBuffer : destroyBuffer);

Middleware composition

The redux-batch-buffer is a modular. It means that you could use only those things that you need.

  1. Batching

    Just apply High Ordered Reducer enableBatching and then use batch function to create batch-action.

  2. Dispatching array of actions

    Apply enableBatching and apply arrayToBatch-middleware as far from reducer as it is possible.

  3. Buffering

    Apply enableBatching and actionsBuffer-middleware as close to reducers as it is possible.

For example:

import thunk from 'redux-thunk';
import logger from 'redux-logger';
import { arrayToBatch, actionsBuffer } from 'redux-batch-buffer';

export const appMiddlewares = [thunk, arrayToBatch, actionsBuffer, logger];

About

Buffering redux-actions before dispatch them in the batch

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published