|
| 1 | +/// <reference path="./redux-actions.d.ts" /> |
| 2 | + |
| 3 | +const minimalAction: ReduxActions.Action = { type: 'INCREMENT' }; |
| 4 | +const richerAction: ReduxActions.Action = { |
| 5 | + type: 'INCREMENT', |
| 6 | + payload: 2, |
| 7 | + error: false, |
| 8 | + meta: { |
| 9 | + remote: true |
| 10 | + } |
| 11 | +}; |
| 12 | + |
| 13 | +const incrementAction: (...args: any[]) => ReduxActions.Action = ReduxActions.createAction<number>( |
| 14 | + 'INCREMENT', |
| 15 | + (amount: number) => amount |
| 16 | +); |
| 17 | +const action: ReduxActions.Action = incrementAction(42); |
| 18 | + |
| 19 | +const incrementByAction: (...args: any[]) => ReduxActions.Action = ReduxActions.createAction<number>( |
| 20 | + 'INCREMENT_BY', |
| 21 | + (amount: number) => amount, |
| 22 | + amount => ({ remote: true }) |
| 23 | +); |
| 24 | + |
| 25 | +let state: number; |
| 26 | + |
| 27 | +const actionHandler = ReduxActions.handleAction<number>( |
| 28 | + 'INCREMENT', |
| 29 | + (state: number, action: ReduxActions.Action) => state + 1 |
| 30 | +); |
| 31 | +state = actionHandler(0, { type: 'INCREMENT' }); |
| 32 | + |
| 33 | +const actionHandlerWithReduceMap = ReduxActions.handleAction<number>( |
| 34 | + 'INCREMENT_BY', { |
| 35 | + next(state: number, action: ReduxActions.Action) { |
| 36 | + return state + action.payload; |
| 37 | + }, |
| 38 | + throw(state: number) { return state } |
| 39 | + } |
| 40 | +); |
| 41 | +state = actionHandlerWithReduceMap(0, { type: 'INCREMENT' }); |
| 42 | + |
| 43 | +const actionsHandler = ReduxActions.handleActions<number>({ |
| 44 | + 'INCREMENT': (state: number, action: ReduxActions.Action) => state + 1, |
| 45 | + 'DECREMENT': (state: number, action: ReduxActions.Action) => state - 1 |
| 46 | +}); |
| 47 | +state = actionsHandler(0, { type: 'INCREMENT' }); |
| 48 | + |
| 49 | +const actionsHandlerWithInitialState = ReduxActions.handleActions<number>({ |
| 50 | + 'INCREMENT': (state: number, action: ReduxActions.Action) => state + 1, |
| 51 | + 'DECREMENT': (state: number, action: ReduxActions.Action) => state - 1 |
| 52 | +}, 0); |
| 53 | +state = actionsHandlerWithInitialState(0, { type: 'INCREMENT' }); |
| 54 | + |
| 55 | + |
| 56 | + |
0 commit comments