mirror of
https://github.com/gosticks/DefinitelyTyped.git
synced 2025-10-16 12:05:41 +00:00
245 lines
6.2 KiB
TypeScript
245 lines
6.2 KiB
TypeScript
/// <reference path="react-redux.d.ts" />
|
|
/// <reference path="../react/react.d.ts"/>
|
|
/// <reference path="../redux/redux.d.ts" />
|
|
/// <reference path="../react-router/react-router.d.ts" />
|
|
/// <reference path="../object-assign/object-assign.d.ts" />
|
|
|
|
import { Component } from 'react';
|
|
import * as React from 'react';
|
|
import * as Router from 'react-router';
|
|
import { Route, RouterState } from 'react-router';
|
|
import { Store, Dispatch, bindActionCreators } from 'redux';
|
|
import { connect, Provider } from 'react-redux';
|
|
import objectAssign = require('object-assign');
|
|
|
|
//
|
|
// Quick Start
|
|
// https://github.com/rackt/react-redux/blob/master/docs/quick-start.md#quick-start
|
|
//
|
|
|
|
interface CounterState {
|
|
counter: number;
|
|
}
|
|
declare var increment: Function;
|
|
|
|
class Counter extends Component<any, any> {
|
|
render() {
|
|
return (
|
|
<button onClick={this.props.onIncrement}>
|
|
{this.props.value}
|
|
</button>
|
|
);
|
|
}
|
|
}
|
|
|
|
function mapStateToProps(state: CounterState) {
|
|
return {
|
|
value: state.counter
|
|
};
|
|
}
|
|
|
|
// Which action creators does it want to receive by props?
|
|
function mapDispatchToProps(dispatch: Dispatch) {
|
|
return {
|
|
onIncrement: () => dispatch(increment())
|
|
};
|
|
}
|
|
|
|
connect(
|
|
mapStateToProps,
|
|
mapDispatchToProps
|
|
)(Counter);
|
|
|
|
|
|
@connect(mapStateToProps)
|
|
class CounterContainer extends Component<any, any> {
|
|
|
|
}
|
|
|
|
class App extends Component<any, any> {
|
|
render(): JSX.Element {
|
|
// ...
|
|
return null;
|
|
}
|
|
}
|
|
|
|
const targetEl = document.getElementById('root');
|
|
|
|
React.render((
|
|
<Provider store={store}>
|
|
{() => <App />}
|
|
</Provider>
|
|
), targetEl);
|
|
|
|
//
|
|
// API
|
|
// https://github.com/rackt/react-redux/blob/master/docs/api.md
|
|
//
|
|
declare var routes: Route;
|
|
declare var store: Store;
|
|
declare var routerState: RouterState;
|
|
class MyRootComponent extends Component<any, any> {
|
|
|
|
}
|
|
class TodoApp extends Component<any, any> {
|
|
|
|
}
|
|
interface TodoState {
|
|
todos: string[]|string;
|
|
}
|
|
interface TodoProps {
|
|
userId: number;
|
|
}
|
|
interface DispatchProps {
|
|
addTodo(userId: number, text: string): void;
|
|
}
|
|
declare var actionCreators: () => {
|
|
action: Function;
|
|
}
|
|
declare var addTodo: () => { type: string; };
|
|
declare var todoActionCreators: { [type: string]: (...args: any[]) => any; };
|
|
declare var counterActionCreators: { [type: string]: (...args: any[]) => any; };
|
|
|
|
React.render(
|
|
<Provider store={store}>
|
|
{() => <MyRootComponent />}
|
|
</Provider>,
|
|
document.body
|
|
);
|
|
|
|
Router.run(routes, Router.HistoryLocation, (Handler, routerState) => { // note "routerState" here
|
|
React.render(
|
|
<Provider store={store}>
|
|
{/*
|
|
//TODO: error TS2339: Property 'routerState' does not exist on type 'RouteProp'.
|
|
{() => <Handler routerState={routerState} />} // note "routerState" here: important to pass it down
|
|
*/}
|
|
</Provider>,
|
|
document.getElementById('root')
|
|
);
|
|
});
|
|
|
|
//TODO: for React Router 1.0
|
|
//TODO: error TS2604: JSX element type 'Router' does not have any construct or call signatures.
|
|
//React.render(
|
|
// <Provider store={store}>
|
|
// {() => <Router history={history}>...</Router>}
|
|
// </Provider>,
|
|
// targetEl
|
|
//);
|
|
|
|
// Inject just dispatch and don't listen to store
|
|
|
|
connect()(TodoApp);
|
|
|
|
// Inject dispatch and every field in the global state
|
|
|
|
connect((state: TodoState) => state)(TodoApp);
|
|
|
|
// Inject dispatch and todos
|
|
|
|
function mapStateToProps2(state: TodoState) {
|
|
return { todos: state.todos };
|
|
}
|
|
|
|
export default connect(mapStateToProps2)(TodoApp);
|
|
|
|
// Inject todos and all action creators (addTodo, completeTodo, ...)
|
|
|
|
//function mapStateToProps(state) {
|
|
// return { todos: state.todos };
|
|
//}
|
|
|
|
connect(mapStateToProps2, actionCreators)(TodoApp);
|
|
|
|
// Inject todos and all action creators (addTodo, completeTodo, ...) as actions
|
|
|
|
//function mapStateToProps(state) {
|
|
// return { todos: state.todos };
|
|
//}
|
|
|
|
function mapDispatchToProps2(dispatch: Dispatch) {
|
|
return { actions: bindActionCreators(actionCreators, dispatch) };
|
|
}
|
|
|
|
connect(mapStateToProps2, mapDispatchToProps2)(TodoApp);
|
|
|
|
// Inject todos and a specific action creator (addTodo)
|
|
|
|
//function mapStateToProps(state) {
|
|
// return { todos: state.todos };
|
|
//}
|
|
|
|
function mapDispatchToProps3(dispatch: Dispatch) {
|
|
return bindActionCreators({ addTodo }, dispatch);
|
|
}
|
|
|
|
connect(mapStateToProps2, mapDispatchToProps3)(TodoApp);
|
|
|
|
// Inject todos, todoActionCreators as todoActions, and counterActionCreators as counterActions
|
|
|
|
//function mapStateToProps(state) {
|
|
// return { todos: state.todos };
|
|
//}
|
|
|
|
function mapDispatchToProps4(dispatch: Dispatch) {
|
|
return {
|
|
todoActions: bindActionCreators(todoActionCreators, dispatch),
|
|
counterActions: bindActionCreators(counterActionCreators, dispatch)
|
|
};
|
|
}
|
|
|
|
connect(mapStateToProps2, mapDispatchToProps4)(TodoApp);
|
|
|
|
// Inject todos, and todoActionCreators and counterActionCreators together as actions
|
|
|
|
//function mapStateToProps(state) {
|
|
// return { todos: state.todos };
|
|
//}
|
|
|
|
function mapDispatchToProps5(dispatch: Dispatch) {
|
|
return {
|
|
actions: bindActionCreators(objectAssign({}, todoActionCreators, counterActionCreators), dispatch)
|
|
};
|
|
}
|
|
|
|
connect(mapStateToProps2, mapDispatchToProps5)(TodoApp);
|
|
|
|
// Inject todos, and all todoActionCreators and counterActionCreators directly as props
|
|
|
|
//function mapStateToProps(state) {
|
|
// return { todos: state.todos };
|
|
//}
|
|
|
|
function mapDispatchToProps6(dispatch: Dispatch) {
|
|
return bindActionCreators(objectAssign({}, todoActionCreators, counterActionCreators), dispatch);
|
|
}
|
|
|
|
connect(mapStateToProps2, mapDispatchToProps6)(TodoApp);
|
|
|
|
// Inject todos of a specific user depending on props
|
|
|
|
function mapStateToProps3(state: TodoState, ownProps: TodoProps): TodoState {
|
|
return { todos: state.todos[ownProps.userId] };
|
|
}
|
|
|
|
connect(mapStateToProps3)(TodoApp);
|
|
|
|
// Inject todos of a specific user depending on props, and inject props.userId into the action
|
|
|
|
//function mapStateToProps(state) {
|
|
// return { todos: state.todos };
|
|
//}
|
|
|
|
function mergeProps(stateProps: TodoState, dispatchProps: DispatchProps, ownProps: TodoProps): DispatchProps & TodoState {
|
|
return objectAssign({}, ownProps, {
|
|
todos: stateProps.todos[ownProps.userId],
|
|
addTodo: (text: string) => dispatchProps.addTodo(ownProps.userId, text)
|
|
});
|
|
}
|
|
|
|
connect(mapStateToProps2, actionCreators, mergeProps)(TodoApp);
|
|
|
|
|
|
|