Skip to content

davidmarne/built_redux_thunk

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Thunks

By adding the thunkMiddleware to any of your built_redux stores, any action dispatched that's payload meets the typedef signature dynamic thunk(MiddlewareApi api) will be called.

Example

Create a function that returns a thunk configured with an url, that dispatches an action (onRequestResolved) in async code:

// api's type is inferred
Thunk<TestCounter, TestCounterBuilder, TestCounterActions> httpRequestThunk(String url) => (api) {
  // call the web server asynchronously.
  HttpRequest.getString(url)
      .then(api.actions.onRequestResolved);
};

Add an thunk dispatcher to your ReduxActions:

abstract class CounterActions extends ReduxActions {
  ActionDispatcher<Thunk<Counter, CounterBuilder, CounterActions>> thunkDispatcher;
  ActionDispatcher<String> onRequestResolved;

  // factory to create on instance of the generated implementation of CounterActions
  CounterActions._();
  factory CounterActions() => new _$CounterActions();
}

The action with Thunk isn't mapped to a reducer.

Register the Thunk middleware:

var store = new Store<Counter, CounterBuilder, CounterActions>(
  createReducer(),
  new Counter(),
  new CounterActions(),
  middleware: <Middleware<TestCounter, TestCounterBuilder, TestCounterActions>>[
    thunkMiddleware
  ],
);

Dispatch the thunk

store.actions.thunkDispatcher(httpRquestThunk('http://example.com/'));

About

thunk middleware for built_redux

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages