0.3.0 • Published 6 years ago

dense-redux-actions v0.3.0

Weekly downloads
27
License
MIT
Repository
github
Last release
6 years ago

dense-redux-actions

Small "class based actions creators" to get type safe actions with TypeScript, to benefit from intellisense and to enable unified naming for ease of code navigation. See this blog post for a discussion of why you might use this module.

How to install

yarn add dense-redux-actions

or 

npm install dense-redux-actions -- save

How to use

A simple example

Create a vanilla action creator:

// actions.ts
import { ActionCreator } from 'dense-redux-actions';

export const myActionCreator = new ActionCreator<string>('MY_ACTION_TYPE'); 

Dispatch an action:

import { myActionCreator } from './actions';

const mapDispatchToProps = (dispatch) => {
  return {
    on: (str: string) => dispatch(myActionCreator.create(str)),
  };
}

or from a saga

yield put(myActionCreator.create('some string payload'));    

Consume an action:

switch (action.type) {
  case myActionCreator.type: {
    const payload = myActionCreator.payload(action);
    // do something with payload
  }
}

Example for use with unified naming

Using the action type as name for the action creator makes navigating the code base easier since you don't have to remember what the creator's name is for a given type.

// actions.ts
import { ActionCreator } from 'dense-redux-actions';

interface ResourceType {
  type: string;
  id: string;
}

interface LocationType {
  region: string;
}

export const API_SOME_RESOURCE_REQUEST 
  = new ActionCreator<ResourceType, LocationType>('API_SOME_RESOURCE_REQUEST'); 

Dispatch an action:

const mapDispatchToProps = (dispatch) => {
  return {
    fetch: (resource, region) => 
      dispatch(API_SOME_RESOURCE_REQUEST.create(resource, region))
  }
}

Consume the action:

import { GenericAction } from 'dense-redux-actions'; 
import { API_SOME_RESOURCE_REQUEST } from './actions';

function* processRequests(action: GenericAction) {
  switch (action.type) {
    case API_SOME_RESOURCE_REQUEST.type: {
      const { payload, meta } = API_SOME_RESOURCE_REQUEST.unpack(action);
      ...
    }
  }
}

API

Create a new action creator:

new ActionCreator<PayloadType, MetaType?>(actionType: string)

Ex:

const ACTION = new ActionCreator<string, string>('ACTION');

or 

const ACTION = new ActionCreator<null>('ACTION');

Create a new action:

create(payload: PayloadType, meta?: MetaType): ActionType

Ex:

ACTION.create('test', 'me') // => {type: 'ACTION', _payload: 'test', _meta: 'me'}

Get typed payload from generic action:

payload(action: GenericAction): PayloadType

Ex:

const payload = ACTION.payload(action); // ex. payload: string = 'test'

Get type meta data:

meta(action: GenericAction): MetaType

Ex:

const meta = ACTION.meta(action); // ex. meta: string = 'me'

Unpack both payload and meta data:

unpack(action: GenericAction): { payload: PayloadType, meta: MetaType }

Ex:

const { payload, meta } = ACTION.unpack(action);

Destructuring - if you want to use shorthand for connect ect.

destruct(): { [actionType: string]: (payload: payloadType, meta?: MetaType) }

Ex:

// makes the prop 
// "ACTION_TYPE: (payload: payloadType, meta?: MetaType) => action" available.

const mapDispatchToProps = {
 ...ACTION.destruct(),  
}

Alternatives

If you are look for a framework for handling redux actions instead you may want to checkout:

or

0.3.0

6 years ago

0.2.2

6 years ago

0.2.1

6 years ago

0.2.0

6 years ago

0.1.3

6 years ago

0.1.2

6 years ago

0.1.0

6 years ago