Реакции: подключенный маршрутизатор не перенаправляет пользователя после выполнения push-вызова
Я бы хотел, чтобы после успешной аутентификации моя сага перенаправляла входящего в систему пользователя на экран главной панели. Я следовал коду, описанному в следующей статье: https://github.com/supasate/connected-react-router и пример из https://github.com/supasate/connected-react-router/tree/master/examples/basic. Я вижу изменение URL при вызове команды push из саги, однако страница не перенаправляется на экран панели инструментов. Вместо этого пользователь просто остается на том же экране. Я в настоящее время работаю с response-redux v6, response v16.4.1, response-router: v4.3.1, response-router-redux v4.0.8. Что я могу делать не так?
app.js:
class App extends Component {
constructor() {
super();
this.state = {
loading: true,
loaded: false
}
}
componentDidMount() {
window.addEventListener('load', () => {
this.setState({loading: false});
setTimeout(() => this.setState({loaded: true}), 500);
});
}
render() {
const loaded = this.state.loaded;
const {history} = this.props;
return (
<div>
{!loaded && <div className={`load${this.state.loading ? '' : ' loaded'}`}>
<div className='load__icon-wrap'>
<svg className='load__icon'>
<path fill='#4ce1b6' d='M12,4V2A10,10 0 0,0 2,12H4A8,8 0 0,1 12,4Z'/>
</svg>
</div>
</div>}
<div>
<ConnectedRouter history={history}>
<Router/>
</ConnectedRouter>
</div>
</div>
)
}
}
history.js:
import { createBrowserHistory } from 'history';
export default createBrowserHistory;
store.js:
import {createStore, applyMiddleware} from 'redux';
import {reducer as reduxFormReducer} from 'redux-form';
import createSagaMiddleware from 'redux-saga';
import sagas from '../redux/sagas';
import reducers from '../redux/reducers';
import { createBrowserHistory, } from 'history';
import { routerMiddleware } from 'connected-react-router';
const history = createBrowserHistory({ basename: '/myrootpath' });
const sagaMiddleware = createSagaMiddleware();
const store = createStore(reducers(history), applyMiddleware(routerMiddleware(history), sagaMiddleware));
store.runSaga = sagaMiddleware.run(sagas);
// store.asyncReducers = {};
const action = type => store.dispatch({type })
export default store;
index.js
import React from 'react';
import App from './app/App';
import {render} from 'react-dom'
import {Provider} from 'react-redux'
import {BrowserRouter} from 'react-router-dom';
import store from './app/store';
import ScrollToTop from './app/ScrollToTop';
import { createBrowserHistory } from 'history';
const history = createBrowserHistory()
render(
<Provider store={store}>
<BrowserRouter basename='/myrootpath'>
<ScrollToTop>
<App history={history}/>
</ScrollToTop>
</BrowserRouter>
</Provider>,
document.getElementById('root')
);
код саги:
function* login(params){
try {
const api = new UserApi();
const {username, password} = params.login;
const user = yield call(api.login, {username, password});
debugger;
yield put(push('/dashboard_default'));
} catch (error) {
debugger;
yield put({ type: types.LOAD_ERROR, error });
}
}
1 ответ
Один и тот же объект истории должен использоваться в обоих местах, например, в history.js:
export default createBrowserHistory({basename: '/myrootpath'});
и в index.js и store.js:
import history from 'history';