Angular2 Redux
data:image/s3,"s3://crabby-images/b0362/b03627adc388533e4cad04ac9785b1473d2c43fd" alt="PRs Welcome"
Wrapper components for using Redux in an Angular2 application.
A full Angular 2 Redux demo can be found here: https://github.com/InfomediaLtd/angular2-redux-example
AppStore
This library includes a wrapper for the redux store. Create the wrapper AppStore by passing in the Redux appStore:
new AppStore(reduxAppStore);
All redux's store methods are supported, with the additional benefit of getting the state passed into subscribers. Here is an example of a sample component using dependency injection to get the store, subscribe to it and clean up the subscription when it is destroyed:
export class SomeComponent implements OnDestroy {
private unsubscribe:()=>void;
constructor(appStore:AppStore) {
this.unsubscribe = appStore.subscribe(state => {
});
}
public ngOnDestroy() {
this.unsubscribe();
}
}
Bootstrapping
It is recommended to create the app store in a factory, for supporting redux (and the redux dev tools) inside Angular2's zone. That means the app store will only be created once angular is bootstrapped:
import {AppStore} from "angular2-redux";
import {bootstrap} from "angular2/platform/browser";
const appStoreFactory = () => {
let reduxAppStore;
return new AppStore(reduxStore);
};
bootstrap(MyAppComponent,[provide(AppStore, { useFactory: appStoreFactory })]);
Another option is to use the provided factory, by passing in your reducers (one or more) and optional middlewares. This factory supports the thunk middleware and the redux dev tools Chrome extension out of the box. To turn on the dev tools pass the debug param in the URL query string (http://...?debug=true)
Simple creation with a single reducer:
import {AppStore,createAppStoreFactory} from "angular2-redux";
const appStoreFactory = createAppStoreFactory(counterReducer);
bootstrap(MyAppComponent,[provide(AppStore, { useFactory: appStoreFactory })]);
Creation with more options: multiple reducers, additional middleware, debugging
import {AppStore,createAppStoreFactoryWithOptions} from "angular2-redux";
const loggerMiddleware = store => next => action => {
console.log('dispatching', action);
return next(action);
}
const appStoreFactory = createAppStoreFactoryWithOptions({
reducers:{reducer1,reducer2},
additionalMiddlewares:[loggerMiddleware],
debug:true
});
bootstrap(MyAppComponent,[provide(AppStore, { useFactory: appStoreFactory })]);
Action Creators
The Actions is intended to be subclassed by action creators. It lets you bind the app store dispatch method to any action. You can use this helper function to avoid having a local property for the app store and the actions inside your Angular components.
Assuming MyActions class extends Actions you can use it like this:
@Component({
selector: 'my-component',
template: '<button (click)="someAction()">Decrement</a>'
})
export class MyComponent {
private someAction;
constructor(myActions:MyActions) {
this.someAction = myActions.createDispatcher(myActions.someAction);
}
}
If you want your actions pure or decoupled from the app store (in case you're using multiple app stores), you can pass the app store in the createDispatcher function:
constructor(myActions:MyActions, appStore:AppStore) {
this.someAction = myActions.createDispatcher(myActions.someAction, appStore);
}
### Usage example
A usage example is included in this project here: [https://github.com/InfomediaLtd/angular2-redux/tree/master/app](https://github.com/InfomediaLtd/angular2-redux/tree/master/app)
To run the included example you need [jspm](http://jspm.io/) and [live-server](https://www.npmjs.com/package/live-server):
```sh
jspm install
live-server
Maintainers
When updating code please follow these commands for checking in
git add *
npm run commit
git push origin master