Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/m0a/typescript-fsa-redux-observable
TypeScript FSA utilities for redux-observable
https://github.com/m0a/typescript-fsa-redux-observable
redux redux-observable typescript
Last synced: 2 months ago
JSON representation
TypeScript FSA utilities for redux-observable
- Host: GitHub
- URL: https://github.com/m0a/typescript-fsa-redux-observable
- Owner: m0a
- License: mit
- Created: 2017-08-08T04:09:32.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2020-07-11T08:15:12.000Z (over 4 years ago)
- Last Synced: 2024-10-23T10:56:29.345Z (3 months ago)
- Topics: redux, redux-observable, typescript
- Language: TypeScript
- Homepage:
- Size: 122 KB
- Stars: 28
- Watchers: 1
- Forks: 6
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# [TypeScript FSA](https://github.com/aikoven/typescript-fsa) utilities for redux-observable
[![npm version](https://badge.fury.io/js/typescript-fsa-redux-observable.svg)](https://badge.fury.io/js/typescript-fsa-redux-observable)
[![Build Status](https://travis-ci.org/m0a/typescript-fsa-redux-observable.svg?branch=master)](https://travis-ci.org/m0a/typescript-fsa-redux-observable)
## Installation```
yarn add typescript-fsa-redux-observable
```## API
### ofAction(action: ActionCreator)
**Example:**
```ts
// for actions
import actionCreatorFactory, { AnyAction, Action, Success } from 'typescript-fsa';// for reducers
import { reducerWithInitialState } from 'typescript-fsa-reducers';
import { combineReducers } from 'redux';//for epics
import { delay, map, tap, ignoreElements } from 'rxjs/operators';
import { ofAction, ofActionPayload } from 'typescript-fsa-redux-observable'; // <-- here
import { combineEpics, Epic, createEpicMiddleware } from 'redux-observable';//reducer
import {createStore, applyMiddleware} from 'redux';// action
const actionCreator = actionCreatorFactory();
const actions = {
increment: actionCreator.async('INCREMENT'),
decrement: actionCreator.async('DECREMENT')
};// reducers & state
interface State {
counter: number;
}const counter = reducerWithInitialState(0)
.case(actions.increment.done, state => state + 1)
.case(actions.decrement.done, state => state - 1);
const rootReducer = combineReducers({
counter
});// epics
const counterIncrementEpic: Epic>, State> =
action$ =>
action$.pipe(
ofActionPayload(actions.increment.started),
delay(300),
map(payload => actions.increment.done({
params: payload,
result: undefined
}))
);const counterDecrementEpic: Epic>, State> =
action$ =>
action$.pipe(
ofActionPayload(actions.decrement.started),
delay(300),
map(payload => actions.decrement.done({
params: payload,
result: undefined
}))
);const loggingEpic: Epic =
action$ =>
action$.pipe(
ofAction(
actions.decrement.started,
actions.increment.started,
),
tap(action => console.log(action.type)),
ignoreElements()
);const rootEpic = combineEpics(
counterIncrementEpic,
counterDecrementEpic,
loggingEpic,
);const epicMiddleware = createEpicMiddleware();
const store = createStore(rootReducer, applyMiddleware(epicMiddleware));
epicMiddleware.run(rootEpic);// tool
async function sleep(time: number) {
return new Promise(resolve => {
setTimeout(() => (resolve()), time)
})
}it("increment decrement test", async () => {
expect(store.getState()).toEqual({ counter: 0 });store.dispatch(actions.increment.started(undefined));
expect(store.getState()).toEqual({ counter: 0 });await sleep(300);
expect(store.getState()).toEqual({ counter: 1 });store.dispatch(actions.decrement.started(undefined));
expect(store.getState()).toEqual({ counter: 1 });await sleep(300);
expect(store.getState()).toEqual({ counter: 0 })
});```