mirror of
				https://github.com/reduxjs/redux-devtools.git
				synced 2025-10-25 13:11:04 +03:00 
			
		
		
		
	| - d3-state-visualizer@1.3.4 - devui@1.0.0-6 - react-base16-styling@0.8.0 - react-dock@0.3.0 - react-json-tree@0.13.0 - redux-devtools-chart-monitor@1.7.2 - redux-devtools-cli@1.0.0-4 - redux-devtools-core@1.0.0-4 - redux-devtools-dock-monitor@1.2.0 - redux-devtools-inspector@0.14.0 - redux-devtools-instrument@1.10.0 - redux-devtools-log-monitor@2.1.0 - redux-devtools-serialize@0.2.0 - redux-devtools-slider-monitor@2.0.0-5 - redux-devtools-test-generator@0.6.2 - redux-devtools-trace-monitor@0.1.3 - redux-devtools@3.7.0 - d3-state-visualizer-tree-example@0.0.2 - react-json-tree-example@1.1.0 - slider-todomvc@0.0.2 - counter-redux@0.1.0 - todomvc@0.1.0 | ||
|---|---|---|
| .. | ||
| src | ||
| test | ||
| .babelrc | ||
| .eslintignore | ||
| .eslintrc.js | ||
| CHANGELOG.md | ||
| jest.config.js | ||
| LICENSE.md | ||
| package.json | ||
| README.md | ||
| tsconfig.json | ||
Redux DevTools Instrumentation
Redux enhancer used along with Redux DevTools or Remote Redux DevTools.
Installation
npm install --save-dev redux-devtools-instrument
Usage
Add the store enhancer:
store/configureStore.js
import { createStore, applyMiddleware, compose } from 'redux';
import thunk from 'redux-thunk';
import devTools from 'remote-redux-devtools';
import reducer from '../reducers';
// Usually you import the reducer from the monitor
// or apply with createDevTools as explained in Redux DevTools
const monitorReducer = (state = {}, action) => state;
export default function configureStore(initialState) {
  const enhancer = compose(
    applyMiddleware(...middlewares),
    // other enhancers and applyMiddleware should be added before the instrumentation
    instrument(monitorReducer, { maxAge: 50 })
  );
  // Note: passing enhancer as last argument requires redux@>=3.1.0
  return createStore(reducer, initialState, enhancer);
}
API
instrument(monitorReducer, [options])
- arguments
- monitorReducer function called whenever an action is dispatched (see the example of a monitor reducer).
- options object
- maxAge number or function(currentLiftedAction, previousLiftedState) - maximum allowed actions to be stored on the history tree, the oldest actions are removed once maxAgeis reached. Can be generated dynamically with a function getting current action as argument.
- shouldCatchErrors boolean - if specified as true, whenever there's an exception in reducers, the monitors will show the error message, and next actions will not be dispatched.
- shouldRecordChanges boolean - if specified as false, it will not record the changes tillpauseRecording(false)is dispatched. Default istrue.
- pauseActionType string - if specified, whenever pauseRecording(false)lifted action is dispatched and there are actions in the history log, will add this action type. If not specified, will commit when paused.
- shouldStartLocked boolean - if specified as true, it will not allow any non-monitor actions to be dispatched tilllockChanges(false)is dispatched. Default isfalse.
- shouldHotReload boolean - if set to false, will not recompute the states on hot reloading (or on replacing the reducers). Default totrue.
- trace boolean or function - if set to true, will include stack trace for every dispatched action. You can use a function (with action object as argument) which should returnnew Error().stackstring, getting the stack outside of reducers. Default tofalse.
- traceLimit number - maximum stack trace frames to be stored (in case traceoption was provided astrue). By default it's10. Iftraceoption is a function,traceLimitwill have no effect, that should be handled there like so:trace: () => new Error().stack.split('\n').slice(0, limit+1).join('\n')(+1is needed for Chrome where's an extra 1st frame forError\n).
 
- maxAge number or function(currentLiftedAction, previousLiftedState) - maximum allowed actions to be stored on the history tree, the oldest actions are removed once 
 
License
MIT