npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

redux-recycle

v1.4.0

Published

higher-order reducer to reset the redux state on certain actions

Downloads

11,919

Readme

redux-recycle

NPM version (>=1.0) NPM Downloads Build Status Dependencies js-standard-style https://paypal.me/DanielBugl/9

higher-order reducer to reset the redux state on certain actions

Installation

npm install --save redux-recycle

Resetting state

import recycleState from 'redux-recycle'
recycleState(reducer, actionArray, initialState, config)

redux-recycle is a reducer enhancer (higher-order reducer), it provides the recycleState function, which takes an existing reducer and an array of actions that will reset the state.

Optionally, you can also pass an initial state to reset to.

Optionally, you can also pass a config object.

Currently, there is one config option:

  • recycleActionType (default: @@redux-recycle/INIT) - if recycleActionType is provided, the reducer function will be called with initialState and the provided action name. If set to false, the state will be reset without calling the reducer one more time.

API

import recycleState from 'redux-recycle'

// recycle the state on the following list of actions
recycleState(reducer, [ARRAY_OF_ACTIONS])

// also provide an initial state to reset to
recycleState(reducer, [ARRAY_OF_ACTIONS], initialState)

// also provide an initial state to reset to, based on the state and action passed
recycleState(reducer, [ARRAY_OF_ACTIONS], (state, action) => initialState)

// also provide the name of the action that will be called on the reducer when recycling it
recycleState(reducer, [ARRAY_OF_ACTIONS], (state, action) => initialState, {
  recycleActionType: 'MY_OWN_ACTION_NAME'
})

// recycles the state to initialState without calling the reducer with any action
recycleState(reducer, [ARRAY_OF_ACTIONS], initialState, {
  recycleActionType: false
})

Instructions

Firstly, import redux-recycle:

// Redux utility functions
import { combineReducers } from 'redux';
// redux-recycle higher-order reducer
import recycleState from 'redux-recycle';

Then, add recycleState to your reducer(s) like this:

combineReducers({
  counter: recycleState(counter, [INCREMENT_COUNTER], 0)
})

Now, once you click the increment button, the state will be reset to 0.

If you need more complex initialization logic, you can provide a reducer function as the last param. It will be called with the state and action to get the initial state.


// here you don't allow resetting counting 10 times
const resetCounter = (state, action) => {
  return state > 10 ? state : 0
}

combineReducers({
  counter: recycleState(counter, [RESET_COUNTERS], resetCounter)
})

What is this magic? How does it work?

Have a read of the Implementing Undo History recipe in the Redux documents, which explains in detail how higher-order reducers work.

License

MIT, see LICENSE.md for more information.