1.6.0 • Published 6 months ago

@hansogj/immer-reduxer v1.6.0

Weekly downloads
-
License
ISC
Repository
github
Last release
6 months ago

IMMER-REDUXER

npm install -s @hansogj/immer-reduxer

Provides a wrapper for immutable redux state reducers and and shortcuts to update your state on action events. For more on immer, see https://immerjs.github.io/immer/

Usage

/// in some.reducer.ts
export enum Actions {
  ERROR = 'ERROR',
  INIT = 'INIT',
  RESET = 'RESET',
}


export const initialState: AppState ({
  init: 'not initiated', // type string
  error: undefined, // type Error
});

const appReducer = reducerForProducers<AppState, ActionTypes, Actions>(initialState, {
  [Actions.INIT]: writeToDraft('init'), // writes the value of 'init' property of any action {type: "INIT", init: ... } to current state.init
  [Actions.RESET]: writeValuesToDraft({ init: 'reset', error: undefined }), // replaces state.init & state.error respectively on any action {type: "RESET", ... }
  [Actions.APP_ERROR]: passReducer,
});

// .... then define some actions ...

export const actions = {
    init: fromActionType(Actions.INIT).withData("init"),
    error: fromActionType(Actions.ERROR).withData("error"),
    reset: fromActionType(Actions.RESET).withData("init", "error"),
    // or just
    reset: fromActionType(Actions.RESET).withData(),
};

/// somewhere else in your code

dispatch(actions.init("The application is now fully initiated"));
dispatch(actions.error(new Error("something terrible happened")));
dispatch(actions.reset("", undefined));
// or just
dispatch(actions.reset());

The action functions (actions.init, actions.error, actions.reset) has now type security with their respective parameters

1.6.0

6 months ago

1.5.0

9 months ago

1.4.0

9 months ago

1.3.0

1 year ago

1.2.1

2 years ago

1.2.0

2 years ago

1.1.0

2 years ago

1.0.0

2 years ago

1.0.0-1

2 years ago