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

sugarbush

v2.1.2

Published

Sugarbush is a performance enhancer for your react-redux application by replacing the Redux combinedReducers.

Downloads

22

Readme

Sugarbush

logo-sm.png

Project Source Code

Sugarbush is a performance enhancer for your react-redux application by replacing the Redux combinedReducers with switchback. Switchback will only run the corresponding reducer that matches the dispatched action type. Sugarbush also has accompanied components confingureAdaptiveStrore, and adaptiveDispatch.


Sugarbush Saga includes adaptiveSagaDispatch and sbPut (saga effect). For more information go to sugarbush-saga

Installation

Minimum Requirements: React 16.8
npm install sugarbush
yarn add sugarbush

Switchback

Switchback replaces the current combinedReducers and only processes the reducer containing the associated dispatch action type.

With most react–redux applications, we use the Redux combinedReducers to process dispatch actions to update the store state. The combinedReducers will perform a linear search (top to bottom) on all the files listed within the combinedReducers. Any dispatch action type found within a reducer, the state is mutated and passed back to the combinedReducers. When a reducer does not contain the dispatch action type, it must return its default or current state. For example, if the first reducer within the combinedReducers contains the dispatch action type, the reducer will update the state. Then the combinedReducers must continue to iterate over the remaining reducers to get their current state. This unnecessary looping process can impact the application's performance. Also, if you dispatch an action type that does not have a corresponding reducer, such as a Saga action, all the reducers are processed again with the combinedReducers.

import { switchback } from 'surgarbush'
import SystemState from './system-reducer'
import CounterState from './counter-reducer'
import StatusState from './status-reducer'
import UserState from './user-reducer'

const reducers = switchback({
  SystemState,
  CounterState,
  StatusState,
  UserState,
})

Note: switchback has two optional parameters. The first verbose (true by default) will output information to the console window. This parameter will be set to false in production environments. The second is sagaBypass. Please read more about sagaBypass at sugarbush-saga.


More setup examples of switchback with optional parameters:


  //example
   const reducers = switchback({
     SystemState,
     CounterState,
     StatusState,
   }, { sagaBypass: '@@SAGABYPASS!', verbose: false})

  //example
   const reducers = switchback({
     SystemState,
     CounterState,
     StatusState,
   }, { verbose: false, sagaBypass: '@@SAGABYPASS!'})

  //example
  const reducers = switchback({
    SystemState,
    CounterState,
    StatusState,
  }, { verbose: false })

  //example
  const reducers = switchback({
    SystemState,
    CounterState,
    StatusState,
  }, { sagaBypass: '@@SAGABYPASS!'})


According to Redux, all reduces must return state. Reducers must return state because combinedReducers creates an empty state object and then iterates over all the reducers returning a reducer's updated or current state. On the other hand, Switchback first creates a new state object from the current store state and only processes the reducer corresponding to the action key.

Note: All reducers need to return state. This is needed to build the state tree during initialization for the application


How does switchback get the key? The key is attached to the action, as shown here.

dispatch({type: 'SET_THEME', payload: 'green', key: 'SystemState'})

The key represents the alias name of the reducer listed within switchback. For example, when importing the system-reducers.ts file, the file is assigned an alias of SystemState. Then SystemState is added to the switchback list. The key for the system-reducer would be SystemState.


What if the dispatch action does not contain a key or the key does not represent a reducer listed in switchback? In this case, all reducers will be processed just like with combinedReducers.

Note: The Redux useDispatch() is still effective and will run all reducers.


To get the dispatch actions to contain a key, use one of the following configureAdaptiveStore or adaptiveDispatch components. Please see the following sections.

configureAdaptiveStore

The configureAdaptiveStore will allow the creation of dispatch actions that contain a key. To create the configureAdaptiveStore see below.

import React from 'react'
import { store } from './store'
import { Provider } from 'react-redux'
import { configureAdaptiveStore } from 'sugarbush'
import Application from '../Application'

/**
 * Create the Sugarbush AdaptiveStore
 * */
export const adpStore = configureAdaptiveStore({
  dispatch: store.dispatch
})

const App = () => {
  return (
    <div>
      <Provider store={store}>
        <Application />
      </Provider>
    </div>
  )
}

export default App

Note: The store only takes one parameter of type Redux Dispatch.


The configureAdaptiveStore contains one method called dispatch


The configureAdaptiveStore dispatch method will allow Switchback to use the key to process the corresponding reducer.

import { adpStore } from '../components/App'

export const SystemDispatch = () => adpStore.dispatch('SystemState')
export const CounterDispatch = () => adpStore.dispatch('CouterState')
export const UserDispatch = () => adpStore.dispatch('UserState')

Note: all the dispatches can be placed in one file or anywhere in the application


In a React page, the dispatches can be imported and used to dispatch an action.

import {
  SystemDispatch,
  CounterDispatch,
} from '../dispatchers'
...
const Application = () => {
  const dispatch = useDispatch()
  const systemDispatch = SystemDispatch()
  const counterDispatch = CounterDispatch()
...
useEffect(() => {
  systemDispatch(SystemActions.fetchSystemTheme())
}, [])

adaptiveDispatch

The adaptiveDispatch can be used instead of creating a configureAdaptiveStore. The syntax is more verbose and takes three parameters. The first parameter, dispatch, is of type Redux dispatch, the second key, is of type string, and the third, verbose (which is optional), of type Boolean. Information will be written out to the console window with the verbose parameter set to true. Verbose is true by default and will be set to false in a production environment.


import { store } from '../components/App/store'
import { adaptiveDispatch } from 'sugarbush'

export const CounterDispatch = () => adaptiveDispatch(
  { dispatch: store.dispatch,
    key: 'CounterState',
    verbose: true
  })

Using the CounterDispatch in a React page is the same as listed above in the configureAdaptiveStore section.


Sugarbush Saga includes adaptiveSagaDispatch and sbPut (saga effect). For more information go to sugarbush-saga

Examples:

License

MIT