Обходной путь для тех, кто застрял с этим: используйте mergeProps (3-й параметр connect-redux connect) и screenProps, чтобы избежать этой ошибки.
Например, этот код станет:
const AdminCompletedOrdersTab = TabNavigator({
completedOrdersTab: { screen: CompletedOrders },
rejectedOrdersTab: { screen: RejectedOrders },
cancelledOrdersTab: { screen: CancelledOrders }
});
class CompletedOrdersScreen extends Component {
static navigationOptions = {
title: "Completed Orders"
}
componentDidMount() {
this.props.screenProps.getCompletedOrders(this.props.user);
}
render() {
return(
<AdminCompletedOrdersTab
{...this.props}
{...{/* anything you need from screenProps */}}
/>
)
}
}
const mapStateToProps = (state) => {
return ({
completedOrders: state.completedOrders.completedOrders,
isLoading: state.completedOrders.isLoading,
hasError: state.completedOrders.hasError
})
}
const mapDispatchToProps = (dispatch) => {
return ({
getCompletedOrders: bindActionCreators(getCompletedOrders, dispatch)
})
}
const mergeProps = (state, dispatch, ownProps) => {
return ({
...ownProps,
screenProps: {
...ownProps.screenProps,
...state,
...dispatch,
}
})
}
export default connect(mapStateToProps, mapDispatchToProps, mergeProps)(CompletedOrdersScreen);
PS: не проверял это с mapDispatchToProps, но думаю, что это также должно работать.