import React from 'react';
import { connect } from 'react-redux';
import { loadConfig } from '../actions/config';
import { loginUser } from '../actions/auth';
import { currentBackend } from '../backends/backend';
class App extends React.Component {
componentDidMount() {
this.props.dispatch(loadConfig());
}
configError(config) {
return
Error loading the CMS configuration
The "config.yml" file could not be loaded or failed to parse properly.
Error message: {config.get('error')}
;
}
configLoading() {
return
Loading configuration...
;
}
handleLogin(credentials) {
this.props.dispatch(loginUser(credentials));
}
authenticating() {
const { auth } = this.props;
const backend = currentBackend(this.props.config);
if (backend == null) {
return Waiting for backend...
;
}
return
{React.createElement(backend.authComponent(), {
onLogin: this.handleLogin.bind(this),
error: auth && auth.get('error'),
isFetching: auth && auth.get('isFetching')
})}
;
}
render() {
const { user, config, children } = this.props;
if (config === null) {
return null;
}
if (config.get('error')) {
return this.configError(config);
}
if (config.get('isFetching')) {
return this.configLoading();
}
if (user == null) {
return this.authenticating();
}
return (
{children}
);
}
}
function mapStateToProps(state) {
const { auth, config } = state;
const user = auth && auth.get('user');
return {auth, config, user};
}
export default connect(mapStateToProps)(App);