The only working method that I found to work this out without using react-router-redux
to route from action creator async action
completion is by passing the history
prop from the component to action creator and doing:
history.push('routename');
Since BrowserRouter
ignores the history prop passed to it thus we cannot use custom history objects with browserhistory.
What is the best possible way to work this out?
Instead of using
BrowserRouter
you could use theRouter
with custom history likein which case your
history.push()
will work. With BrowserRouterhistory.push
doesn't work because Creating a newbrowserHistory
won't work because<BrowserRouter>
creates its own history instance, and listens for changes on that. So a different instance will change the url but not update the<BrowserRouter>
.Once you create a custom
history
, you can export it and then import it in youraction creator
and use it to navigate dynamically like