UseReduction
useReducer without boilerplate
Install / Use
/learn @anater/UseReductionREADME
useReduction
function App() {
const [count, actions] = useReduction(0, {
increment: (count, { payload }) => count + payload,
decrement: (count, { payload }) => count - payload
});
return (
<div>
<h1>{count}</h1>
<button onClick={() => actions.increment(2)}>+2</button>
<button onClick={() => actions.decrement(2)}>-2</button>
</div>
);
}
useReduction minimizes reducer code by automatically creating action creators from your reducer object.
Write less code by using objects instead of switch statements for defining reducers.
Debugging is baked in. In debug mode, all dispatched actions are logged to the console.
Installation
npm install use-reduction
Note: React is a peer dependency. Its assumed you already have this installed for your project.
Usage
import useReduction from "use-reduction";
// Call the hook with an initial state and a reducer object:
const initialState = 0;
const reducer = {
increment: (count, { payload }) => count + payload,
decrement: (count, { payload }) => count - payload
};
const [state, actions] = useReduction(initialState, reducer);
The hook returns the current state and an object with action creators. When an action creator is called, an action ({ type, payload }) will be dispatched to update your state.
Actions
Action names are derived from reducer names to minimize boilerplate. Providing useReduction with a reducer increment() will generate an action creator also named increment() that dispatches an action with a type “increment” and uses the first argument as payload. increment(1) would use 1 as the payload provided to the reducer.
// use actions to update count from previous example
actions.increment(1)
// count = 1
actions.decrement(2)
// count = -1
Debugging
Pass true as the third argument in useReduction to enable debug mode. It will log the dispatched action to the console.
const [state, actions] = useReduction(initialState, reducerMap, true);
Related Skills
bluebubbles
341.0kUse when you need to send or manage iMessages via BlueBubbles (recommended iMessage integration). Calls go through the generic message tool with channel="bluebubbles".
node-connect
341.0kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
slack
341.0kUse when you need to control Slack from OpenClaw via the slack tool, including reacting to messages or pinning/unpinning items in Slack channels or DMs.
frontend-design
84.4kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
