J'ai le morceau de code suivant, qui reçoit un objet historique comme prop :
const ChildComponent = ({ history }) => (
<div className={styles.body}>
<div className={styles.cta}>
<FloatingActionButton onClick={() => history.push(routes[4].path)}>
<span>Click me</span>
</FloatingActionButton>
</div>
</div>
);
Comment ajouter un contrôle de type pour cette proposition d'histoire, qui est reçu en enveloppant son parent avec withRouter HOC ? Un moyen auquel je pense est d'écrire quelque chose comme ceci :
interface Props {
history: {
push(url: string): void;
};
}
Mais je suis sûr que ce n'est pas la bonne méthode, car le reste des propriétés de l'objet historique est perdu.
Pouvez-vous me suggérer la bonne façon de procéder ?
MISE À JOUR du code basé sur la réponse de @Oblosys
import { withRouter, RouteComponentProps } from "react-router-dom";
interface Props extends RouteComponentProps<any> {
/* Parent component's props*/
}
class Parent extends React.Component<Props, {}> {
render() {
return <ChildComponent history={this.props.history} />;
}
}
//Child component related stuff
interface ChildComponentProps extends RouteComponentProps<any> {}
const ChildComponent: React.SFC<ChildComponentProps> = (props) => (
<div className={styles.body}>
<div className={styles.cta}>
<FloatingActionButton onClick={() => history.push(routes[4].path)}>
<span>Click me</span>
</FloatingActionButton>
</div>
</div>
);
function mapStateToProps(state: types.AppState) {
/* related code */
}
function mapDispatchToProps(dispatch: Redux.Dispatch<types.AppState>{
/* related code */
}
export default withRouter(connect(mapStateToProps, mapDispatchToProps)(Parent));
Mais, maintenant, j'obtiens l'erreur suivante :
Type '{ history: History; }' is not assignable to type 'ChildComponentProps'.
Property 'match' is missing in type '{ history: History; }'