mirror of
https://github.com/reduxjs/redux-devtools.git
synced 2025-02-18 20:40:58 +03:00
111 lines
5.2 KiB
Markdown
111 lines
5.2 KiB
Markdown
Redux DevTools
|
||
=========================
|
||
|
||
A live-editing time travel environment for [Redux](https://github.com/rackt/redux).
|
||
**[See Dan's React Europe talk demoing it!](http://youtube.com/watch?v=xsSnOQynTHs)**
|
||
|
||
[data:image/s3,"s3://crabby-images/ddd41/ddd416dee040e4d7d406034782cc1d2a3abb8ab2" alt="build status"](https://travis-ci.org/gaearon/redux-devtools)
|
||
[data:image/s3,"s3://crabby-images/d694f/d694fd3ff6ae6cfadab44b12c4da699cc91bda87" alt="npm version"](https://www.npmjs.com/package/redux-devtools)
|
||
[data:image/s3,"s3://crabby-images/65eb6/65eb6a5461da02b7a70a6a5ef8f09afe8e1f34f2" alt="npm downloads"](https://www.npmjs.com/package/redux-devtools)
|
||
[data:image/s3,"s3://crabby-images/41b9b/41b9bcfdc60f0e62b0766307b8e6b94e95e8f07f" alt="redux channel on discord"](https://discord.gg/0ZcbPKXt5bWb10Ma)
|
||
|
||
data:image/s3,"s3://crabby-images/969b9/969b99b562112827c81e4e53a4b5410fa02edecf" alt=""
|
||
|
||
### Features
|
||
|
||
* Lets you inspect every state and action payload
|
||
* Lets you go back in time by “cancelling” actions
|
||
* If you change the reducer code, each “staged” action will be re-evaluated
|
||
* If the reducers throw, you will see during which action this happened, and what the error was
|
||
* With `persistState()` store enhancer, you can persist debug sessions across page reloads
|
||
|
||
### Overview
|
||
|
||
Redux DevTools is a development time package that provides power-ups for your Redux development workflow. Be careful to strip its code in production! To use Redux DevTools, you need to choose a “monitor”—a React component that will serve as a UI for the DevTools. Different tasks and workflows require different UIs, so Redux DevTools is built to be flexible in this regard. We recommend using [`LogMonitor`](https://github.com/gaearon/redux-devtools-log-monitor) for inspecting the state and time travel, and wrap it in a [`DockMonitor`](https://github.com/gaearon/redux-devtools-dock-monitor) to quickly move it across the screen. That said, when you’re comfortable rolling up your own setup, feel free to do this, and share it with us.
|
||
|
||
### Chrome Extension
|
||
|
||
If you don’t want to bother with installing Redux DevTools and integrating it into your project, consider using [Redux DevTools Chrome Extension](https://github.com/zalmoxisus/redux-devtools-extension). It provides access to the most popular monitors, is easy to configure to filter actions, and doesn’t require installing any packages.
|
||
|
||
### Walkthrough
|
||
|
||
Read the [walkthrough](./docs/Walkthrough.md) for the integration instructions.
|
||
|
||
### Running Examples
|
||
|
||
Clone the project:
|
||
|
||
```
|
||
git clone https://github.com/gaearon/redux-devtools.git
|
||
cd redux-devtools
|
||
```
|
||
|
||
Run `npm install` in the root folder:
|
||
|
||
```
|
||
npm install
|
||
```
|
||
|
||
Now you can open an example folder and run `npm install` there:
|
||
|
||
```
|
||
cd examples/counter # or examples/todomvc
|
||
npm install
|
||
```
|
||
|
||
Finally, run the development server and open the page:
|
||
|
||
```
|
||
npm start
|
||
open http://localhost:3000
|
||
```
|
||
|
||
Try clicking on actions in the log, or changing some code inside the reducers. You should see the action log re-evaluate the state on every code change.
|
||
|
||
Also try opening `http://localhost:3000/?debug_session=123`, click around, and then refresh. You should see that all actions have been restored from the local storage.
|
||
|
||
### Custom Monitors
|
||
|
||
**DevTools accepts monitor components so you can build a completely custom UI.** [`LogMonitor`](https://github.com/gaearon/redux-devtools-log-monitor) and [`DockMonitor`](https://github.com/gaearon/redux-devtools-dock-monitor) are just examples of what is possible.
|
||
|
||
**[I challenge you to build a custom monitor for Redux DevTools!](https://github.com/gaearon/redux-devtools/issues/3)**
|
||
|
||
Some crazy ideas for custom monitors:
|
||
|
||
* A slider that lets you jump between computed states just by dragging it
|
||
* An in-app layer that shows the last N states right in the app (e.g. for animation)
|
||
* A time machine like interface where the last N states of your app reside on different Z layers
|
||
* Feel free to come up with and implement your own! Check [`LogMonitor`](https://github.com/gaearon/redux-devtools-log-monitor) `propTypes` to see what you can do.
|
||
|
||
In fact some of these are implemented already:
|
||
|
||
#### [Slider Monitor](https://github.com/calesce/redux-slider-monitor)
|
||
|
||
data:image/s3,"s3://crabby-images/bc70b/bc70be8be344cd39f193426e2404ce933c1b7786" alt=""
|
||
|
||
#### [Diff Monitor](https://github.com/whetstone/redux-devtools-diff-monitor)
|
||
|
||
data:image/s3,"s3://crabby-images/080a3/080a3c9a81ba236ad13031cb0a08ffc28e89a499" alt=""
|
||
|
||
#### [Filterable Log Monitor](https://github.com/bvaughn/redux-devtools-filterable-log-monitor/)
|
||
|
||
data:image/s3,"s3://crabby-images/61cee/61cee2855f4fa38edce9b1b9b90f3c1377f1198d" alt="redux-devtools-filterable-log-monitor"
|
||
|
||
#### [Chart Monitor](https://github.com/romseguy/redux-devtools-chart-monitor)
|
||
|
||
data:image/s3,"s3://crabby-images/46e92/46e92de607dfdd2ceef24b3e768eeb41d75154de" alt="redux-devtools-chart-monitor"
|
||
|
||
#### [Filter Actions](https://github.com/zalmoxisus/redux-devtools-filter-actions)
|
||
|
||
(Does not have a UI but can wrap any other monitor)
|
||
|
||
<img src='http://i.imgur.com/TlqnU0J.png' width='400'>
|
||
|
||
#### Keep them coming!
|
||
|
||
Create a PR to add your custom monitor.
|
||
|
||
### License
|
||
|
||
MIT
|