Awesome Redux Overview
Catalog of Redux Libraries & Learning Material
🏠 Home · 🔥 Feed · 📮 Subscribe · ❤️ Sponsor · 😺 brillout/awesome-redux · ⭐ 363 · 🏷️ Front-End Development
Redux Libraries & Learning Material
Redux is a state container for JavaScript apps.
- Official website:
devarchy.com/redux
- Use devarchy to add a library to the catalog
Contents
- Code Architecture
- Utilities
- Code Style
- Dev tools / Inspection tools
- React Integration
- Other Integrations
- Boilerplate
- Miscellaneous
- Learning Material
- Community
Code Architecture
Aims to improve the overall structure of the source code. Makes reasoning about the code easier.
- redux-schema (⭐157) - Automatic actions, reducers and validation for Redux.
- redux-tcomb (⭐212) - Immutable and type-checked state and actions for Redux.
- redux-action-tree (⭐227) - The Cerebral signals running with Redux.
- redux-elm (⭐496) - The Elm Architecture in JavaScript.
Utilities
- redux-orm (⭐3k) - Small, simple and immutable ORM to manage relational data in your Redux store.
- redux-api-middleware (⭐1.5k) - Redux middleware for calling an API.
- redux-ignore (⭐841) - Higher-order reducer to ignore Redux actions.
- redux-modifiers (⭐159) - Collection of generic functions for writing Redux reducers to operate on various data structures.
- rereduce (⭐166) - Reducer library for Redux.
- redux-search (⭐1.4k) - Redux bindings for client-side search.
- redux-logger (⭐5.7k) - Logger middleware for Redux.
- redux-immutable (⭐1.9k) - Redux-immutable is used to create an equivalent function of Redux combineReducers that works with Immutable.js state.
- reselect (⭐19k) - Selector library for Redux.
- redux-requests (⭐245) - Manages in-flight requests with a Redux reducer to avoid issuing duplicate requests.
- redux-undo (⭐2.8k) - Higher order reducer to add undo/redo functionality to Redux state containers.
- redux-bug-reporter (⭐689) - Bug reporter and bug playback tool for Redux.
- redux-transducers (⭐130) - Transducer utilities for Redux.
Store Persistence
- redux-storage (⭐675) - Persistence layer for Redux with flexible backends.
- redux-persist (⭐12k) - Persist and rehydrate a Redux store.
Side Effects
Side Effects / Asynchronous Actions
- redux-saga (⭐22k) - Alternative side effect model for Redux apps.
- redux-promise-middleware (⭐2k) - Redux middleware for resolving and rejecting promises with conditional optimistic updates.
- redux-effects (⭐492) - You write pure functions, redux-effects handles the rest.
- redux-thunk (⭐17k) - Thunk middleware for Redux.
- redux-connect (⭐549) - Provides decorator for resolving async props in react-router, extremely useful for handling server-side rendering in React.
- redux-loop (⭐2k) - Port of elm-effects and the Elm Architecture to Redux that allows you to sequence your effects naturally and purely by returning them from your reducers.
- redux-side-effects (⭐182) - Redux toolset for keeping all the side effects inside your reducers while maintaining their purity.
- redux-logic (⭐1.8k) - Redux middleware for organizing business logic and action side effects.
- redux-observable (⭐7.8k) - RxJS middleware for action side effects in Redux using "Epics".
- redux-ship (⭐615) - Composable, testable and typable side effects.
Code Style
Aims to make parts of the source code easier to read/write.
- redux-act (⭐1.5k) - Opinionated lib to create actions and reducers for Redux.
- redux-crud (⭐632) - Set of standard actions and reducers for Redux CRUD Applications.
Dev tools / Inspection tools
- redux-devtools-inspector (⭐240) - Another Redux DevTools Monitor.
- redux-diff-logger (⭐177) - Diff logger between states for Redux.
- redux-devtools-chart-monitor (⭐294) - Chart monitor for Redux DevTools.
- redux-devtools (⭐13k) - DevTools for Redux with hot reloading, action replay, and customizable UI.
- redux-devtools-dispatch (⭐145) - Dispatch your actions manually to test if your app Reacts well.
- redux-devtools-dock-monitor (⭐403) - Resizable and movable dock for Redux DevTools monitors.
- redux-devtools-filterable-log-monitor (⭐154) - Filterable tree view monitor for Redux DevTools.
- redux-devtools-log-monitor (⭐312) - The default monitor for Redux DevTools with a tree view.
- remote-redux-devtools (⭐1.8k) - Redux DevTools remotely.
React Integration
- redux-test-recorder (⭐492) - Redux middleware to automatically generate tests for reducers through ui interaction.
- react-redux (⭐22k) - Official React bindings for Redux.
- react-easy-universal - Universal Routing & Rendering with React & Redux was too hard. Now it's easy.
- redux-form-material-ui (⭐834) - Set of wrapper components to facilitate using Material UI with Redux Form.
Routing
- redux-async-connect (⭐650) - It allows you to request async data, store them in Redux state and connect them to your React component.
- redux-tiny-router (⭐130) - Router made for Redux and made for universal apps. Stop using the router as a controller, it's just state.
- redux-router (⭐2.3k) - Redux bindings for React Router – keep your router state inside your Redux store.
- react-router-redux (⭐7.9k) - Ruthlessly simple bindings to keep react-router and Redux in sync.
- ground-control (⭐263) - Scalable reducer management & powerful data fetching for React Router & Redux.
Forms
- redux-form (⭐13k) - Higher Order Component using react-redux to keep form state in a Redux store.
- react-redux-form (⭐2.1k) - Create forms easily in React with Redux.
Component State
- redux-react-local (⭐373) - Local component state via Redux.
- redux-ui (⭐640) - Easy UI state management for React Redux.
Other Integrations
Flux
- redux-actions (⭐6.6k) - Flux Standard Action utilities for Redux.
- redux-promise (⭐2.7k) - FSA-compliant promise middleware for Redux.
Backbone
- backbone-redux (⭐189) - Easy way to keep your backbone collections and Redux store in sync.
Falcor
- redux-falcor (⭐369) - Connect your Redux front-end to your falcor back-end.
RxJS
- redux-observable (⭐7.8k) - RxJS middleware for action side effects in Redux using "Epics".
- rx-redux (⭐421) - Reimplementation of Redux using RxJS.
- redux-rx (⭐1k) - RxJS utilities for Redux.
- redurx (⭐97) - Redux'ish Functional State Management using RxJS.
Electron
- redux-electron-store (⭐375) - Redux store enhancer that allows automatic synchronization between electron processes.
Deku
- deku-redux (⭐31) - Bindings for Redux in deku < v2.
Other
- redux-rollbar-middleware - Redux middleware that wraps exceptions in actions and sends them to Rollbar with current state.
- kasia (⭐218) - React Redux toolset for the WordPress API.
Boilerplate
Boilerplates / Scaffolds / Starter Kits / Generators / Stack Ensembles
- redux-cli (⭐890) - Opinionated CLI for building Redux/React apps quicker.
- reactuate (⭐490) - React/Redux stack (not a boilerplate kit).
- react-chrome-extension-boilerplate (⭐2.1k) - Boilerplate for Chrome Extension React.js project.
- universal-redux (⭐462) - Npm package that lets you jump right into coding React and Redux with universal (isomorphic) rendering. Only manage Express setups or Webpack configurations if you want to.
- generator-react-aspnet-boilerplate (⭐284) - Starting point for building isomorphic React applications with ASP.NET Core 1, leveraging existing techniques.
- generator-redux (⭐251) - CLI tools for Redux: next-gen functional Flux/React with devtools.
- generator-react-webpack-redux (⭐552) - React Webpack Generator including Redux support.
- socrates (⭐579) - Small (8kb), batteries-included Redux store to reduce boilerplate and promote good habits.
Miscellaneous
- redux-core (⭐42) - Minimal Redux.
Learning Material
Redux's concepts
Redux official documentation does a great job at explaining Redux's core principles.
Why immutable data structures
The guide on performance of React's official documentation explains well what immutable data structures are and why they play an important role.
Side Effects
Redux Loop's readme (⭐2k) gives a good insight on Side Effects in the context of Redux.
Reading the aforementioned material will get you a good start for writing apps with Redux. If you are curious for more, check out following resources.
Functional Programming - Basics
This post goes over basic concepts of functional programming while building a YouTube instant search demo app.
Reactive Programming
This introduction to Reactive Programming explains Reactive Programming with clarity.
Functional Programming - Going beyond
Well written article that talks about interesting computer science concepts implemented in functional languages and how these apply to JavaScript.
Monads
Curious about monads? Wikipedia gives a good overview on monads and this article explains monads in more details with graphics and simple examples.